mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-20 17:39:58 +03:00
f37e52c394
The generic bitmap handlers provided by each frontend are called back from the core and therefore should be in an operation table. This was one of the very few remaining interfaces stopping the core code from being split into a library.
135 lines
3.1 KiB
C
135 lines
3.1 KiB
C
/*
|
|
* Copyright 2014 Vincent Sanders <vince@netsurf-browser.org>
|
|
*
|
|
* This file is part of NetSurf, http://www.netsurf-browser.org/
|
|
*
|
|
* NetSurf 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; version 2 of the License.
|
|
*
|
|
* NetSurf 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/>.
|
|
*/
|
|
|
|
/**
|
|
* \file
|
|
* top level interface table.
|
|
*
|
|
* \note This should probably not be included directly but rather
|
|
* through netsurf.h or gui_internal.h
|
|
*/
|
|
|
|
#ifndef _NETSURF_DESKTOP_GUI_TABLE_H_
|
|
#define _NETSURF_DESKTOP_GUI_TABLE_H_
|
|
|
|
struct gui_browser_table;
|
|
struct gui_window_table;
|
|
struct gui_download_table;
|
|
struct gui_clipboard_table;
|
|
struct gui_fetch_table;
|
|
struct gui_file_table;
|
|
struct gui_utf8_table;
|
|
struct gui_search_table;
|
|
struct gui_search_web_table;
|
|
struct gui_llcache_table;
|
|
struct gui_bitmap_table;
|
|
|
|
/**
|
|
* NetSurf operation function table
|
|
*
|
|
* Function table implementing interface operations for the browser core.
|
|
*/
|
|
struct netsurf_table {
|
|
|
|
/**
|
|
* Browser table.
|
|
*
|
|
* Provides miscellaneous browser functionality. The table
|
|
* is mandantory and must be provided.
|
|
*/
|
|
struct gui_browser_table *browser;
|
|
|
|
/**
|
|
* Window table.
|
|
*
|
|
* Provides all operations which affect a frontends display window.
|
|
*/
|
|
struct gui_window_table *window;
|
|
|
|
/**
|
|
* Download table.
|
|
*
|
|
* operations table for the download windows.
|
|
*/
|
|
struct gui_download_table *download;
|
|
|
|
/**
|
|
* Clipboard table.
|
|
*/
|
|
struct gui_clipboard_table *clipboard;
|
|
|
|
/**
|
|
* Fetcher table
|
|
*/
|
|
struct gui_fetch_table *fetch;
|
|
|
|
/**
|
|
* File table
|
|
*
|
|
* Provides file and filename operations to the core. The
|
|
* table is optional and may be NULL in which case the default
|
|
* posix compliant operations will be used.
|
|
*/
|
|
struct gui_file_table *file;
|
|
|
|
/**
|
|
* UTF8 table.
|
|
*
|
|
* Provides for conversion between the gui local character
|
|
* encoding and utf8. The table optional and may be NULL which
|
|
* implies the local encoding is utf8.
|
|
*/
|
|
struct gui_utf8_table *utf8;
|
|
|
|
/**
|
|
* Page search table.
|
|
*
|
|
* Provides routines for the interactive text search on a page.
|
|
*/
|
|
struct gui_search_table *search;
|
|
|
|
/**
|
|
* Web search table.
|
|
*
|
|
* Used by the web search provider system. The table is
|
|
* optional and may be NULL which uses the default empty
|
|
* implementation.
|
|
*/
|
|
struct gui_search_web_table *search_web;
|
|
|
|
/**
|
|
* Low level cache table.
|
|
*
|
|
* Used by the low level cache to push objects to persistant
|
|
* storage. The table is optional and may be NULL which
|
|
* uses the default implementation.
|
|
*/
|
|
struct gui_llcache_table *llcache;
|
|
|
|
/**
|
|
* Bitmap table.
|
|
*
|
|
* Used by the image convertors as a generic interface to
|
|
* native platform-specific image formats. The table
|
|
* is mandantory and must be provided.
|
|
*/
|
|
struct gui_bitmap_table *bitmap;
|
|
};
|
|
|
|
#endif
|