Merge branch '2316_code_cleanup'

* 2316_code_cleanup:
  Ticket #2337: Check for inode count instead of block count
  Fixed formatting after autoformatting.
  Don't reset use_subshell variable twice.
  Function movements.
  Removed panel command wrappers.
  Ticket #2316: code cleanup before 4.7.4 release.
This commit is contained in:
Andrew Borodin 2010-09-06 15:34:23 +04:00
commit 9f2ceeea7a
9 changed files with 197 additions and 278 deletions

View File

@ -564,9 +564,6 @@ mc_args_process (int argc, char *argv[])
#ifdef HAVE_SUBSHELL_SUPPORT #ifdef HAVE_SUBSHELL_SUPPORT
if (mc_args__nouse_subshell) if (mc_args__nouse_subshell)
use_subshell = 0; use_subshell = 0;
if (mc_args__nouse_subshell)
use_subshell = 0;
#endif /* HAVE_SUBSHELL_SUPPORT */ #endif /* HAVE_SUBSHELL_SUPPORT */
mc_setup_by_args (argc, argv); mc_setup_by_args (argc, argv);

View File

@ -413,7 +413,7 @@ confirm_box (void)
/* TRANSLATORS: no need to translate 'Confirmation', it's just a context prefix */ /* TRANSLATORS: no need to translate 'Confirmation', it's just a context prefix */
/* 2 */ QUICK_CHECKBOX (3, 46, 8, 13, N_("Confirmation|&History cleanup"), /* 2 */ QUICK_CHECKBOX (3, 46, 8, 13, N_("Confirmation|&History cleanup"),
&confirm_history_cleanup), &confirm_history_cleanup),
/* 3 */ QUICK_CHECKBOX (3, 46, 7, 13, N_("Confirmation|&Directory hotlist delete"), /* 3 */ QUICK_CHECKBOX (3, 46, 7, 13, N_("Confirmation|Di&rectory hotlist delete"),
&confirm_directory_hotlist_delete), &confirm_directory_hotlist_delete),
/* 4 */ QUICK_CHECKBOX (3, 46, 6, 13, N_("Confirmation|E&xit"), &confirm_exit), /* 4 */ QUICK_CHECKBOX (3, 46, 6, 13, N_("Confirmation|E&xit"), &confirm_exit),
/* 5 */ QUICK_CHECKBOX (3, 46, 5, 13, N_("Confirmation|&Execute"), &confirm_execute), /* 5 */ QUICK_CHECKBOX (3, 46, 5, 13, N_("Confirmation|&Execute"), &confirm_execute),

View File

@ -1245,7 +1245,7 @@ nice_cd (const char *text, const char *xtext, const char *help,
else else
cd_path = g_strconcat (prefix, machine, to_home ? "/~/" : (char *) NULL, (char *) NULL); cd_path = g_strconcat (prefix, machine, to_home ? "/~/" : (char *) NULL, (char *) NULL);
if (do_panel_cd (MENU_PANEL, cd_path, 0)) if (do_panel_cd (MENU_PANEL, cd_path, cd_parse_command))
directory_history_add (MENU_PANEL, (MENU_PANEL)->cwd); directory_history_add (MENU_PANEL, (MENU_PANEL)->cwd);
else else
message (D_ERROR, MSG_ERROR, _("Cannot chdir to %s"), cd_path); message (D_ERROR, MSG_ERROR, _("Cannot chdir to %s"), cd_path);

View File

@ -127,7 +127,7 @@ info_show_info (struct WInfo *info)
if (myfs_stats.nfree > 0 || myfs_stats.nodes > 0) if (myfs_stats.nfree > 0 || myfs_stats.nodes > 0)
tty_printf (_("Free nodes: %ld (%ld%%) of %ld"), tty_printf (_("Free nodes: %ld (%ld%%) of %ld"),
(size_t) myfs_stats.nfree, (size_t) myfs_stats.nfree,
myfs_stats.total != 0 myfs_stats.nodes != 0
? 100 * (size_t) myfs_stats.nfree / (size_t) myfs_stats.nodes : 0, ? 100 * (size_t) myfs_stats.nfree / (size_t) myfs_stats.nodes : 0,
(size_t) myfs_stats.nodes); (size_t) myfs_stats.nodes);
else else

View File

@ -389,180 +389,12 @@ subshell_chdir (const char *directory)
#endif /* HAVE_SUBSHELL_SUPPORT */ #endif /* HAVE_SUBSHELL_SUPPORT */
} }
void
directory_history_add (struct WPanel *panel, const char *dir)
{
char *tmp;
tmp = g_strdup (dir);
strip_password (tmp, 1);
panel->dir_history = list_append_unique (panel->dir_history, tmp);
}
/*
* If we moved to the parent directory move the selection pointer to
* the old directory name; If we leave VFS dir, remove FS specificator.
*
* You do _NOT_ want to add any vfs aware code here. <pavel@ucw.cz>
*/
static const char *
get_parent_dir_name (const char *cwd, const char *lwd)
{
size_t llen, clen;
llen = strlen (lwd);
clen = strlen (cwd);
if (llen > clen)
{
const char *p;
p = strrchr (lwd, PATH_SEP);
if ((p != NULL)
&& (strncmp (cwd, lwd, (size_t) (p - lwd)) == 0)
&& (clen == (size_t) (p - lwd)
|| ((p == lwd) && (cwd[0] == PATH_SEP) && (cwd[1] == '\0'))))
return (p + 1);
}
return NULL;
}
/*
* Changes the current directory of the panel.
* Don't record change in the directory history.
*/
static int
_do_panel_cd (WPanel * panel, const char *new_dir, enum cd_enum cd_type)
{
const char *directory;
char *olddir;
char temp[MC_MAXPATHLEN];
char *translated_url;
if (cd_type == cd_parse_command)
{
while (*new_dir == ' ')
new_dir++;
}
olddir = g_strdup (panel->cwd);
new_dir = translated_url = vfs_translate_url (new_dir);
/* Convert *new_path to a suitable pathname, handle ~user */
if (cd_type == cd_parse_command)
{
if (!strcmp (new_dir, "-"))
{
strcpy (temp, panel->lwd);
new_dir = temp;
}
}
directory = *new_dir ? new_dir : home_dir;
if (mc_chdir (directory) == -1)
{
strcpy (panel->cwd, olddir);
g_free (olddir);
g_free (translated_url);
return 0;
}
g_free (translated_url);
/* Success: save previous directory, shutdown status of previous dir */
strcpy (panel->lwd, olddir);
free_completions (cmdline);
mc_get_current_wd (panel->cwd, sizeof (panel->cwd) - 2);
vfs_release_path (olddir);
subshell_chdir (panel->cwd);
/* Reload current panel */
panel_clean_dir (panel);
panel->count =
do_load_dir (panel->cwd, &panel->dir, panel->current_sort_field->sort_routine,
panel->reverse, panel->case_sensitive, panel->exec_first, panel->filter);
try_to_select (panel, get_parent_dir_name (panel->cwd, olddir));
load_hint (0);
panel->dirty = 1;
update_xterm_title_path ();
g_free (olddir);
return 1;
}
/*
* Changes the current directory of the panel.
* Record change in the directory history.
*/
int
do_panel_cd (struct WPanel *panel, const char *new_dir, enum cd_enum cd_type)
{
int r;
r = _do_panel_cd (panel, new_dir, cd_type);
if (r)
directory_history_add (panel, panel->cwd);
return r;
}
int int
do_cd (const char *new_dir, enum cd_enum exact) do_cd (const char *new_dir, enum cd_enum exact)
{ {
return (do_panel_cd (current_panel, new_dir, exact)); return (do_panel_cd (current_panel, new_dir, exact));
} }
void
directory_history_next (WPanel * panel)
{
GList *nextdir;
nextdir = g_list_next (panel->dir_history);
if (!nextdir)
return;
if (_do_panel_cd (panel, (char *) nextdir->data, cd_exact))
panel->dir_history = nextdir;
}
void
directory_history_prev (WPanel * panel)
{
GList *prevdir;
prevdir = g_list_previous (panel->dir_history);
if (!prevdir)
return;
if (_do_panel_cd (panel, (char *) prevdir->data, cd_exact))
panel->dir_history = prevdir;
}
void
directory_history_list (WPanel * panel)
{
char *s;
s = show_hist (&panel->dir_history, &panel->widget);
if (s != NULL)
{
if (_do_panel_cd (panel, s, cd_exact))
directory_history_add (panel, panel->cwd);
else
message (D_ERROR, MSG_ERROR, _("Cannot change directory"));
g_free (s);
}
}
#ifdef HAVE_SUBSHELL_SUPPORT #ifdef HAVE_SUBSHELL_SUPPORT
int int
load_prompt (int fd, void *unused) load_prompt (int fd, void *unused)

View File

@ -110,7 +110,7 @@ enum cd_enum
cd_exact cd_exact
}; };
int do_cd (const char *new_dir, enum cd_enum cd_type); /* For find.c */ int do_cd (const char *new_dir, enum cd_enum cd_type);
void sort_cmd (void); void sort_cmd (void);
void change_panel (void); void change_panel (void);
void save_cwds_stat (void); void save_cwds_stat (void);
@ -136,9 +136,4 @@ void init_menu (void);
char *remove_encoding_from_path (const char *); char *remove_encoding_from_path (const char *);
struct WPanel;
void directory_history_add (struct WPanel *panel, const char *dir);
int do_panel_cd (struct WPanel *panel, const char *new_dir, enum cd_enum cd_type);
#endif /* MC_MAIN_H */ #endif /* MC_MAIN_H */

View File

@ -12,6 +12,7 @@
#include "dir.h" /* dir_list */ #include "dir.h" /* dir_list */
#include "dialog.h" /* Widget */ #include "dialog.h" /* Widget */
#include "main.h" /* cd_enum */
#define selection(p) (&(p->dir.list[p->selected])) #define selection(p) (&(p->dir.list[p->selected]))
#define DEFAULT_USER_FORMAT "half type name | size | perm" #define DEFAULT_USER_FORMAT "half type name | size | perm"
@ -140,9 +141,9 @@ void recalculate_panel_summary (WPanel *panel);
void file_mark (WPanel *panel, int idx, int val); void file_mark (WPanel *panel, int idx, int val);
void do_file_mark (WPanel *panel, int idx, int val); void do_file_mark (WPanel *panel, int idx, int val);
void directory_history_next (WPanel *panel); gboolean do_panel_cd (struct WPanel *panel, const char *new_dir, enum cd_enum cd_type);
void directory_history_prev (WPanel *panel);
void directory_history_list (WPanel *panel); void directory_history_add (struct WPanel *panel, const char *dir);
gsize panel_get_num_of_sortable_fields(void); gsize panel_get_num_of_sortable_fields(void);
const char **panel_get_sortable_fields(gsize *); const char **panel_get_sortable_fields(gsize *);

View File

@ -34,10 +34,10 @@
#include "lib/global.h" #include "lib/global.h"
#include "lib/tty/tty.h" #include "lib/tty/tty.h"
#include "lib/skin.h"
#include "lib/strescape.h"
#include "lib/tty/mouse.h" /* For Gpm_Event */ #include "lib/tty/mouse.h" /* For Gpm_Event */
#include "lib/tty/key.h" /* XCTRL and ALT macros */ #include "lib/tty/key.h" /* XCTRL and ALT macros */
#include "lib/skin.h"
#include "lib/strescape.h"
#include "lib/filehighlight.h" #include "lib/filehighlight.h"
#include "lib/mcconfig.h" #include "lib/mcconfig.h"
#include "lib/vfs/mc-vfs/vfs.h" #include "lib/vfs/mc-vfs/vfs.h"
@ -2813,60 +2813,155 @@ panel_set_sort_type_by_id (WPanel * panel, const char *name)
panel_set_sort_order (panel, panel->current_sort_field); panel_set_sort_order (panel, panel->current_sort_field);
} }
typedef void (*panel_key_callback) (WPanel *); /*
* If we moved to the parent directory move the selection pointer to
* the old directory name; If we leave VFS dir, remove FS specificator.
*
* You do _NOT_ want to add any vfs aware code here. <pavel@ucw.cz>
*/
static const char *
get_parent_dir_name (const char *cwd, const char *lwd)
{
size_t llen, clen;
llen = strlen (lwd);
clen = strlen (cwd);
if (llen > clen)
{
const char *p;
p = strrchr (lwd, PATH_SEP);
if ((p != NULL)
&& (strncmp (cwd, lwd, (size_t) (p - lwd)) == 0)
&& (clen == (size_t) (p - lwd)
|| ((p == lwd) && (cwd[0] == PATH_SEP) && (cwd[1] == '\0'))))
return (p + 1);
}
return NULL;
}
/*
* Changes the current directory of the panel.
* Don't record change in the directory history.
*/
static gboolean
_do_panel_cd (WPanel * panel, const char *new_dir, enum cd_enum cd_type)
{
const char *directory;
char *olddir;
char temp[MC_MAXPATHLEN];
char *translated_url;
if (cd_type == cd_parse_command)
{
while (*new_dir == ' ')
new_dir++;
}
olddir = g_strdup (panel->cwd);
new_dir = translated_url = vfs_translate_url (new_dir);
/* Convert *new_path to a suitable pathname, handle ~user */
if (cd_type == cd_parse_command)
{
if (!strcmp (new_dir, "-"))
{
strcpy (temp, panel->lwd);
new_dir = temp;
}
}
directory = *new_dir ? new_dir : home_dir;
if (mc_chdir (directory) == -1)
{
strcpy (panel->cwd, olddir);
g_free (olddir);
g_free (translated_url);
return FALSE;
}
g_free (translated_url);
/* Success: save previous directory, shutdown status of previous dir */
strcpy (panel->lwd, olddir);
free_completions (cmdline);
mc_get_current_wd (panel->cwd, sizeof (panel->cwd) - 2);
vfs_release_path (olddir);
subshell_chdir (panel->cwd);
/* Reload current panel */
panel_clean_dir (panel);
panel->count =
do_load_dir (panel->cwd, &panel->dir, panel->current_sort_field->sort_routine,
panel->reverse, panel->case_sensitive, panel->exec_first, panel->filter);
try_to_select (panel, get_parent_dir_name (panel->cwd, olddir));
load_hint (0);
panel->dirty = 1;
update_xterm_title_path ();
g_free (olddir);
return TRUE;
}
/*
* Changes the current directory of the panel.
* Record change in the directory history.
*/
gboolean
do_panel_cd (struct WPanel *panel, const char *new_dir, enum cd_enum cd_type)
{
gboolean r;
r = _do_panel_cd (panel, new_dir, cd_type);
if (r)
directory_history_add (panel, panel->cwd);
return r;
}
static void static void
cmd_do_enter (WPanel * wp) directory_history_next (WPanel * panel)
{ {
(void) do_enter (wp); GList *nextdir;
nextdir = g_list_next (panel->dir_history);
if ((nextdir != NULL) && (_do_panel_cd (panel, (char *) nextdir->data, cd_exact)))
panel->dir_history = nextdir;
} }
static void static void
cmd_view_simple (WPanel * wp) directory_history_prev (WPanel * panel)
{ {
(void) wp; GList *prevdir;
view_simple_cmd ();
prevdir = g_list_previous (panel->dir_history);
if ((prevdir != NULL) && (_do_panel_cd (panel, (char *) prevdir->data, cd_exact)))
panel->dir_history = prevdir;
} }
static void static void
cmd_edit_new (WPanel * wp) directory_history_list (WPanel * panel)
{ {
(void) wp; char *s;
edit_cmd_new ();
} s = show_hist (&panel->dir_history, &panel->widget);
static void
cmd_copy_local (WPanel * wp) if (s != NULL)
{ {
(void) wp; if (_do_panel_cd (panel, s, cd_exact))
copy_cmd_local (); directory_history_add (panel, panel->cwd);
} else
static void message (D_ERROR, MSG_ERROR, _("Cannot change directory"));
cmd_rename_local (WPanel * wp) g_free (s);
{ }
(void) wp;
rename_cmd_local ();
}
static void
cmd_delete_local (WPanel * wp)
{
(void) wp;
delete_cmd_local ();
}
static void
cmd_select (WPanel * wp)
{
(void) wp;
select_cmd ();
}
static void
cmd_unselect (WPanel * wp)
{
(void) wp;
unselect_cmd ();
}
static void
cmd_reverse_selection (WPanel * wp)
{
(void) wp;
reverse_selection_cmd ();
} }
static cb_ret_t static cb_ret_t
@ -2886,31 +2981,31 @@ panel_execute_cmd (WPanel * panel, unsigned long command)
chdir_to_readlink (panel); chdir_to_readlink (panel);
break; break;
case CK_PanelCmdCopyLocal: case CK_PanelCmdCopyLocal:
cmd_copy_local (panel); copy_cmd_local ();
break; break;
case CK_PanelCmdDeleteLocal: case CK_PanelCmdDeleteLocal:
cmd_delete_local (panel); delete_cmd_local ();
break; break;
case CK_PanelCmdDoEnter: case CK_PanelCmdDoEnter:
cmd_do_enter (panel); do_enter (panel);
break; break;
case CK_PanelCmdViewSimple: case CK_PanelCmdViewSimple:
cmd_view_simple (panel); view_simple_cmd ();
break; break;
case CK_PanelCmdEditNew: case CK_PanelCmdEditNew:
cmd_edit_new (panel); edit_cmd_new ();
break; break;
case CK_PanelCmdRenameLocal: case CK_PanelCmdRenameLocal:
cmd_rename_local (panel); rename_cmd_local ();
break; break;
case CK_PanelCmdReverseSelection: case CK_PanelCmdReverseSelection:
cmd_reverse_selection (panel); reverse_selection_cmd ();
break; break;
case CK_PanelCmdSelect: case CK_PanelCmdSelect:
cmd_select (panel); select_cmd ();
break; break;
case CK_PanelCmdUnselect: case CK_PanelCmdUnselect:
cmd_unselect (panel); unselect_cmd ();
break; break;
case CK_PanelNextPage: case CK_PanelNextPage:
next_page (panel); next_page (panel);
@ -3425,7 +3520,7 @@ set_panel_encoding (WPanel * panel)
/* No translation */ /* No translation */
g_free (init_translation_table (display_codepage, display_codepage)); g_free (init_translation_table (display_codepage, display_codepage));
cd_path = remove_encoding_from_path (panel->cwd); cd_path = remove_encoding_from_path (panel->cwd);
do_panel_cd (panel, cd_path, 0); do_panel_cd (panel, cd_path, cd_parse_command);
g_free (cd_path); g_free (cd_path);
return; return;
} }
@ -3445,7 +3540,7 @@ set_panel_encoding (WPanel * panel)
if (encoding != NULL) if (encoding != NULL)
{ {
cd_path = add_encoding_to_path (panel->cwd, encoding); cd_path = add_encoding_to_path (panel->cwd, encoding);
if (!do_panel_cd (panel, cd_path, 0)) if (!do_panel_cd (panel, cd_path, cd_parse_command))
message (D_ERROR, MSG_ERROR, _("Cannot chdir to \"%s\""), cd_path); message (D_ERROR, MSG_ERROR, _("Cannot chdir to \"%s\""), cd_path);
g_free (cd_path); g_free (cd_path);
} }
@ -3571,6 +3666,17 @@ update_panels (int force_update, const char *current_file)
ret = mc_chdir (panel->cwd); ret = mc_chdir (panel->cwd);
} }
void
directory_history_add (struct WPanel *panel, const char *dir)
{
char *tmp;
tmp = g_strdup (dir);
strip_password (tmp, 1);
panel->dir_history = list_append_unique (panel->dir_history, tmp);
}
gsize gsize
panel_get_num_of_sortable_fields (void) panel_get_num_of_sortable_fields (void)
{ {
@ -3582,7 +3688,6 @@ panel_get_num_of_sortable_fields (void)
return ret; return ret;
} }
const char ** const char **
panel_get_sortable_fields (gsize * array_size) panel_get_sortable_fields (gsize * array_size)
{ {

View File

@ -110,12 +110,10 @@ static const char subshell_switch_key = XCTRL ('o') & 255;
* INACTIVE: the default state; awaiting a command * INACTIVE: the default state; awaiting a command
* ACTIVE: remain in the shell until the user hits `subshell_switch_key' * ACTIVE: remain in the shell until the user hits `subshell_switch_key'
* RUNNING_COMMAND: return to MC when the current command finishes */ * RUNNING_COMMAND: return to MC when the current command finishes */
enum subshell_state_enum enum subshell_state_enum subshell_state;
subshell_state;
/* Holds the latest prompt captured from the subshell */ /* Holds the latest prompt captured from the subshell */
char * char *subshell_prompt = NULL;
subshell_prompt = NULL;
/* Initial length of the buffer for the subshell's prompt */ /* Initial length of the buffer for the subshell's prompt */
#define INITIAL_PROMPT_SIZE 10 #define INITIAL_PROMPT_SIZE 10
@ -127,62 +125,53 @@ static const char subshell_switch_key = XCTRL ('o') & 255;
#define PTY_BUFFER_SIZE BUF_SMALL /* Arbitrary; but keep it >= 80 */ #define PTY_BUFFER_SIZE BUF_SMALL /* Arbitrary; but keep it >= 80 */
/* For pipes */ /* For pipes */
enum enum
{ {
READ = 0, WRITE = 1 }; READ = 0,
WRITE = 1
};
static char static char pty_buffer[PTY_BUFFER_SIZE] = "\0"; /* For reading/writing on the subshell's pty */
pty_buffer[PTY_BUFFER_SIZE] = "\0"; /* For reading/writing on the subshell's pty */ static int subshell_pipe[2]; /* To pass CWD info from the subshell to MC */
static int static pid_t subshell_pid = 1; /* The subshell's process ID */
subshell_pipe[2]; /* To pass CWD info from the subshell to MC */ static char subshell_cwd[MC_MAXPATHLEN + 1]; /* One extra char for final '\n' */
static pid_t
subshell_pid = 1; /* The subshell's process ID */
static char
subshell_cwd[MC_MAXPATHLEN + 1]; /* One extra char for final '\n' */
/* Subshell type (gleaned from the SHELL environment variable, if available) */ /* Subshell type (gleaned from the SHELL environment variable, if available) */
static enum static enum
{ {
BASH, BASH,
TCSH, TCSH,
ZSH, ZSH,
FISH FISH
} subshell_type; } subshell_type;
/* Flag to indicate whether the subshell is ready for next command */ /* Flag to indicate whether the subshell is ready for next command */
static int static int subshell_ready;
subshell_ready;
/* The following two flags can be changed by the SIGCHLD handler. This is */ /* The following two flags can be changed by the SIGCHLD handler. This is */
/* OK, because the `int' type is updated atomically on all known machines */ /* OK, because the `int' type is updated atomically on all known machines */
static volatile int static volatile int subshell_alive, subshell_stopped;
subshell_alive,
subshell_stopped;
/* We store the terminal's initial mode here so that we can configure /* We store the terminal's initial mode here so that we can configure
the pty similarly, and also so we can restore the real terminal to the pty similarly, and also so we can restore the real terminal to
sanity if we have to exit abruptly */ sanity if we have to exit abruptly */
static struct termios static struct termios shell_mode;
shell_mode;
/* This is a transparent mode for the terminal where MC is running on */ /* This is a transparent mode for the terminal where MC is running on */
/* It is used when the shell is active, so that the control signals */ /* It is used when the shell is active, so that the control signals */
/* are delivered to the shell pty */ /* are delivered to the shell pty */
static struct termios static struct termios raw_mode;
raw_mode;
/* This counter indicates how many characters of prompt we have read */ /* This counter indicates how many characters of prompt we have read */
/* FIXME: try to figure out why this had to become global */ /* FIXME: try to figure out why this had to become global */
static int static int prompt_pos;
prompt_pos;
/* /*
* Write all data, even if the write() call is interrupted. * Write all data, even if the write() call is interrupted.
*/ */
static static ssize_t
ssize_t write_all (int fd, const void *buf, size_t count)
write_all (int fd, const void *buf, size_t count)
{ {
ssize_t ret; ssize_t ret;
ssize_t written = 0; ssize_t written = 0;