mirror of
https://github.com/KevinMidboe/linguist.git
synced 2025-10-29 09:40:21 +00:00
See https://github.com/github/linguist/issues/1626#issuecomment-73870081
Taken from 469fe63df4/pqiv.h
167 lines
5.9 KiB
C
167 lines
5.9 KiB
C
/**
|
|
* pqiv
|
|
*
|
|
* Copyright (c) 2013-2014, Phillip Berndt
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
// This file contains the definition of files, image types and
|
|
// the plugin infrastructure. It should be included in file type
|
|
// handlers.
|
|
|
|
#ifndef _PQIV_H_INCLUDED
|
|
#define _PQIV_H_INCLUDED
|
|
|
|
#include <glib.h>
|
|
#include <gtk/gtk.h>
|
|
#include <gio/gio.h>
|
|
#include "lib/bostree.h"
|
|
|
|
#ifndef PQIV_VERSION
|
|
#define PQIV_VERSION "2.3"
|
|
#endif
|
|
|
|
#define FILE_FLAGS_ANIMATION (guint)(1)
|
|
#define FILE_FLAGS_MEMORY_IMAGE (guint)(1<<1)
|
|
|
|
// The structure for images {{{
|
|
typedef struct file_type_handler_struct_t file_type_handler_t;
|
|
typedef struct {
|
|
// File type
|
|
const file_type_handler_t *file_type;
|
|
|
|
// Special flags
|
|
// FILE_FLAGS_ANIMATION -> Animation functions are invoked
|
|
// Set by file type handlers
|
|
// FILE_FLAGS_MEMORY_IMAGE -> File lives in memory
|
|
guint file_flags;
|
|
|
|
// The file name to display and to sort by
|
|
gchar *display_name;
|
|
|
|
// The URI or file name of the file
|
|
gchar *file_name;
|
|
|
|
// If the file is a memory image, the actual image data
|
|
GBytes *file_data;
|
|
|
|
// The file monitor structure is used for inotify-watching of
|
|
// the files
|
|
GFileMonitor *file_monitor;
|
|
|
|
// This flag stores whether this image is currently loaded
|
|
// and valid. i.e. if it is set, you can assume that
|
|
// private_data contains a representation of the image;
|
|
// if not, you can NOT assume that it does not.
|
|
gboolean is_loaded;
|
|
|
|
// Cached image size
|
|
guint width;
|
|
guint height;
|
|
|
|
// File-type specific data, allocated and freed by the file type handlers
|
|
void *private;
|
|
} file_t;
|
|
// }}}
|
|
// Definition of the built-in file types {{{
|
|
|
|
// If you want to implement your own file type, you'll have to implement the
|
|
// following functions and a non-static initialization function named
|
|
// file_type_NAME_initializer that fills a file_type_handler_t with pointers to
|
|
// the functions. Store the file in backends/NAME.c and adjust the Makefile to
|
|
// add the required libraries if your backend is listed in the $(BACKENDS)
|
|
// variable.
|
|
|
|
typedef enum { PARAMETER, RECURSION, INOTIFY, BROWSE_ORIGINAL_PARAMETER, FILTER_OUTPUT } load_images_state_t;
|
|
// Allocation function: Allocate the ->private structure within a file and add the
|
|
// image(s) to the list of available images via load_images_handle_parameter_add_file()
|
|
// If an image is not to be loaded for any reason, the file structure should be
|
|
// deallocated using file_free()
|
|
// Returns a pointer to the first added image
|
|
// Optional, you can also set the pointer to this function to NULL.
|
|
typedef BOSNode *(*file_type_alloc_fn_t)(load_images_state_t state, file_t *file);
|
|
|
|
// Deallocation, if a file is removed from the images list. Free the ->private structure.
|
|
// Only called if ->private is non-NULL.
|
|
typedef void (*file_type_free_fn_t)(file_t *file);
|
|
|
|
// Actually load a file into memory
|
|
typedef void (*file_type_load_fn_t)(file_t *file, GInputStream *data, GError **error_pointer);
|
|
|
|
// Unload a file
|
|
typedef void (*file_type_unload_fn_t)(file_t *file);
|
|
|
|
// Animation support: Initialize memory for animations, return ms until first frame
|
|
// Optional, you can also set the pointer to this function to NULL.
|
|
typedef double (*file_type_animation_initialize_fn_t)(file_t *file);
|
|
|
|
// Animation support: Advance to the next frame, return ms until next frame
|
|
// Optional, you can also set the pointer to this function to NULL.
|
|
typedef double (*file_type_animation_next_frame_fn_t)(file_t *file);
|
|
|
|
// Draw the current view to a cairo context
|
|
typedef void (*file_type_draw_fn_t)(file_t *file, cairo_t *cr);
|
|
|
|
struct file_type_handler_struct_t {
|
|
// All files will be filtered with this filter. If it lets it pass,
|
|
// a handler is assigned to a file. If none do, the file is
|
|
// discarded if it was found during directory traversal or
|
|
// loaded using the first image backend if it was an explicit
|
|
// parameter.
|
|
GtkFileFilter *file_types_handled;
|
|
|
|
// Pointers to the functions defined above
|
|
file_type_alloc_fn_t alloc_fn;
|
|
file_type_free_fn_t free_fn;
|
|
file_type_load_fn_t load_fn;
|
|
file_type_unload_fn_t unload_fn;
|
|
file_type_animation_initialize_fn_t animation_initialize_fn;
|
|
file_type_animation_next_frame_fn_t animation_next_frame_fn;
|
|
file_type_draw_fn_t draw_fn;
|
|
};
|
|
|
|
// Initialization function: Tell pqiv about a backend
|
|
typedef void (*file_type_initializer_fn_t)(file_type_handler_t *info);
|
|
|
|
// pqiv symbols available to plugins {{{
|
|
|
|
// Global cancellable that should be used for every i/o operation
|
|
extern GCancellable *image_loader_cancellable;
|
|
|
|
// Current scale level. For backends that don't support cairo natively.
|
|
extern gdouble current_scale_level;
|
|
|
|
// Load a file from disc/memory/network
|
|
GInputStream *image_loader_stream_file(file_t *file, GError **error_pointer);
|
|
|
|
// Add a file to the list of loaded files
|
|
// Should be called at least once in a file_type_alloc_fn_t, with the state being
|
|
// forwarded unaltered.
|
|
BOSNode *load_images_handle_parameter_add_file(load_images_state_t state, file_t *file);
|
|
|
|
// Load all data from an input stream into memory, conveinience function
|
|
GBytes *g_input_stream_read_completely(GInputStream *input_stream, GCancellable *cancellable, GError **error_pointer);
|
|
|
|
// Free a file
|
|
void file_free(file_t *file);
|
|
|
|
// }}}
|
|
|
|
// File type handlers, used in the initializer and file type guessing
|
|
extern file_type_handler_t file_type_handlers[];
|
|
|
|
/* }}} */
|
|
|
|
#endif
|