Move them to appropriate files.
#ifndef ADVANCED_EXIF_H
#define ADVANCED_EXIF_H
+struct FileData;
+struct LayoutWindow;
GtkWidget *advanced_exif_new(LayoutWindow *lw);
#ifndef BAR_KEYWORDS_H
#define BAR_KEYWORDS_H
+struct LayoutWindow;
+
GtkWidget *bar_pane_keywords_new_from_config(const gchar **attribute_names, const gchar **attribute_values);
void bar_pane_keywords_update_from_config(GtkWidget *pane, const gchar **attribute_names, const gchar **attribute_values);
void bar_pane_keywords_entry_add_from_config(GtkWidget *pane, const gchar **attribute_names, const gchar **attribute_values);
#ifndef BAR_SORT_H
#define BAR_SORT_H
+struct LayoutWindow;
GtkWidget *bar_sort_new_default(LayoutWindow *lw);
GtkWidget *bar_sort_new_from_config(LayoutWindow *lw, const gchar **attribute_names, const gchar **attribute_values);
#include "bar-histogram.h"
#include "filedata.h"
+#include "layout.h"
#include "metadata.h"
#include "rcfile.h"
#include "ui-menu.h"
#ifndef BAR_H
#define BAR_H
+struct FileData;
+struct LayoutWindow;
+
enum PaneType {
PANE_UNDEF = 0,
PANE_COMMENT,
}
CacheLoader *cache_loader_new(FileData *fd, CacheDataType load_mask,
- CacheLoaderDoneFunc done_func, gpointer done_data)
+ CacheLoader::DoneFunc done_func, gpointer done_data)
{
CacheLoader *cl;
gchar *found;
#include "cache.h"
#include "image-load.h"
-
-struct CacheLoader;
-
-using CacheLoaderDoneFunc = void (*)(CacheLoader *, gint, gpointer);
-
+struct FileData;
enum CacheDataType {
CACHE_LOADER_NONE = 0,
CacheDataType todo_mask;
CacheDataType done_mask;
- CacheLoaderDoneFunc done_func;
+ using DoneFunc = void (*)(CacheLoader *, gint, gpointer);
+ DoneFunc done_func;
gpointer done_data;
gboolean error;
CacheLoader *cache_loader_new(FileData *fd, CacheDataType load_mask,
- CacheLoaderDoneFunc done_func, gpointer done_data);
+ CacheLoader::DoneFunc done_func, gpointer done_data);
void cache_loader_free(CacheLoader *cl);
#ifndef CACHE_MAINT_H
#define CACHE_MAINT_H
+struct FileData;
void cache_maintain_home(gboolean metadata, gboolean clear, GtkWidget *parent);
void cache_notify_cb(FileData *fd, NotifyType type, gpointer data);
#ifndef COLLECT_IO_H
#define COLLECT_IO_H
+struct CollectionData;
+struct FileData;
+
enum CollectionLoadFlags {
COLLECTION_LOAD_NONE = 0,
COLLECTION_LOAD_APPEND = 1 << 0,
#include "collect.h"
+struct CollectTable
+{
+ GtkWidget *scrolled;
+ GtkWidget *listview;
+ gint columns;
+ gint rows;
+
+ CollectionData *cd;
+
+ GList *selection;
+ CollectInfo *prev_selection;
+
+ CollectInfo *click_info;
+
+ GtkWidget *tip_window;
+ guint tip_delay_id; /**< event source id */
+ CollectInfo *tip_info;
+
+ GdkWindow *marker_window;
+ CollectInfo *marker_info;
+
+ GtkWidget *status_label;
+ GtkWidget *extra_label;
+
+ gint focus_row;
+ gint focus_column;
+ CollectInfo *focus_info;
+
+ GtkWidget *popup;
+ CollectInfo *drop_info;
+ GList *drop_list;
+
+ guint sync_idle_id; /**< event source id */
+ guint drop_idle_id; /**< event source id */
+
+ gboolean show_text;
+ gboolean show_stars;
+
+ GList *editmenu_fd_list; /**< file list for edit menu */
+};
+
void collection_table_select_all(CollectTable *ct);
void collection_table_unselect_all(CollectTable *ct);
#ifndef COLLECT_H
#define COLLECT_H
+struct CollectTable;
+struct FileData;
+struct ThumbLoader;
+
+struct CollectInfo
+{
+ FileData *fd;
+ GdkPixbuf *pixbuf;
+ guint flag_mask;
+};
CollectInfo *collection_info_new(FileData *fd, struct stat *st, GdkPixbuf *pixbuf);
CollectInfo *collection_list_find_fd(GList *list, FileData *fd);
GList *collection_list_to_filelist(GList *list);
+struct CollectionData
+{
+ gchar *path;
+ gchar *name;
+ GList *list;
+ SortType sort_method;
+
+ ThumbLoader *thumb_loader;
+ CollectInfo *thumb_info;
+
+ void (*info_updated_func)(CollectionData *, CollectInfo *, gpointer);
+ gpointer info_updated_data;
+
+ gint ref;
+
+ /* geometry */
+ gint window_read;
+ gint window_x;
+ gint window_y;
+ gint window_w;
+ gint window_h;
+
+ gboolean changed; /**< contents changed since save flag */
+
+ GHashTable *existence;
+
+ GtkWidget *dialog_name_entry;
+ gchar *collection_path; /**< Full path to collection including extension */
+ gint collection_append_index;
+};
+
CollectionData *collection_new(const gchar *path);
void collection_free(CollectionData *cd);
void collection_update_geometry(CollectionData *cd);
+struct CollectWindow
+{
+ GtkWidget *window;
+ CollectTable *table;
+ GtkWidget *status_box;
+
+ GtkWidget *close_dialog;
+
+ CollectionData *cd;
+};
+
CollectWindow *collection_window_new(const gchar *path);
void collection_window_close_by_collection(CollectionData *cd);
CollectWindow *collection_window_find(CollectionData *cd);
#include "main.h"
#include "color-man.h"
+#include "filedata.h"
#include "image.h"
#include "ui-fileops.h"
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wunused-function"
-void color_man_start_bg_unused(ColorMan *cm, ColorManDoneFunc done_func, gpointer done_data)
+void color_man_start_bg_unused(ColorMan *cm, ColorMan::DoneFunc done_func, gpointer done_data)
{
cm->func_done = done_func;
cm->func_done_data = done_data;
#ifndef COLOR_MAN_H
#define COLOR_MAN_H
+struct FileData;
+struct ImageWindow;
+
enum ColorManProfileType {
COLOR_PROFILE_NONE = -1,
COLOR_PROFILE_MEM = -2,
COLOR_RETURN_IMAGE_CHANGED
};
-struct ColorMan;
-using ColorManDoneFunc = void (*)(ColorMan *, ColorManReturnType, gpointer);
-
struct ColorMan {
ImageWindow *imd;
guint idle_id; /* event source id */
- ColorManDoneFunc func_done;
+ using DoneFunc = void (*)(ColorMan *, ColorManReturnType, gpointer);
+ DoneFunc func_done;
gpointer func_done_data;
};
#include "similar.h"
+struct CollectInfo;
+struct CollectionData;
+struct FileData;
+struct ImageLoader;
+struct ThumbLoader;
+
/** @enum DupeMatchType
* match methods
*/
#ifndef EDITORS_H
#define EDITORS_H
+struct FileData;
enum EditorFlags {
EDITOR_KEEP_FS = 0x00000001,
#ifndef __EXIF_H
#define __EXIF_H
+struct ExifData;
+struct ExifItem;
+struct FileData;
+
#define EXIF_FORMATTED() "formatted."
#define EXIF_FORMATTED_LEN (sizeof(EXIF_FORMATTED()) - 1)
*-----------------------------------------------------------------------------
*/
-struct ExifItem;
-
struct ExifRational
{
guint32 num;
#include "main.h"
#include "exif.h"
+#include "filedata.h"
#include "filefilter.h"
-#include "ui-fileops.h"
-
#include "misc.h"
+#include "ui-fileops.h"
#if EXIV2_TEST_VERSION(0,28,0)
#define AnyError Error
#ifndef FILEDATA_H
#define FILEDATA_H
+struct ExifData;
+struct HistMap;
+
#ifdef DEBUG
#define DEBUG_FILEDATA
#endif
gchar *text_from_size_abrev(gint64 size);
const gchar *text_from_time(time_t t);
+enum FileDataChangeType {
+ FILEDATA_CHANGE_DELETE,
+ FILEDATA_CHANGE_MOVE,
+ FILEDATA_CHANGE_RENAME,
+ FILEDATA_CHANGE_COPY,
+ FILEDATA_CHANGE_UNSPECIFIED,
+ FILEDATA_CHANGE_WRITE_METADATA
+};
+
+enum NotifyPriority {
+ NOTIFY_PRIORITY_HIGH = 0,
+ NOTIFY_PRIORITY_MEDIUM,
+ NOTIFY_PRIORITY_LOW
+};
+
+enum SelectionType {
+ SELECTION_NONE = 0,
+ SELECTION_SELECTED = 1 << 0,
+ SELECTION_PRELIGHT = 1 << 1,
+ SELECTION_FOCUS = 1 << 2
+};
+
+struct FileDataChangeInfo {
+ FileDataChangeType type;
+ gchar *source;
+ gchar *dest;
+ gint error;
+ gboolean regroup_when_finished;
+};
+
+struct FileData {
+ guint magick;
+ gint type;
+ gchar *original_path; /**< key to file_data_pool hash table */
+ gchar *path;
+ const gchar *name;
+ const gchar *extension;
+ gchar *extended_extension;
+ FileFormatClass format_class;
+ gchar *format_name; /**< set by the image loader */
+ gchar *collate_key_name;
+ gchar *collate_key_name_nocase;
+ gchar *collate_key_name_natural;
+ gchar *collate_key_name_nocase_natural;
+ gint64 size;
+ time_t date;
+ time_t cdate;
+ mode_t mode; /**< this is needed at least for notification in view_dir because it is preserved after the file/directory is deleted */
+ gint sidecar_priority;
+
+ guint marks; /**< each bit represents one mark */
+ guint valid_marks; /**< zero bit means that the corresponding mark needs to be reread */
+
+
+ GList *sidecar_files;
+ FileData *parent; /**< parent file if this is a sidecar file, NULL otherwise */
+ FileDataChangeInfo *change; /**< for rename, move ... */
+ GdkPixbuf *thumb_pixbuf;
+
+ GdkPixbuf *pixbuf; /**< full-size image, only complete images, NULL during loading
+ all FileData with non-NULL pixbuf are referenced by image_cache */
+
+ HistMap *histmap;
+
+ gboolean locked;
+ gint ref;
+ gint version; /**< increased when any field in this structure is changed */
+ gboolean disable_grouping;
+
+ gint user_orientation;
+ gint exif_orientation;
+
+ ExifData *exif;
+ time_t exifdate;
+ time_t exifdate_digitized;
+ GHashTable *modified_xmp; /**< hash table which contains unwritten xmp metadata in format: key->list of string values */
+ GList *cached_metadata;
+ gint rating;
+ gboolean metadata_in_idle_loaded;
+
+ gchar *owner;
+ gchar *group;
+ gchar *sym_link;
+
+ SelectionType selected; /**< Used by view-file-icon. */
+
+ gint page_num;
+ gint page_total;
+};
+
/**
* @headerfile file_data_new_group
* scan for sidecar files - expensive
#ifndef FULLSCREEN_H
#define FULLSCREEN_H
+struct ImageWindow;
+
#define FULL_SCREEN_HIDE_MOUSE_DELAY 3000
#define FULL_SCREEN_BUSY_MOUSE_DELAY 200
+struct FullScreenData
+{
+ GtkWidget *window;
+ ImageWindow *imd;
+
+ GtkWidget *normal_window;
+ ImageWindow *normal_imd;
+
+ guint hide_mouse_id; /**< event source id */
+ guint busy_mouse_id; /**< event source id */
+
+ gint cursor_state;
+
+ guint saver_block_id; /**< event source id */
+
+ void (*stop_func)(FullScreenData *, gpointer);
+ gpointer stop_data;
+
+ gboolean same_region; /**< the returned region will overlap the current location of widget. */
+};
+
FullScreenData *fullscreen_start(GtkWidget *window, ImageWindow *imd,
void (*stop_func)(FullScreenData *, gpointer), gpointer stop_data);
void fullscreen_stop(FullScreenData *fs);
#include <glib.h>
#include "main.h"
+struct FileData;
+
void lua_init();
gchar *lua_callvalue(FileData *fd, const gchar *file, const gchar *function);
#ifndef HISTOGRAM_H
#define HISTOGRAM_H
+struct FileData;
+struct HistMap;
+
/* Note: The order is important */
#define HCHAN_R 0
#define HCHAN_G 1
#define HCHAN_COUNT 5
#define HCHAN_DEFAULT HCHAN_RGB
+struct Histogram {
+ gint histogram_channel; /**< drawing mode for histogram */
+ gint histogram_mode; /**< logarithmical or not */
+ guint vgrid; /**< number of vertical divisions, 0 for none */
+ guint hgrid; /**< number of horizontal divisions, 0 for none */
+ struct {
+ int R; /**< red */
+ int G; /**< green */
+ int B; /**< blue */
+ int A; /**< alpha */
+ } grid_color; /**< grid color */
+};
+
Histogram *histogram_new();
void histogram_free(Histogram *histogram);
#include "image-load-collection.h"
#include "cache.h"
+#include "filedata.h"
#include "misc.h"
#include "ui-fileops.h"
#include "image-load.h"
#include "image-load-external.h"
+#include "filedata.h"
#include "misc.h"
#include "ui-fileops.h"
#include "image-load.h"
#include "image-load-ffmpegthumbnailer.h"
+#include "filedata.h"
+
#ifdef HAVE_FFMPEGTHUMBNAILER
#include <libffmpegthumbnailer/videothumbnailerc.h>
#include "image-load.h"
#include "image-load-gdk.h"
+#include "filedata.h"
+
static gchar* image_loader_gdk_get_format_name(gpointer loader)
{
#include "main.h"
+#include "filedata.h"
#include "filefilter.h"
#include "image-load.h"
#include "image-load-libraw.h"
#ifndef IMAGE_LOAD_H
#define IMAGE_LOAD_H
+struct FileData;
+
#define TYPE_IMAGE_LOADER (image_loader_get_type())
using ImageLoaderBackendCbAreaPrepared = void (*)(gpointer, gpointer);
#include "main.h"
#include "image-overlay.h"
+#include "collect.h"
#include "filedata.h"
#include "histogram.h"
#include "image.h"
+#include "image-load.h"
#include "img-view.h"
#include "layout.h"
#include "osd.h"
#include "pixbuf-renderer.h"
#include "pixbuf-util.h"
+#include "slideshow.h"
#include "ui-fileops.h"
-#include "image-load.h"
/*
*----------------------------------------------------------------------------
#ifndef IMAGE_OVERLAY_H
#define IMAGE_OVERLAY_H
+struct Histogram;
+struct ImageWindow;
+
enum ImageOSDFlag {
IMAGE_OSD_NONE = 0,
IMAGE_OSD_ROTATE_USER,
#ifndef IMAGE_H
#define IMAGE_H
+struct CollectInfo;
+struct CollectionData;
+struct FileData;
+struct ImageLoader;
+
+enum ImageState {
+ IMAGE_STATE_NONE = 0,
+ IMAGE_STATE_IMAGE = 1 << 0,
+ IMAGE_STATE_LOADING = 1 << 1,
+ IMAGE_STATE_ERROR = 1 << 2,
+ IMAGE_STATE_COLOR_ADJ = 1 << 3,
+ IMAGE_STATE_ROTATE_AUTO = 1 << 4,
+ IMAGE_STATE_ROTATE_USER = 1 << 5,
+ IMAGE_STATE_DELAY_FLIP = 1 << 6
+};
+
+struct ImageWindow
+{
+ GtkWidget *widget; /**< use this to add it and show it */
+ GtkWidget *pr;
+ GtkWidget *frame;
+
+ FileData *image_fd;
+
+ gboolean unknown; /**< failed to load image */
+
+ ImageLoader *il; /**< @FIXME image loader should probably go to FileData, but it must first support
+ sending callbacks to multiple ImageWindows in parallel */
+
+ gint has_frame; /**< not boolean, see image_new() */
+
+ /* top level (not necessarily parent) window */
+ gboolean top_window_sync; /**< resize top_window when image dimensions change */
+ GtkWidget *top_window; /**< window that gets title, and window to resize when 'fitting' */
+ gchar *title; /**< window title to display left of file name */
+ gchar *title_right; /**< window title to display right of file name */
+ gboolean title_show_zoom; /**< option to include zoom in window title */
+
+ gboolean completed;
+ ImageState state; /**< mask of IMAGE_STATE_* flags about current image */
+
+ void (*func_update)(ImageWindow *imd, gpointer data);
+ void (*func_complete)(ImageWindow *imd, gint preload, gpointer data);
+ void (*func_state)(ImageWindow *imd, ImageState state, gpointer data);
+
+ using TileRequestFunc = gint (*)(ImageWindow *, gint, gint, gint, gint, GdkPixbuf *, gpointer);
+ TileRequestFunc func_tile_request;
+
+ using TileDisposeFunc = void (*)(ImageWindow *, gint, gint, gint, gint, GdkPixbuf *, gpointer);
+ TileDisposeFunc func_tile_dispose;
+
+ gpointer data_update;
+ gpointer data_complete;
+ gpointer data_state;
+ gpointer data_tile;
+
+ /* button, scroll functions */
+ void (*func_button)(ImageWindow *, GdkEventButton *event, gpointer);
+ void (*func_drag)(ImageWindow *, GdkEventMotion *event, gdouble dx, gdouble dy, gpointer);
+ void (*func_scroll)(ImageWindow *, GdkEventScroll *event, gpointer);
+ void (*func_focus_in)(ImageWindow *, gpointer);
+
+ gpointer data_button;
+ gpointer data_drag;
+ gpointer data_scroll;
+ gpointer data_focus_in;
+
+ /**
+ * @headerfile func_scroll_notify
+ * scroll notification (for scroll bar implementation)
+ */
+ void (*func_scroll_notify)(ImageWindow *, gint x, gint y, gint width, gint height, gpointer);
+
+ gpointer data_scroll_notify;
+
+ /* collection info */
+ CollectionData *collection;
+ CollectInfo *collection_info;
+
+ /* color profiles */
+ gboolean color_profile_enable;
+ gint color_profile_input;
+ gboolean color_profile_use_image;
+ gint color_profile_from_image;
+ gpointer cm;
+
+ AlterType delay_alter_type;
+
+ FileData *read_ahead_fd;
+ ImageLoader *read_ahead_il;
+
+ gint prev_color_row;
+
+ gboolean auto_refresh;
+
+ gboolean delay_flip;
+ gint orientation;
+ gboolean desaturate;
+ gboolean overunderexposed;
+ gint user_stereo;
+
+ gboolean mouse_wheel_mode;
+};
void image_set_frame(ImageWindow *imd, gboolean frame);
ImageWindow *image_new(gboolean frame);
void image_set_image_as_tiles(ImageWindow *imd, gint width, gint height,
gint tile_width, gint tile_height, gint cache_size,
- ImageTileRequestFunc func_tile_request,
- ImageTileDisposeFunc func_tile_dispose,
+ ImageWindow::TileRequestFunc func_tile_request,
+ ImageWindow::TileDisposeFunc func_tile_dispose,
gpointer data,
gdouble zoom);
#ifndef IMG_VIEW_H
#define IMG_VIEW_H
+struct CollectInfo;
+struct CollectionData;
+struct FileData;
+struct ImageWindow;
void view_window_new(FileData *fd);
void view_window_new_from_list(GList *list);
*----------------------------------------------------------------------------
*/
+struct AnimationData
+{
+ ImageWindow *iw;
+ LayoutWindow *lw;
+ GdkPixbufAnimation *gpa;
+ GdkPixbufAnimationIter *iter;
+ GdkPixbuf *gpb;
+ FileData *data_adr;
+ gint delay;
+ gboolean valid;
+ GCancellable *cancellable;
+ GFile *in_file;
+ GFileInputStream *gfstream;
+};
+
static void image_animation_data_free(AnimationData *fd)
{
if(!fd) return;
#ifndef LAYOUT_IMAGE_H
#define LAYOUT_IMAGE_H
+struct CollectInfo;
+struct CollectionData;
+struct FileData;
+struct LayoutWindow;
GtkWidget *layout_image_new(LayoutWindow *lw, gint i);
void layout_image_activate(LayoutWindow *lw, gint i, gboolean force);
#include "collect-dlg.h"
#include "collect-io.h"
#include "color-man.h"
+#include "desktop-file.h"
#include "dupe.h"
#include "editors.h"
+#include "fullscreen.h"
+#include "histogram.h"
#include "history-list.h"
#include "image.h"
#include "image-overlay.h"
-#include "histogram.h"
#include "img-view.h"
#include "layout-image.h"
#include "logwindow.h"
+#include "metadata.h"
#include "misc.h"
#include "pan-view.h"
#include "pixbuf-util.h"
#include "view-dir.h"
#include "view-file.h"
#include "window.h"
-#include "metadata.h"
-#include "desktop-file.h"
#include <sys/wait.h>
#include "keymap-template.h"
#include "layout.h"
#include "filedata.h"
+#include "histogram.h"
#include "history-list.h"
#include "image.h"
#include "image-overlay.h"
#ifndef LAYOUT_H
#define LAYOUT_H
+struct AnimationData;
+struct FileData;
+struct FullScreenData;
+struct ImageWindow;
+struct SlideShowData;
+struct ViewDir;
+struct ViewFile;
+
#define LAYOUT_ID_CURRENT "_current_"
+#define MAX_SPLIT_IMAGES 4
extern GList *layout_window_list;
+enum LayoutLocation {
+ LAYOUT_HIDE = 0,
+ LAYOUT_LEFT = 1 << 0,
+ LAYOUT_RIGHT = 1 << 1,
+ LAYOUT_TOP = 1 << 2,
+ LAYOUT_BOTTOM = 1 << 3
+};
+
+struct LayoutWindow
+{
+ LayoutOptions options;
+
+ FileData *dir_fd;
+
+ /* base */
+
+ GtkWidget *window;
+
+ GtkWidget *main_box;
+
+ GtkWidget *group_box;
+ GtkWidget *h_pane;
+ GtkWidget *v_pane;
+
+ /* menus, path selector */
+
+ GtkActionGroup *action_group;
+ GtkActionGroup *action_group_editors;
+ guint ui_editors_id;
+ GtkUIManager *ui_manager;
+ guint toolbar_merge_id[TOOLBAR_COUNT];
+ GList *toolbar_actions[TOOLBAR_COUNT];
+
+ GtkWidget *path_entry;
+
+ /* image */
+
+ LayoutLocation image_location;
+
+ ImageWindow *image;
+
+ ImageWindow *split_images[MAX_SPLIT_IMAGES];
+ ImageSplitMode split_mode;
+ gint active_split_image;
+
+ GtkWidget *split_image_widget;
+ GtkSizeGroup *split_image_sizegroup;
+
+ /* tools window (float) */
+
+ GtkWidget *tools;
+ GtkWidget *tools_pane;
+
+ GtkWidget *menu_tool_bar; /**< Combined menu and toolbar box */
+ GtkWidget *menu_bar; /**< referenced by lw, exist during whole lw lifetime */
+ /* toolbar */
+
+ GtkWidget *toolbar[TOOLBAR_COUNT]; /**< referenced by lw, exist during whole lw lifetime */
+
+ GtkWidget *back_button;
+
+ /* dir view */
+
+ LayoutLocation dir_location;
+
+ ViewDir *vd;
+ GtkWidget *dir_view;
+
+ /* file view */
+
+ LayoutLocation file_location;
+
+ ViewFile *vf;
+
+ GtkWidget *file_view;
+
+ GtkWidget *info_box; /**< status bar */
+ GtkWidget *info_progress_bar; /**< status bar */
+ GtkWidget *info_sort; /**< status bar */
+ GtkWidget *info_status; /**< status bar */
+ GtkWidget *info_details; /**< status bar */
+ GtkWidget *info_zoom; /**< status bar */
+ GtkWidget *info_pixel; /**< status bar */
+
+ /* slide show */
+
+ SlideShowData *slideshow;
+
+ /* full screen */
+
+ FullScreenData *full_screen;
+
+ /* misc */
+
+ GtkWidget *utility_box; /**< referenced by lw, exist during whole lw lifetime */
+ GtkWidget *utility_paned; /**< between image and bar */
+ GtkWidget *bar_sort;
+ GtkWidget *bar;
+
+ gboolean bar_sort_enabled; /**< Set during start-up, and checked when the editors have loaded */
+
+ GtkWidget *exif_window;
+ GtkWidget *sar_window; /**< Search and Run window */
+
+ AnimationData *animation;
+
+ GtkWidget *log_window;
+};
+
LayoutWindow *layout_new(FileData *dir_fd, LayoutOptions *lop);
LayoutWindow *layout_new_with_geometry(FileData *dir_fd, LayoutOptions *lop,
const gchar *geometry);
#include <deque>
#include <string>
+#include "layout.h"
#include "misc.h"
#include "ui-misc.h"
#include "window.h"
#ifndef LOGWINDOW_H
#define LOGWINDOW_H
+struct LayoutWindow;
+
enum LogType
{
LOG_NORMAL = 0,
#include "main.h"
#include "glua.h"
-#include "ui-fileops.h"
#include "exif.h"
+#include "filedata.h"
+#include "ui-fileops.h"
/**
* @file
#ifndef METADATA_H
#define METADATA_H
+struct FileData;
+
#define COMMENT_KEY "Xmp.dc.description"
#define KEYWORD_KEY "Xmp.dc.subject"
#define ORIENTATION_KEY "Xmp.tiff.Orientation"
#include "main.h"
#include "misc.h"
+#include "filedata.h"
#include "ui-fileops.h"
#include <langinfo.h>
#ifndef MISC_H
#define MISC_H
+struct FileData;
+
gdouble get_zoom_increment();
gchar *utf8_validate_or_convert(const gchar *text);
gint utf8_compare(const gchar *s1, const gchar *s2, gboolean case_sensitive);
#ifndef OPTIONS_H
#define OPTIONS_H
+struct SecureSaveInfo;
+
+/**
+ * @enum DnDAction
+ * drag and drop default action
+ */
+enum DnDAction {
+ DND_ACTION_ASK,
+ DND_ACTION_COPY,
+ DND_ACTION_MOVE
+};
+
+enum ZoomStyle {
+ ZOOM_GEOMETRIC = 0,
+ ZOOM_ARITHMETIC = 1
+};
+
struct ConfOptions
{
/* ui */
GList *disabled_plugins;
};
+struct CommandLine
+{
+ int argc;
+ gchar **argv;
+ gboolean startup_blank;
+ gboolean startup_full_screen;
+ gboolean startup_in_slideshow;
+ gboolean startup_command_line_collection;
+ gboolean tools_hide;
+ gboolean tools_show;
+ gboolean log_window_show;
+ gchar *path;
+ gchar *file;
+ GList *cmd_list;
+ GList *collection_list;
+ gchar *geometry;
+ gchar *regexp;
+ gchar *log_file;
+ SecureSaveInfo *ssi;
+ gboolean new_instance;
+};
+
extern ConfOptions *options;
extern CommandLine *command_line;
void save_options(ConfOptions *options);
gboolean load_options(ConfOptions *options);
+
+enum StartUpPath {
+ STARTUP_PATH_CURRENT = 0,
+ STARTUP_PATH_LAST,
+ STARTUP_PATH_HOME,
+};
+
+enum SortActionType {
+ BAR_SORT_COPY = 0,
+ BAR_SORT_MOVE,
+ BAR_SORT_FILTER,
+ BAR_SORT_ACTION_COUNT
+};
+
+enum SortModeType {
+ BAR_SORT_MODE_FOLDER = 0,
+ BAR_SORT_MODE_COLLECTION,
+ BAR_SORT_MODE_COUNT
+};
+
+enum SortSelectionType {
+ BAR_SORT_SELECTION_IMAGE = 0,
+ BAR_SORT_SELECTION_SELECTED,
+ BAR_SORT_SELECTION_COUNT
+};
+
+struct LayoutOptions
+{
+ gchar *id;
+
+ gchar *order;
+ gint style;
+
+ DirViewType dir_view_type;
+ FileViewType file_view_type;
+
+ struct {
+ SortType method;
+ gboolean ascend;
+ gboolean case_sensitive;
+ } dir_view_list_sort;
+
+ struct {
+ SortType method;
+ gboolean ascend;
+ gboolean case_sensitive;
+ } file_view_list_sort;
+
+ gboolean show_thumbnails;
+ gboolean show_marks;
+ gboolean show_file_filter;
+ gboolean show_directory_date;
+ gboolean show_info_pixel;
+ gboolean split_pane_sync;
+ gboolean ignore_alpha;
+
+ struct {
+ gint w;
+ gint h;
+ gint x;
+ gint y;
+ gboolean maximized;
+ gint hdivider_pos;
+ gint vdivider_pos;
+ } main_window;
+
+ struct {
+ gint w;
+ gint h;
+ gint x;
+ gint y;
+ gint vdivider_pos;
+ } float_window;
+
+ struct {
+ gint vdivider_pos;
+ } folder_window;
+
+ struct {
+ gint w;
+ gint h;
+ } properties_window;
+
+ struct {
+ guint state;
+ gint histogram_channel;
+ gint histogram_mode;
+ } image_overlay;
+
+ struct {
+ gint w;
+ gint h;
+ gint x;
+ gint y;
+ } log_window;
+
+ struct {
+ gint w;
+ gint h;
+ gint x;
+ gint y;
+ gint page_number;
+ } preferences_window;
+
+ struct {
+ gint w;
+ gint h;
+ gint x;
+ gint y;
+ } search_window;
+
+ struct {
+ gint w;
+ gint h;
+ gint x;
+ gint y;
+ } dupe_window;
+
+ struct {
+ gint w;
+ gint h;
+ gint x;
+ gint y;
+ } advanced_exif_window;
+
+ gboolean tools_float;
+ gboolean tools_hidden;
+ gboolean toolbar_hidden;
+
+ struct {
+ gboolean info;
+ gboolean sort;
+ gboolean tools_float;
+ gboolean tools_hidden;
+ gboolean hidden;
+ } bars_state;
+
+ gchar *home_path;
+ gchar *last_path;
+
+ StartUpPath startup_path;
+
+ gboolean animate;
+ gint workspace;
+
+ SortActionType action;
+ SortModeType mode;
+ SortSelectionType selection;
+ gchar *filter_key;
+};
+
void copy_layout_options(LayoutOptions *dest, const LayoutOptions *src);
void free_layout_options_content(LayoutOptions *dest);
LayoutOptions *init_layout_options(LayoutOptions *options);
#ifndef OSD_H
#define OSD_H
+struct FileData;
+
enum OsdTemplateFlags {
OSDT_NONE = 0,
OSDT_FREE = 1 << 0,
#include "cache-loader.h"
#include "filedata.h"
+struct FullScreenData;
+struct ImageWindow;
+struct ThumbLoader;
+
/* thumbnail sizes and spacing */
#define PAN_THUMB_SIZE_DOTS 4
#include "pan-view-filter.h"
+#include "image.h"
#include "metadata.h"
#include "pan-view.h"
#include "ui-fileops.h"
#include "main.h"
#include "pixbuf-util.h"
+
#include "exif.h"
+#include "filedata.h"
#include "ui-fileops.h"
#include <cmath>
#ifndef PIXBUF_UTIL_H
#define PIXBUF_UTIL_H
+struct FileData;
gboolean pixbuf_to_file_as_png (GdkPixbuf *pixbuf, const gchar *filename);
#ifndef PREFERENCES_H
#define PREFERENCES_H
+struct LayoutWindow;
void show_config_window(LayoutWindow *lw);
void show_about_window(LayoutWindow *lw);
#ifndef PRINT_H
#define PRINT_H
+struct FileData;
/**
* @headerfile print_window_new
*/
void print_window_new(FileData *fd, GList *selection, GList *list, GtkWidget *parent);
-
#endif
/* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */
#ifndef RCFILE_H
#define RCFILE_H
+struct LayoutWindow;
void write_indent(GString *str, gint indent);
void write_char_option(GString *str, gint indent, const gchar *label, const gchar *text);
gboolean load_config_from_buf(const gchar *buf, gsize size, gboolean startup);
gboolean load_config_from_file(const gchar *utf8_path, gboolean startup);
-
#endif
/* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */
return rc;
}
-static void remote_server_subscribe(RemoteConnection *rc, RemoteReadFunc *func, gpointer data)
+static void remote_server_subscribe(RemoteConnection *rc, RemoteConnection::ReadFunc *func, gpointer data)
{
if (!rc || !rc->server) return;
#ifndef REMOTE_H
#define REMOTE_H
-
-struct RemoteConnection;
-
-using RemoteReadFunc = void (RemoteConnection *, const gchar *, GIOChannel *, gpointer);
+struct CollectionData;
struct RemoteConnection {
gint server;
gchar *path;
gint channel_id;
- RemoteReadFunc *read_func;
+
+ using ReadFunc = void (RemoteConnection *, const gchar *, GIOChannel *, gpointer);
+ ReadFunc *read_func;
gpointer read_data;
GList *clients;
#include "main.h"
#include "search-and-run.h"
+#include "layout.h"
#include "ui-misc.h"
#include "window.h"
#ifndef SEARCH_AND_RUN_H
#define SEARCH_AND_RUN_H
+struct LayoutWindow;
GtkWidget *search_and_run_new(LayoutWindow *lw);
#ifndef SEARCH_H
#define SEARCH_H
+struct FileData;
void search_new(FileData *dir_fd, FileData *example_file);
-
#endif
/* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */
#ifndef SECURE_SAVE_H
#define SECURE_SAVE_H
+/**
+ * @enum SecureSaveErrno
+ * see err field in #SecureSaveInfo
+ */
+enum SecureSaveErrno {
+ SS_ERR_NONE = 0,
+ SS_ERR_DISABLED, /**< secsave is disabled. */
+ SS_ERR_OUT_OF_MEM, /**< memory allocation failure */
+
+ SS_ERR_OPEN_READ,
+ SS_ERR_OPEN_WRITE,
+ SS_ERR_STAT,
+ SS_ERR_ACCESS,
+ SS_ERR_MKSTEMP,
+ SS_ERR_RENAME,
+ SS_ERR_OTHER,
+};
+
extern SecureSaveErrno secsave_errno; /**< internal secsave error number */
+struct SecureSaveInfo {
+ FILE *fp; /**< file stream pointer */
+ gchar *file_name; /**< final file name */
+ gchar *tmp_file_name; /**< temporary file name */
+ gint err; /**< set to non-zero value in case of error */
+ gboolean secure_save; /**< use secure save for this file, internal use only */
+ gboolean preserve_perms; /**< whether to preserve perms, TRUE by default */
+ gboolean preserve_mtime; /**< whether to preserve mtime, FALSE by default */
+ gboolean unlink_on_error; /**< whether to remove temporary file on save failure, TRUE by default */
+};
+
SecureSaveInfo *secure_open(const gchar *);
gint secure_close(SecureSaveInfo *);
#ifndef SHORTCUTS_H
#define SHORTCUTS_H
+struct LayoutWindow;
+
GtkWidget *shortcuts_new_default(LayoutWindow *lw);
#endif
#ifndef SLIDESHOW_H
#define SLIDESHOW_H
+struct CollectInfo;
+struct CollectionData;
+struct ImageWindow;
+struct LayoutWindow;
#define SLIDESHOW_SUBSECOND_PRECISION 10
#define SLIDESHOW_MIN_SECONDS 0.1
* CollectionData, then finally falls back to the layout listing.
*/
+struct SlideShowData
+{
+ LayoutWindow *lw; /**< use this window to display the slideshow */
+ ImageWindow *imd; /**< use this window only if lw is not available,
+ @FIXME it is probably required only by img-view.cc and should be dropped with it */
+
+ GList *filelist;
+ CollectionData *cd;
+ FileData *dir_fd;
+
+ GList *list;
+ GList *list_done;
+
+ FileData *slide_fd;
+
+ guint slide_count;
+ guint timeout_id; /**< event source id */
+
+ gboolean from_selection;
+
+ void (*stop_func)(SlideShowData *, gpointer);
+ gpointer stop_data;
+
+ gboolean paused;
+};
+
void slideshow_free(SlideShowData *ss);
gboolean slideshow_should_continue(SlideShowData *ss);
}
void thumb_loader_std_set_callbacks(ThumbLoaderStd *tl,
- ThumbLoaderStdFunc func_done,
- ThumbLoaderStdFunc func_error,
- ThumbLoaderStdFunc func_progress,
+ ThumbLoaderStd::Func func_done,
+ ThumbLoaderStd::Func func_error,
+ ThumbLoaderStd::Func func_progress,
gpointer data)
{
if (!tl) return;
#ifndef THUMB_STANDARD_H
#define THUMB_STANDARD_H
+struct FileData;
+struct ImageLoader;
#if GLIB_CHECK_VERSION (2, 34, 0)
#define THUMB_FOLDER_GLOBAL "thumbnails"
#define THUMB_NAME_EXTENSION ".png"
-struct ThumbLoaderStd;
-using ThumbLoaderStdFunc = void (*)(ThumbLoaderStd *, gpointer);
-
struct ThumbLoaderStd
{
gboolean standard_loader;
gdouble progress;
- ThumbLoaderStdFunc func_done;
- ThumbLoaderStdFunc func_error;
- ThumbLoaderStdFunc func_progress;
+ using Func = void (*)(ThumbLoaderStd *, gpointer);
+ Func func_done;
+ Func func_error;
+ Func func_progress;
gpointer data;
};
ThumbLoaderStd *thumb_loader_std_new(gint width, gint height);
void thumb_loader_std_set_callbacks(ThumbLoaderStd *tl,
- ThumbLoaderStdFunc func_done,
- ThumbLoaderStdFunc func_error,
- ThumbLoaderStdFunc func_progress,
+ ThumbLoaderStd::Func func_done,
+ ThumbLoaderStd::Func func_error,
+ ThumbLoaderStd::Func func_progress,
gpointer data);
void thumb_loader_std_set_cache(ThumbLoaderStd *tl, gboolean enable_cache, gboolean local, gboolean retry_failed);
gboolean thumb_loader_std_start(ThumbLoaderStd *tl, FileData *fd);
}
void thumb_loader_set_callbacks(ThumbLoader *tl,
- ThumbLoaderFunc func_done,
- ThumbLoaderFunc func_error,
- ThumbLoaderFunc func_progress,
+ ThumbLoader::Func func_done,
+ ThumbLoader::Func func_error,
+ ThumbLoader::Func func_progress,
gpointer data)
{
if (!tl) return;
if (tl->standard_loader)
{
thumb_loader_std_set_callbacks(reinterpret_cast<ThumbLoaderStd *>(tl),
- reinterpret_cast<ThumbLoaderStdFunc>(func_done),
- reinterpret_cast<ThumbLoaderStdFunc>(func_error),
- reinterpret_cast<ThumbLoaderStdFunc>(func_progress),
+ reinterpret_cast<ThumbLoaderStd::Func>(func_done),
+ reinterpret_cast<ThumbLoaderStd::Func>(func_error),
+ reinterpret_cast<ThumbLoaderStd::Func>(func_progress),
data);
return;
}
#ifndef THUMB_H
#define THUMB_H
+struct FileData;
+struct ImageLoader;
+
+struct ThumbLoader
+{
+ gboolean standard_loader;
+
+ ImageLoader *il;
+ FileData *fd; /**< fd->pixbuf contains final (scaled) image when done */
+
+ gboolean cache_enable;
+ gboolean cache_hit;
+ gdouble percent_done;
+
+ gint max_w;
+ gint max_h;
+
+ using Func = void (*)(ThumbLoader *, gpointer);
+ Func func_done;
+ Func func_error;
+ Func func_progress;
+
+ gpointer data;
+
+ guint idle_done_id; /**< event source id */
+};
+
ThumbLoader *thumb_loader_new(gint width, gint height);
void thumb_loader_set_callbacks(ThumbLoader *tl,
- ThumbLoaderFunc func_done,
- ThumbLoaderFunc func_error,
- ThumbLoaderFunc func_progress,
+ ThumbLoader::Func func_done,
+ ThumbLoader::Func func_error,
+ ThumbLoader::Func func_progress,
gpointer data);
void thumb_loader_set_cache(ThumbLoader *tl, gboolean enable_cache, gboolean local, gboolean retry_failed);
#ifndef TOOLBAR_H
#define TOOLBAR_H
+struct LayoutWindow;
+
GtkWidget *toolbar_select_new(LayoutWindow *lw, ToolbarType bar);
void toolbar_apply(ToolbarType bar);
+
#endif
/* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */
ZOOM_RESET_NONE = 2
};
-enum ZoomStyle {
- ZOOM_GEOMETRIC = 0,
- ZOOM_ARITHMETIC = 1
-};
-
enum ClipboardDestination {
CLIPBOARD_TEXT_PLAIN = 0,
CLIPBOARD_TEXT_URI_LIST = 1,
SORT_CLASS
};
-/**
- * @enum DnDAction
- * drag and drop default action
- */
-enum DnDAction {
- DND_ACTION_ASK,
- DND_ACTION_COPY,
- DND_ACTION_MOVE
-};
-
enum AlterType {
ALTER_NONE, /**< do nothing */
ALTER_ROTATE_90,
ALTER_FLIP,
};
-enum LayoutLocation {
- LAYOUT_HIDE = 0,
- LAYOUT_LEFT = 1 << 0,
- LAYOUT_RIGHT = 1 << 1,
- LAYOUT_TOP = 1 << 2,
- LAYOUT_BOTTOM = 1 << 3
-};
-
-
-enum ImageState {
- IMAGE_STATE_NONE = 0,
- IMAGE_STATE_IMAGE = 1 << 0,
- IMAGE_STATE_LOADING = 1 << 1,
- IMAGE_STATE_ERROR = 1 << 2,
- IMAGE_STATE_COLOR_ADJ = 1 << 3,
- IMAGE_STATE_ROTATE_AUTO = 1 << 4,
- IMAGE_STATE_ROTATE_USER = 1 << 5,
- IMAGE_STATE_DELAY_FLIP = 1 << 6
-};
enum ImageSplitMode {
SPLIT_NONE = 0,
SPLIT_QUAD,
};
-enum FileDataChangeType {
- FILEDATA_CHANGE_DELETE,
- FILEDATA_CHANGE_MOVE,
- FILEDATA_CHANGE_RENAME,
- FILEDATA_CHANGE_COPY,
- FILEDATA_CHANGE_UNSPECIFIED,
- FILEDATA_CHANGE_WRITE_METADATA
-};
-
enum MarkToSelectionMode {
MTS_MODE_MINUS,
MTS_MODE_SET,
extern const gchar *format_class_list[]; /**< defined in preferences.cc */
-/**
- * @enum SecureSaveErrno
- * see err field in #SecureSaveInfo
- */
-enum SecureSaveErrno {
- SS_ERR_NONE = 0,
- SS_ERR_DISABLED, /**< secsave is disabled. */
- SS_ERR_OUT_OF_MEM, /**< memory allocation failure */
-
- SS_ERR_OPEN_READ,
- SS_ERR_OPEN_WRITE,
- SS_ERR_STAT,
- SS_ERR_ACCESS,
- SS_ERR_MKSTEMP,
- SS_ERR_RENAME,
- SS_ERR_OTHER,
-};
-
-enum NotifyPriority {
- NOTIFY_PRIORITY_HIGH = 0,
- NOTIFY_PRIORITY_MEDIUM,
- NOTIFY_PRIORITY_LOW
-};
-
enum NotifyType {
NOTIFY_MARKS = 1 << 1, /**< changed marks */
NOTIFY_PIXBUF = 1 << 2, /**< image was read into fd->pixbuf */
METADATA_FORMATTED = 1 /**< for display only */
};
-enum StartUpPath {
- STARTUP_PATH_CURRENT = 0,
- STARTUP_PATH_LAST,
- STARTUP_PATH_HOME,
-};
-
enum ToolbarType {
TOOLBAR_MAIN,
TOOLBAR_STATUS,
STEREO_PIXBUF_NONE = 3
};
-enum SortModeType {
- BAR_SORT_MODE_FOLDER = 0,
- BAR_SORT_MODE_COLLECTION,
- BAR_SORT_MODE_COUNT
-};
-
-enum SortActionType {
- BAR_SORT_COPY = 0,
- BAR_SORT_MOVE,
- BAR_SORT_FILTER,
- BAR_SORT_ACTION_COUNT
-};
-
-enum SortSelectionType {
- BAR_SORT_SELECTION_IMAGE = 0,
- BAR_SORT_SELECTION_SELECTED,
- BAR_SORT_SELECTION_COUNT
-};
-
-#define MAX_SPLIT_IMAGES 4
-
-enum SelectionType {
- SELECTION_NONE = 0,
- SELECTION_SELECTED = 1 << 0,
- SELECTION_PRELIGHT = 1 << 1,
- SELECTION_FOCUS = 1 << 2
-};
-
-struct ImageLoader;
-struct ThumbLoader;
-
-struct AnimationData;
-
-struct CollectInfo;
-struct CollectionData;
-struct CollectTable;
-struct CollectWindow;
-
-struct ImageWindow;
-
-struct FileData;
-struct FileDataChangeInfo;
-
-struct LayoutWindow;
-struct LayoutOptions;
-
-struct ViewDir;
-struct ViewDirInfoList;
-struct ViewDirInfoTree;
-
-struct ViewFile;
-struct ViewFileInfoList;
-struct ViewFileInfoIcon;
-
-struct SlideShowData;
-struct FullScreenData;
-
-struct PixmapFolders;
-struct Histogram;
-struct HistMap;
-
-struct SecureSaveInfo;
-
-struct ExifData;
-
-struct EditorDescription;
-
-struct CommandLine;
-
-struct Histogram {
- gint histogram_channel; /**< drawing mode for histogram */
- gint histogram_mode; /**< logarithmical or not */
- guint vgrid; /**< number of vertical divisions, 0 for none */
- guint hgrid; /**< number of horizontal divisions, 0 for none */
- struct {
- int R; /**< red */
- int G; /**< green */
- int B; /**< blue */
- int A; /**< alpha */
- } grid_color; /**< grid color */
-
-};
-
-
-
-struct ImageLoader;
-
-using ThumbLoaderFunc = void (*)(ThumbLoader *, gpointer);
-
using FileUtilDoneFunc = void (*)(gboolean, const gchar *, gpointer);
-struct ThumbLoader
-{
- gboolean standard_loader;
-
- ImageLoader *il;
- FileData *fd; /**< fd->pixbuf contains final (scaled) image when done */
-
- gboolean cache_enable;
- gboolean cache_hit;
- gdouble percent_done;
-
- gint max_w;
- gint max_h;
-
- ThumbLoaderFunc func_done;
- ThumbLoaderFunc func_error;
- ThumbLoaderFunc func_progress;
-
- gpointer data;
-
- guint idle_done_id; /**< event source id */
-};
-
-struct ActionItem
-{
- const gchar *name; /* GtkActionEntry terminology */
- const gchar *label;
- const gchar *icon_name;
-};
-
-struct AnimationData
-{
- ImageWindow *iw;
- LayoutWindow *lw;
- GdkPixbufAnimation *gpa;
- GdkPixbufAnimationIter *iter;
- GdkPixbuf *gpb;
- FileData *data_adr;
- gint delay;
- gboolean valid;
- GCancellable *cancellable;
- GFile *in_file;
- GFileInputStream *gfstream;
-};
-
-struct CollectInfo
-{
- FileData *fd;
- GdkPixbuf *pixbuf;
- guint flag_mask;
-};
-
-struct CollectionData
-{
- gchar *path;
- gchar *name;
- GList *list;
- SortType sort_method;
-
- ThumbLoader *thumb_loader;
- CollectInfo *thumb_info;
-
- void (*info_updated_func)(CollectionData *, CollectInfo *, gpointer);
- gpointer info_updated_data;
-
- gint ref;
-
- /* geometry */
- gint window_read;
- gint window_x;
- gint window_y;
- gint window_w;
- gint window_h;
-
- gboolean changed; /**< contents changed since save flag */
-
- GHashTable *existence;
-
- GtkWidget *dialog_name_entry;
- gchar *collection_path; /**< Full path to collection including extension */
- gint collection_append_index;
-};
-
-struct CollectTable
-{
- GtkWidget *scrolled;
- GtkWidget *listview;
- gint columns;
- gint rows;
-
- CollectionData *cd;
-
- GList *selection;
- CollectInfo *prev_selection;
-
- CollectInfo *click_info;
-
- GtkWidget *tip_window;
- guint tip_delay_id; /**< event source id */
- CollectInfo *tip_info;
-
- GdkWindow *marker_window;
- CollectInfo *marker_info;
-
- GtkWidget *status_label;
- GtkWidget *extra_label;
-
- gint focus_row;
- gint focus_column;
- CollectInfo *focus_info;
-
- GtkWidget *popup;
- CollectInfo *drop_info;
- GList *drop_list;
-
- guint sync_idle_id; /**< event source id */
- guint drop_idle_id; /**< event source id */
-
- gboolean show_text;
- gboolean show_stars;
-
- GList *editmenu_fd_list; /**< file list for edit menu */
-};
-
-struct CollectWindow
-{
- GtkWidget *window;
- CollectTable *table;
- GtkWidget *status_box;
-
- GtkWidget *close_dialog;
-
- CollectionData *cd;
-};
-
-using ImageTileRequestFunc = gint (*)(ImageWindow *, gint, gint, gint, gint, GdkPixbuf *, gpointer);
-using ImageTileDisposeFunc = void (*)(ImageWindow *, gint, gint, gint, gint, GdkPixbuf *, gpointer);
-
-struct ImageWindow
-{
- GtkWidget *widget; /**< use this to add it and show it */
- GtkWidget *pr;
- GtkWidget *frame;
-
- FileData *image_fd;
-
- gboolean unknown; /**< failed to load image */
-
- ImageLoader *il; /**< @FIXME image loader should probably go to FileData, but it must first support
- sending callbacks to multiple ImageWindows in parallel */
-
- gint has_frame; /**< not boolean, see image_new() */
-
- /* top level (not necessarily parent) window */
- gboolean top_window_sync; /**< resize top_window when image dimensions change */
- GtkWidget *top_window; /**< window that gets title, and window to resize when 'fitting' */
- gchar *title; /**< window title to display left of file name */
- gchar *title_right; /**< window title to display right of file name */
- gboolean title_show_zoom; /**< option to include zoom in window title */
-
- gboolean completed;
- ImageState state; /**< mask of IMAGE_STATE_* flags about current image */
-
- void (*func_update)(ImageWindow *imd, gpointer data);
- void (*func_complete)(ImageWindow *imd, gint preload, gpointer data);
- void (*func_state)(ImageWindow *imd, ImageState state, gpointer data);
- ImageTileRequestFunc func_tile_request;
- ImageTileDisposeFunc func_tile_dispose;
-
- gpointer data_update;
- gpointer data_complete;
- gpointer data_state;
- gpointer data_tile;
-
- /* button, scroll functions */
- void (*func_button)(ImageWindow *, GdkEventButton *event, gpointer);
- void (*func_drag)(ImageWindow *, GdkEventMotion *event, gdouble dx, gdouble dy, gpointer);
- void (*func_scroll)(ImageWindow *, GdkEventScroll *event, gpointer);
- void (*func_focus_in)(ImageWindow *, gpointer);
-
- gpointer data_button;
- gpointer data_drag;
- gpointer data_scroll;
- gpointer data_focus_in;
-
- /**
- * @headerfile func_scroll_notify
- * scroll notification (for scroll bar implementation)
- */
- void (*func_scroll_notify)(ImageWindow *, gint x, gint y, gint width, gint height, gpointer);
-
- gpointer data_scroll_notify;
-
- /* collection info */
- CollectionData *collection;
- CollectInfo *collection_info;
-
- /* color profiles */
- gboolean color_profile_enable;
- gint color_profile_input;
- gboolean color_profile_use_image;
- gint color_profile_from_image;
- gpointer cm;
-
- AlterType delay_alter_type;
-
- FileData *read_ahead_fd;
- ImageLoader *read_ahead_il;
-
- gint prev_color_row;
-
- gboolean auto_refresh;
-
- gboolean delay_flip;
- gint orientation;
- gboolean desaturate;
- gboolean overunderexposed;
- gint user_stereo;
-
- gboolean mouse_wheel_mode;
-};
-
#define FILEDATA_MARKS_SIZE 10
-struct FileDataChangeInfo {
- FileDataChangeType type;
- gchar *source;
- gchar *dest;
- gint error;
- gboolean regroup_when_finished;
-};
-
-struct FileData {
- guint magick;
- gint type;
- gchar *original_path; /**< key to file_data_pool hash table */
- gchar *path;
- const gchar *name;
- const gchar *extension;
- gchar *extended_extension;
- FileFormatClass format_class;
- gchar *format_name; /**< set by the image loader */
- gchar *collate_key_name;
- gchar *collate_key_name_nocase;
- gchar *collate_key_name_natural;
- gchar *collate_key_name_nocase_natural;
- gint64 size;
- time_t date;
- time_t cdate;
- mode_t mode; /**< this is needed at least for notification in view_dir because it is preserved after the file/directory is deleted */
- gint sidecar_priority;
-
- guint marks; /**< each bit represents one mark */
- guint valid_marks; /**< zero bit means that the corresponding mark needs to be reread */
-
-
- GList *sidecar_files;
- FileData *parent; /**< parent file if this is a sidecar file, NULL otherwise */
- FileDataChangeInfo *change; /**< for rename, move ... */
- GdkPixbuf *thumb_pixbuf;
-
- GdkPixbuf *pixbuf; /**< full-size image, only complete images, NULL during loading
- all FileData with non-NULL pixbuf are referenced by image_cache */
-
- HistMap *histmap;
-
- gboolean locked;
- gint ref;
- gint version; /**< increased when any field in this structure is changed */
- gboolean disable_grouping;
-
- gint user_orientation;
- gint exif_orientation;
-
- ExifData *exif;
- time_t exifdate;
- time_t exifdate_digitized;
- GHashTable *modified_xmp; /**< hash table which contains unwritten xmp metadata in format: key->list of string values */
- GList *cached_metadata;
- gint rating;
- gboolean metadata_in_idle_loaded;
-
- gchar *owner;
- gchar *group;
- gchar *sym_link;
-
- SelectionType selected; /**< Used by view-file-icon. */
-
- gint page_num;
- gint page_total;
-};
-
-struct LayoutOptions
-{
- gchar *id;
-
- gchar *order;
- gint style;
-
- DirViewType dir_view_type;
- FileViewType file_view_type;
-
- struct {
- SortType method;
- gboolean ascend;
- gboolean case_sensitive;
- } dir_view_list_sort;
-
- struct {
- SortType method;
- gboolean ascend;
- gboolean case_sensitive;
- } file_view_list_sort;
-
- gboolean show_thumbnails;
- gboolean show_marks;
- gboolean show_file_filter;
- gboolean show_directory_date;
- gboolean show_info_pixel;
- gboolean split_pane_sync;
- gboolean ignore_alpha;
-
- struct {
- gint w;
- gint h;
- gint x;
- gint y;
- gboolean maximized;
- gint hdivider_pos;
- gint vdivider_pos;
- } main_window;
-
- struct {
- gint w;
- gint h;
- gint x;
- gint y;
- gint vdivider_pos;
- } float_window;
-
- struct {
- gint vdivider_pos;
- } folder_window;
-
- struct {
- gint w;
- gint h;
- } properties_window;
-
- struct {
- guint state;
- gint histogram_channel;
- gint histogram_mode;
- } image_overlay;
-
- struct {
- gint w;
- gint h;
- gint x;
- gint y;
- } log_window;
-
- struct {
- gint w;
- gint h;
- gint x;
- gint y;
- gint page_number;
- } preferences_window;
-
- struct {
- gint w;
- gint h;
- gint x;
- gint y;
- } search_window;
-
- struct {
- gint w;
- gint h;
- gint x;
- gint y;
- } dupe_window;
-
- struct {
- gint w;
- gint h;
- gint x;
- gint y;
- } advanced_exif_window;
-
- gboolean tools_float;
- gboolean tools_hidden;
- gboolean toolbar_hidden;
-
- struct {
- gboolean info;
- gboolean sort;
- gboolean tools_float;
- gboolean tools_hidden;
- gboolean hidden;
- } bars_state;
-
- gchar *home_path;
- gchar *last_path;
-
- StartUpPath startup_path;
-
- gboolean animate;
- gint workspace;
-
- SortActionType action;
- SortModeType mode;
- SortSelectionType selection;
- gchar *filter_key;
-};
-
-struct LayoutWindow
-{
- LayoutOptions options;
-
- FileData *dir_fd;
-
- /* base */
-
- GtkWidget *window;
-
- GtkWidget *main_box;
-
- GtkWidget *group_box;
- GtkWidget *h_pane;
- GtkWidget *v_pane;
-
- /* menus, path selector */
-
- GtkActionGroup *action_group;
- GtkActionGroup *action_group_editors;
- guint ui_editors_id;
- GtkUIManager *ui_manager;
- guint toolbar_merge_id[TOOLBAR_COUNT];
- GList *toolbar_actions[TOOLBAR_COUNT];
-
- GtkWidget *path_entry;
-
- /* image */
-
- LayoutLocation image_location;
-
- ImageWindow *image;
-
- ImageWindow *split_images[MAX_SPLIT_IMAGES];
- ImageSplitMode split_mode;
- gint active_split_image;
-
- GtkWidget *split_image_widget;
- GtkSizeGroup *split_image_sizegroup;
-
- /* tools window (float) */
-
- GtkWidget *tools;
- GtkWidget *tools_pane;
-
- GtkWidget *menu_tool_bar; /**< Combined menu and toolbar box */
- GtkWidget *menu_bar; /**< referenced by lw, exist during whole lw lifetime */
- /* toolbar */
-
- GtkWidget *toolbar[TOOLBAR_COUNT]; /**< referenced by lw, exist during whole lw lifetime */
-
- GtkWidget *back_button;
-
- /* dir view */
-
- LayoutLocation dir_location;
-
- ViewDir *vd;
- GtkWidget *dir_view;
-
- /* file view */
-
- LayoutLocation file_location;
-
- ViewFile *vf;
-
- GtkWidget *file_view;
-
- GtkWidget *info_box; /**< status bar */
- GtkWidget *info_progress_bar; /**< status bar */
- GtkWidget *info_sort; /**< status bar */
- GtkWidget *info_status; /**< status bar */
- GtkWidget *info_details; /**< status bar */
- GtkWidget *info_zoom; /**< status bar */
- GtkWidget *info_pixel; /**< status bar */
-
- /* slide show */
-
- SlideShowData *slideshow;
-
- /* full screen */
-
- FullScreenData *full_screen;
-
- /* misc */
-
- GtkWidget *utility_box; /**< referenced by lw, exist during whole lw lifetime */
- GtkWidget *utility_paned; /**< between image and bar */
- GtkWidget *bar_sort;
- GtkWidget *bar;
-
- gboolean bar_sort_enabled; /**< Set during start-up, and checked when the editors have loaded */
-
- GtkWidget *exif_window;
- GtkWidget *sar_window; /**< Search and Run window */
-
- AnimationData *animation;
-
- GtkWidget *log_window;
-};
-
-struct ViewDir
-{
- DirViewType type;
- gpointer info;
-
- GtkWidget *widget;
- GtkWidget *view;
-
- FileData *dir_fd;
-
- FileData *click_fd;
-
- FileData *drop_fd;
- GList *drop_list;
- guint drop_scroll_id; /**< event source id */
-
- /* func list */
- void (*select_func)(ViewDir *vd, FileData *fd, gpointer data);
- gpointer select_data;
-
- void (*dnd_drop_update_func)(ViewDir *vd);
- void (*dnd_drop_leave_func)(ViewDir *vd);
-
- LayoutWindow *layout;
-
- GtkWidget *popup;
-
- PixmapFolders *pf;
-};
-
-struct ViewDirInfoList
-{
- GList *list;
-};
-
-struct ViewDirInfoTree
-{
- guint drop_expand_id; /**< event source id */
- gint busy_ref;
-};
-
-
-struct ViewFile
-{
- FileViewType type; /**< @todo (xsdg): Turn this into a union (see VFLIST and VFICON from view-file.h). */
-
- gpointer info;
-
- GtkWidget *widget;
- GtkWidget *listview;
- GtkWidget *scrolled;
- GtkWidget *filter;
- GtkWidget *filter_check[FILEDATA_MARKS_SIZE];
-
- struct {
- GtkWidget *combo;
- GtkWidget *frame;
- gint count;
- gint last_selected;
- gboolean case_sensitive;
- } file_filter;
-
- FileData *dir_fd;
- GList *list;
-
- SortType sort_method;
- gboolean sort_ascend;
- gboolean sort_case;
-
- /* func list */
- void (*func_thumb_status)(ViewFile *vf, gdouble val, const gchar *text, gpointer data);
- gpointer data_thumb_status;
-
- void (*func_status)(ViewFile *vf, gpointer data);
- gpointer data_status;
-
- LayoutWindow *layout;
-
- GtkWidget *popup;
-
- /* thumbs updates*/
- gboolean thumbs_running;
- ThumbLoader *thumbs_loader;
- FileData *thumbs_filedata;
-
- /* marks */
- gboolean marks_enabled;
- gint active_mark;
- gint clicked_mark;
-
- /* stars */
- FileData *stars_filedata;
- guint stars_id;
-
- /* refresh */
- guint refresh_idle_id; /**< event source id */
- time_t time_refresh_set; /**< time when refresh_idle_id was set */
-
- GList *editmenu_fd_list; /**< file list for edit menu */
-
- guint read_metadata_in_idle_id;
-};
-
-struct ViewFileInfoList
-{
- FileData *click_fd;
- FileData *select_fd;
-
- gboolean thumbs_enabled;
-
- guint select_idle_id; /**< event source id */
-};
-
-struct ViewFileInfoIcon
-{
- /* table stuff */
- gint columns;
- gint rows;
-
- GList *selection;
- FileData *prev_selection;
-
- GtkWidget *tip_window;
- guint tip_delay_id; /**< event source id */
- FileData *tip_fd;
-
- FileData *click_fd;
-
- FileData *focus_fd;
- gint focus_row;
- gint focus_column;
-
- gboolean show_text;
-};
-
-struct SlideShowData
-{
- LayoutWindow *lw; /**< use this window to display the slideshow */
- ImageWindow *imd; /**< use this window only if lw is not available,
- @FIXME it is probably required only by img-view.cc and should be dropped with it */
-
- GList *filelist;
- CollectionData *cd;
- FileData *dir_fd;
-
- GList *list;
- GList *list_done;
-
- FileData *slide_fd;
-
- guint slide_count;
- guint timeout_id; /**< event source id */
-
- gboolean from_selection;
-
- void (*stop_func)(SlideShowData *, gpointer);
- gpointer stop_data;
-
- gboolean paused;
-};
-
-struct FullScreenData
-{
- GtkWidget *window;
- ImageWindow *imd;
-
- GtkWidget *normal_window;
- ImageWindow *normal_imd;
-
- guint hide_mouse_id; /**< event source id */
- guint busy_mouse_id; /**< event source id */
-
- gint cursor_state;
-
- guint saver_block_id; /**< event source id */
-
- void (*stop_func)(FullScreenData *, gpointer);
- gpointer stop_data;
-
- gboolean same_region; /**< the returned region will overlap the current location of widget. */
-};
-
-struct PixmapFolders
-{
- GdkPixbuf *close;
- GdkPixbuf *open;
- GdkPixbuf *deny;
- GdkPixbuf *parent;
- GdkPixbuf *link;
- GdkPixbuf *read_only;
-};
-
-struct SecureSaveInfo {
- FILE *fp; /**< file stream pointer */
- gchar *file_name; /**< final file name */
- gchar *tmp_file_name; /**< temporary file name */
- gint err; /**< set to non-zero value in case of error */
- gboolean secure_save; /**< use secure save for this file, internal use only */
- gboolean preserve_perms; /**< whether to preserve perms, TRUE by default */
- gboolean preserve_mtime; /**< whether to preserve mtime, FALSE by default */
- gboolean unlink_on_error; /**< whether to remove temporary file on save failure, TRUE by default */
-};
-
-struct CommandLine
-{
- int argc;
- gchar **argv;
- gboolean startup_blank;
- gboolean startup_full_screen;
- gboolean startup_in_slideshow;
- gboolean startup_command_line_collection;
- gboolean tools_hide;
- gboolean tools_show;
- gboolean log_window_show;
- gchar *path;
- gchar *file;
- GList *cmd_list;
- GList *collection_list;
- gchar *geometry;
- gchar *regexp;
- gchar *log_file;
- SecureSaveInfo *ssi;
- gboolean new_instance;
-};
-
-/**
- * @struct hard_coded_window_keys
- * @brief hard coded window shortcut keys
- *
- * Used for two purposes:\n
- * to display the shortcuts keys in popup menus\n
- * used by ./doc/create-shortcuts-xml.sh to generate shortcut documentation in the Help files
- *
- */
-struct hard_coded_window_keys {
- GdkModifierType mask; /**< modifier key mask */
- guint key_value; /**< GDK_keyval */
- const gchar *text; /**< menu item label - NULL if end of list */
-};
-
#endif
/* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */
#define UI_MENU_H
+/**
+ * @struct hard_coded_window_keys
+ * @brief hard coded window shortcut keys
+ *
+ * Used for two purposes:\n
+ * to display the shortcuts keys in popup menus\n
+ * used by ./doc/create-shortcuts-xml.sh to generate shortcut documentation in the Help files
+ *
+ */
+struct hard_coded_window_keys {
+ GdkModifierType mask; /**< modifier key mask */
+ guint key_value; /**< GDK_keyval */
+ const gchar *text; /**< menu item label - NULL if end of list */
+};
+
GtkWidget *menu_item_add(GtkWidget *menu, const gchar *label,
GCallback func, gpointer data);
GtkWidget *menu_item_add_stock(GtkWidget *menu, const gchar *label, const gchar *stock_id,
gchar *text_widget_text_pull(GtkWidget *text_widget);
gchar *text_widget_text_pull_selected(GtkWidget *text_widget);
+struct ActionItem
+{
+ const gchar *name; /* GtkActionEntry terminology */
+ const gchar *label;
+ const gchar *icon_name;
+};
+
GList* get_action_items();
void action_items_free(GList *list);
#ifndef UI_UTILDLG_H
#define UI_UTILDLG_H
+struct FileData;
#define GENERIC_DIALOG(gd) ((GenericDialog *)gd)
#include "ui-utildlg.h"
+struct FileData;
+
void file_maint_renamed(FileData *fd);
void file_maint_moved(FileData *fd, GList *ignore_list);
void file_maint_copied(FileData *fd);
#include "view-dir-list.h"
#include "filedata.h"
+#include "layout.h"
#include "ui-fileops.h"
#include "ui-tree-edit.h"
#include "view-dir.h"
+struct ViewDirInfoList
+{
+ GList *list;
+};
+
#define VDLIST(_vd_) ((ViewDirInfoList *)(_vd_->info))
#ifndef VIEW_DIR_LIST_H
#define VIEW_DIR_LIST_H
+struct FileData;
+struct ViewDir;
ViewDir *vdlist_new(ViewDir *vd, FileData *dir_fd);
#include "view-dir-tree.h"
#include "filedata.h"
+#include "layout.h"
#include "ui-fileops.h"
#include "ui-tree-edit.h"
#include "view-dir.h"
+struct ViewDirInfoTree
+{
+ guint drop_expand_id; /**< event source id */
+ gint busy_ref;
+};
+
#define VDTREE(_vd_) ((ViewDirInfoTree *)(_vd_->info))
#ifndef VIEW_DIR_TREE_H
#define VIEW_DIR_TREE_H
+struct FileData;
+struct ViewDir;
+
struct NodeData
{
FileData *fd;
#ifndef VIEW_DIR_H
#define VIEW_DIR_H
+struct FileData;
+struct LayoutWindow;
+
enum {
DIR_COLUMN_POINTER = 0,
DIR_COLUMN_ICON,
DIR_COLUMN_COUNT
};
+struct PixmapFolders
+{
+ GdkPixbuf *close;
+ GdkPixbuf *open;
+ GdkPixbuf *deny;
+ GdkPixbuf *parent;
+ GdkPixbuf *link;
+ GdkPixbuf *read_only;
+};
+
+struct ViewDir
+{
+ DirViewType type;
+ gpointer info;
+
+ GtkWidget *widget;
+ GtkWidget *view;
+
+ FileData *dir_fd;
+
+ FileData *click_fd;
+
+ FileData *drop_fd;
+ GList *drop_list;
+ guint drop_scroll_id; /**< event source id */
+
+ /* func list */
+ void (*select_func)(ViewDir *vd, FileData *fd, gpointer data);
+ gpointer select_data;
+
+ void (*dnd_drop_update_func)(ViewDir *vd);
+ void (*dnd_drop_leave_func)(ViewDir *vd);
+
+ LayoutWindow *layout;
+
+ GtkWidget *popup;
+
+ PixmapFolders *pf;
+};
+
ViewDir *vd_new(LayoutWindow *lw);
void vd_set_select_func(ViewDir *vdl, void (*func)(ViewDir *vdl, FileData *fd, gpointer data), gpointer data);
#ifndef VIEW_FILE_H
#define VIEW_FILE_H
+struct FileData;
+struct LayoutWindow;
+struct ThumbLoader;
+
+struct ViewFile
+{
+ FileViewType type; /**< @todo (xsdg): Turn this into a union (see VFLIST and VFICON). */
+
+ gpointer info;
+
+ GtkWidget *widget;
+ GtkWidget *listview;
+ GtkWidget *scrolled;
+ GtkWidget *filter;
+ GtkWidget *filter_check[FILEDATA_MARKS_SIZE];
+
+ struct {
+ GtkWidget *combo;
+ GtkWidget *frame;
+ gint count;
+ gint last_selected;
+ gboolean case_sensitive;
+ } file_filter;
+
+ FileData *dir_fd;
+ GList *list;
+
+ SortType sort_method;
+ gboolean sort_ascend;
+ gboolean sort_case;
+
+ /* func list */
+ void (*func_thumb_status)(ViewFile *vf, gdouble val, const gchar *text, gpointer data);
+ gpointer data_thumb_status;
+
+ void (*func_status)(ViewFile *vf, gpointer data);
+ gpointer data_status;
+
+ LayoutWindow *layout;
+
+ GtkWidget *popup;
+
+ /* thumbs updates*/
+ gboolean thumbs_running;
+ ThumbLoader *thumbs_loader;
+ FileData *thumbs_filedata;
+
+ /* marks */
+ gboolean marks_enabled;
+ gint active_mark;
+ gint clicked_mark;
+
+ /* stars */
+ FileData *stars_filedata;
+ guint stars_id;
+
+ /* refresh */
+ guint refresh_idle_id; /**< event source id */
+ time_t time_refresh_set; /**< time when refresh_idle_id was set */
+
+ GList *editmenu_fd_list; /**< file list for edit menu */
+
+ guint read_metadata_in_idle_id;
+};
+
+struct ViewFileInfoList
+{
+ FileData *click_fd;
+ FileData *select_fd;
+
+ gboolean thumbs_enabled;
+
+ guint select_idle_id; /**< event source id */
+};
+
+struct ViewFileInfoIcon
+{
+ /* table stuff */
+ gint columns;
+ gint rows;
+
+ GList *selection;
+ FileData *prev_selection;
+
+ GtkWidget *tip_window;
+ guint tip_delay_id; /**< event source id */
+ FileData *tip_fd;
+
+ FileData *click_fd;
+
+ FileData *focus_fd;
+ gint focus_row;
+ gint focus_column;
+
+ gboolean show_text;
+};
+
#define VFLIST(_vf_) ((ViewFileInfoList *)(_vf_->info))
#define VFICON(_vf_) ((ViewFileInfoIcon *)(_vf_->info))
#include "filedata.h"
+struct ViewFile;
+
gboolean vficon_press_key_cb(GtkWidget *widget, GdkEventKey *event, gpointer data);
gboolean vficon_press_cb(GtkWidget *widget, GdkEventButton *bevent, gpointer data);
gboolean vficon_release_cb(GtkWidget *widget, GdkEventButton *bevent, gpointer data);
#include "filedata.h"
+struct ViewFile;
+
gboolean vflist_press_key_cb(GtkWidget *widget, GdkEventKey *event, gpointer data);
gboolean vflist_press_cb(GtkWidget *widget, GdkEventButton *bevent, gpointer data);
gboolean vflist_release_cb(GtkWidget *widget, GdkEventButton *bevent, gpointer data);