diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-04 17:44:12 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-04 17:44:12 +0000 |
commit | 8ccb487c21368a7fdc8c7c72315325bf0aa06147 (patch) | |
tree | b2056fae01d325924508a41731edfbd4c3cddd23 /src/setup.h | |
parent | Initial commit. (diff) | |
download | mc-upstream/3%4.8.29.tar.xz mc-upstream/3%4.8.29.zip |
Adding upstream version 3:4.8.29.upstream/3%4.8.29upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/setup.h')
-rw-r--r-- | src/setup.h | 163 |
1 files changed, 163 insertions, 0 deletions
diff --git a/src/setup.h b/src/setup.h new file mode 100644 index 0000000..3506514 --- /dev/null +++ b/src/setup.h @@ -0,0 +1,163 @@ +/** \file setup.h + * \brief Header: setup loading/saving + */ + +#ifndef MC__SETUP_H +#define MC__SETUP_H + +#include <config.h> + +#include "lib/global.h" /* GError */ + +#include "filemanager/layout.h" /* panel_view_mode_t */ +#include "filemanager/panel.h" /* WPanel */ + +/*** typedefs(not structures) and defined constants **********************************************/ + +/* TAB length for editor and viewer */ +#define DEFAULT_TAB_SPACING 8 + +#define MAX_MACRO_LENGTH 1024 + +/*** enums ***************************************************************************************/ + +typedef enum +{ + QSEARCH_CASE_INSENSITIVE = 0, /* quick search in case insensitive mode */ + QSEARCH_CASE_SENSITIVE = 1, /* quick search in case sensitive mode */ + QSEARCH_PANEL_CASE = 2, /* quick search get value from panel case_sensitive */ + QSEARCH_NUM +} qsearch_mode_t; + +/*** structures declarations (and typedefs of structures)*****************************************/ + +/* panels ini options; [Panels] section */ +typedef struct +{ + gboolean show_mini_info; /* If true, show the mini-info on the panel */ + gboolean kilobyte_si; /* If TRUE, SI units (1000 based) will be used for larger units + * (kilobyte, megabyte, ...). If FALSE, binary units (1024 based) will be used */ + gboolean mix_all_files; /* If FALSE then directories are shown separately from files */ + gboolean show_backups; /* If TRUE, show files ending in ~ */ + gboolean show_dot_files; /* If TRUE, show files starting with a dot */ + gboolean fast_reload; /* If TRUE then use stat() on the cwd to determine directory changes */ + gboolean fast_reload_msg_shown; /* Have we shown the fast-reload warning in the past? */ + gboolean mark_moves_down; /* If TRUE, marking a files moves the cursor down */ + gboolean reverse_files_only; /* If TRUE, only selection of files is inverted */ + gboolean auto_save_setup; + gboolean navigate_with_arrows; /* If TRUE: l&r arrows are used to chdir if the input line is empty */ + gboolean scroll_pages; /* If TRUE, panel is scrolled by half the display when the cursor reaches + the end or the beginning of the panel */ + gboolean scroll_center; /* If TRUE, scroll when the cursor hits the middle of the panel */ + gboolean mouse_move_pages; /* Scroll page/item using mouse wheel */ + gboolean filetype_mode; /* If TRUE then add per file type hilighting */ + gboolean permission_mode; /* If TRUE, we use permission hilighting */ + qsearch_mode_t qsearch_mode; /* Quick search mode */ + gboolean torben_fj_mode; /* If TRUE, use some usability hacks by Torben */ + select_flags_t select_flags; /* Select/unselect file flags */ +} panels_options_t; + +typedef struct macro_action_t +{ + long action; + int ch; +} macro_action_t; + +typedef struct macros_t +{ + int hotkey; + GArray *macro; +} macros_t; + +struct mc_fhl_struct; + +/*** global variables defined in .c file *********************************************************/ + +/* global parameters */ +extern char *global_profile_name; +extern gboolean confirm_delete; +extern gboolean confirm_directory_hotlist_delete; +extern gboolean confirm_execute; +extern gboolean confirm_exit; +extern gboolean confirm_overwrite; +extern gboolean confirm_view_dir; +extern gboolean safe_delete; +extern gboolean safe_overwrite; +extern gboolean clear_before_exec; +extern gboolean auto_menu; +extern gboolean drop_menus; +extern gboolean verbose; +extern gboolean copymove_persistent_attr; +extern gboolean classic_progressbar; +extern gboolean easy_patterns; +extern int option_tab_spacing; +extern gboolean auto_save_setup; +extern gboolean only_leading_plus_minus; +extern int cd_symlinks; +extern gboolean auto_fill_mkdir_name; +extern gboolean output_starts_shell; +#ifdef USE_FILE_CMD +extern gboolean use_file_to_check_type; +#endif +extern gboolean file_op_compute_totals; +extern gboolean editor_ask_filename_before_edit; + +extern panels_options_t panels_options; + +extern panel_view_mode_t startup_left_mode; +extern panel_view_mode_t startup_right_mode; +extern gboolean boot_current_is_left; +extern gboolean use_internal_view; +extern gboolean use_internal_edit; + +#ifdef HAVE_CHARSET +extern int default_source_codepage; +extern char *autodetect_codeset; +extern gboolean is_autodetect_codeset_enabled; +#endif /* !HAVE_CHARSET */ + +#ifdef HAVE_ASPELL +extern char *spell_language; +#endif + +/* Value of "other_dir" key in ini file */ +extern char *saved_other_dir; + +/* If set, then print to the given file the last directory we were at */ +extern char *last_wd_string; + +extern int quit; +/* Set to TRUE to suppress printing the last directory */ +extern gboolean print_last_revert; + +#ifdef USE_INTERNAL_EDIT +/* index to record_macro_buf[], -1 if not recording a macro */ +extern int macro_index; + +/* macro stuff */ +extern struct macro_action_t record_macro_buf[MAX_MACRO_LENGTH]; + +extern GArray *macros_list; +#endif /* USE_INTERNAL_EDIT */ + +extern int saving_setup; + +/*** declarations of public functions ************************************************************/ + +const char *setup_init (void); +void load_setup (void); +gboolean save_setup (gboolean save_options, gboolean save_panel_options); +void done_setup (void); +void setup_save_config_show_error (const char *filename, GError ** mcerror); + +void load_key_defs (void); +#ifdef ENABLE_VFS_FTP +char *load_anon_passwd (void); +#endif /* ENABLE_VFS_FTP */ + +void panel_load_setup (WPanel * panel, const char *section); +void panel_save_setup (WPanel * panel, const char *section); + +/*** inline functions ****************************************************************************/ + +#endif /* MC__SETUP_H */ |