summaryrefslogtreecommitdiffstats
path: root/src/setup.h
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 17:44:12 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 17:44:12 +0000
commit8ccb487c21368a7fdc8c7c72315325bf0aa06147 (patch)
treeb2056fae01d325924508a41731edfbd4c3cddd23 /src/setup.h
parentInitial commit. (diff)
downloadmc-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.h163
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 */