/* See LICENSE file for license and copyright information */ #ifndef TYPES_H #define TYPES_H #include <girara/datastructures.h> #include "macros.h" /** * Document */ typedef struct zathura_document_s zathura_document_t; /** * Page */ typedef struct zathura_page_s zathura_page_t; /** * Page widget */ typedef struct zathura_page_widget_s ZathuraPage; typedef struct zathura_page_widget_class_s ZathuraPageClass; /** * Zathura */ typedef struct zathura_s zathura_t; /** * Plugin manager */ typedef struct zathura_plugin_manager_s zathura_plugin_manager_t; /** * Renderer */ typedef struct zathura_renderer_s ZathuraRenderer; /** * D-Bus manager */ typedef struct zathura_dbus_s ZathuraDbus; /** * Error types */ typedef enum zathura_plugin_error_e { ZATHURA_ERROR_OK, /**< No error occured */ ZATHURA_ERROR_UNKNOWN, /**< An unknown error occured */ ZATHURA_ERROR_OUT_OF_MEMORY, /**< Out of memory */ ZATHURA_ERROR_NOT_IMPLEMENTED, /**< The called function has not been implemented */ ZATHURA_ERROR_INVALID_ARGUMENTS, /**< Invalid arguments have been passed */ ZATHURA_ERROR_INVALID_PASSWORD /**< The provided password is invalid */ } zathura_error_t; /** * Possible information entry types */ typedef enum zathura_document_information_type_e { ZATHURA_DOCUMENT_INFORMATION_TITLE, /**< Title of the document */ ZATHURA_DOCUMENT_INFORMATION_AUTHOR, /**< Author of the document */ ZATHURA_DOCUMENT_INFORMATION_SUBJECT, /**< Subject of the document */ ZATHURA_DOCUMENT_INFORMATION_KEYWORDS, /**< Keywords of the document */ ZATHURA_DOCUMENT_INFORMATION_CREATOR, /**< Creator of the document */ ZATHURA_DOCUMENT_INFORMATION_PRODUCER, /**< Producer of the document */ ZATHURA_DOCUMENT_INFORMATION_CREATION_DATE, /**< Creation data */ ZATHURA_DOCUMENT_INFORMATION_MODIFICATION_DATE, /**< Modification data */ ZATHURA_DOCUMENT_INFORMATION_OTHER /**< Any other information */ } zathura_document_information_type_t; /** * Plugin */ typedef struct zathura_plugin_s zathura_plugin_t; /** * Document information entry * * Represents a single entry in the returned list from the \ref * zathura_document_get_information function */ typedef struct zathura_document_information_entry_s zathura_document_information_entry_t; /** * Image buffer */ typedef struct zathura_image_buffer_s { unsigned char* data; /**< Image buffer data */ unsigned int height; /**< Height of the image */ unsigned int width; /**< Width of the image */ unsigned int rowstride; /**< Rowstride of the image */ } zathura_image_buffer_t; /** * Adjust mode */ typedef enum zathura_adjust_mode_e { ZATHURA_ADJUST_NONE, /**< No adjustment */ ZATHURA_ADJUST_BESTFIT, /**< Adjust to best-fit */ ZATHURA_ADJUST_WIDTH, /**< Adjust to width */ ZATHURA_ADJUST_INPUTBAR /**< Focusing the inputbar */ } zathura_adjust_mode_t; /** * Creates an image buffer * * @param width Width of the image stored in the buffer * @param height Height of the image stored in the buffer * @return Image buffer or NULL if an error occured */ zathura_image_buffer_t* zathura_image_buffer_create(unsigned int width, unsigned int height); /** * Frees the image buffer * * @param buffer The image buffer */ void zathura_image_buffer_free(zathura_image_buffer_t* buffer); /** * Rectangle structure. * The coordinate system has its origin in the left upper corner. The x axes * goes to the right, the y access goes down. */ typedef struct zathura_rectangle_s { double x1; /**< X coordinate of point 1 */ double y1; /**< Y coordinate of point 1 */ double x2; /**< X coordinate of point 2 */ double y2; /**< Y coordinate of point 2 */ } zathura_rectangle_t; /** * Image structure */ typedef struct zathura_image_s { zathura_rectangle_t position; /**< Coordinates of the image */ void* data; /**< Custom data of the plugin */ } zathura_image_t; /** * Possible link types */ typedef enum zathura_link_type_e { ZATHURA_LINK_INVALID, /**< Invalid type */ ZATHURA_LINK_NONE, /**< No action */ ZATHURA_LINK_GOTO_DEST, /**< Links to a page */ ZATHURA_LINK_GOTO_REMOTE, /**< Links to a page */ ZATHURA_LINK_URI, /**< Links to an external source */ ZATHURA_LINK_LAUNCH, /**< Links to an external source */ ZATHURA_LINK_NAMED /**< Links to an external source */ } zathura_link_type_t; typedef enum zathura_link_destination_type_e { ZATHURA_LINK_DESTINATION_UNKNOWN, ZATHURA_LINK_DESTINATION_XYZ, ZATHURA_LINK_DESTINATION_FIT, ZATHURA_LINK_DESTINATION_FITH, ZATHURA_LINK_DESTINATION_FITV, ZATHURA_LINK_DESTINATION_FITR, ZATHURA_LINK_DESTINATION_FITB, ZATHURA_LINK_DESTINATION_FITBH, ZATHURA_LINK_DESTINATION_FITBV } zathura_link_destination_type_t; typedef struct zathura_link_target_s { zathura_link_destination_type_t destination_type; char* value; /**< Value */ unsigned int page_number; /**< Page number */ double left; /**< Left coordinate */ double right; /**< Right coordinate */ double top; /**< Top coordinate */ double bottom; /**< Bottom coordinate */ double scale; /**< Scale */ } zathura_link_target_t; /** * Link */ typedef struct zathura_link_s zathura_link_t; /** * Index element */ typedef struct zathura_index_element_s { char* title; /**< Title of the element */ zathura_link_t* link; } zathura_index_element_t; /** * Form type */ typedef enum zathura_form_type_e { ZATHURA_FORM_CHECKBOX, /**< Checkbox */ ZATHURA_FORM_TEXTFIELD /**< Textfield */ } zathura_form_type_t; /** * Form element */ typedef struct zathura_form_s { zathura_rectangle_t position; /**< Position */ zathura_form_type_t type; /**< Type */ } zathura_form_t; /** * Create new index element * * @param title Title of the index element * @return Index element */ zathura_index_element_t* zathura_index_element_new(const char* title); /** * Free index element * * @param index The index element */ void zathura_index_element_free(zathura_index_element_t* index); /** * Creates a list that should be used to store \ref * zathura_document_information_entry_t entries * * @return A list or NULL if an error occured */ girara_list_t* zathura_document_information_entry_list_new(); /** * Creates a new document information entry * * @param type The type * @param value The value * * @return A new entry or NULL if an error occured */ zathura_document_information_entry_t* zathura_document_information_entry_new(zathura_document_information_type_t type, const char* value); /** * Frees a document information entry * * @param entry The entry that should be freed */ void zathura_document_information_entry_free(zathura_document_information_entry_t* entry); #endif // TYPES_H