/* See LICENSE file for license and copyright information */ #ifndef DATABASE_H #define DATABASE_H #include #include #include "zathura.h" #include "bookmarks.h" /** * Initialize database system. * * @param dir Path to the directory where the database file should be located. * @return A valid zathura_database_t instance or NULL on failure */ zathura_database_t* zathura_db_init(const char* dir); /** * Free database instance. * * @param db The database instance to free. */ void zathura_db_free(zathura_database_t* db); /** * Add or update bookmark in the database. * * @param db The database instance * @param file The file to which the bookmark belongs to. * @param bookmark The bookmark instance. * @return true on success, false otherwise */ bool zathura_db_add_bookmark(zathura_database_t* db, const char* file, zathura_bookmark_t* bookmark); /** * Add or update bookmark in the database. * * @param db The database instance * @param file The file to which the bookmark belongs to. * @param id The id of the bookmark * @return true on success, false otherwise */ bool zathura_db_remove_bookmark(zathura_database_t* db, const char* file, const char* id); /** * Loads all bookmarks from the database belonging to a specific file. * * @param db The database instance. * @param file The file for which the bookmarks should be loaded. * @return List of zathura_bookmark_t* or NULL on failure. */ girara_list_t* zathura_db_load_bookmarks(zathura_database_t* db, const char* file); /** * Set file info (last site, ...) in the database. * * @param db The database instance * @param file The file to which the file info belongs to. * @param page The last page. * @param offset The last offset. * @param scale The last scale. * @return true on success, false otherwise. */ bool zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned int page, int offset, double scale); /* Get file info (last site, ...) from the database. * * @param db The database instance * @param file The file to which the file info belongs to. * @param page The last page. * @param offset The last offset. * @param scale The last scale. * @return true on success, false otherwise. */ bool zathura_db_get_fileinfo(zathura_database_t* db, const char* file, unsigned int* page, int* offset, double* scale); #endif // DATABASE_H