/* * Copyright 2012 Michael Drake * * 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 . */ /** * \file * Interface to core window handling. * * This provides a generalised API for frontends to implement which * allows them to provide a single implementation for general window * operations on their platform. * * General core implementations (cookie manager, global history, * hotlist and ssl certificate viewer) use this API to perform * operations like drawing and user input in a portable way. */ #ifndef _NETSURF_CORE_WINDOW_H_ #define _NETSURF_CORE_WINDOW_H_ struct core_window; struct rect; /** * drag status passed to drag_status callback */ typedef enum { CORE_WINDOW_DRAG_NONE, CORE_WINDOW_DRAG_SELECTION, CORE_WINDOW_DRAG_TEXT_SELECTION, CORE_WINDOW_DRAG_MOVE } core_window_drag_status; /** * Callbacks to achieve various core window functionality. */ struct core_window_callback_table { /** * Invalidate an area of a window. * * The specified area of the window should now be considered * out of date. If the area is NULL the entire window must be * invalidated. It is expected that the windowing system will * then subsequently cause redraw/expose operations as * necessary. * * \note the frontend should not attempt to actually start the * redraw operations as a result of this callback because the * core redraw functions may already be threaded. * * \param[in] cw The core window to invalidate. * \param[in] rect area to redraw or NULL for the entire window area * \return NSERROR_OK on success or appropriate error code */ nserror (*invalidate)(struct core_window *cw, const struct rect *rect); /** * Update the limits of the window * * \param[in] cw the core window object * \param[in] width the width in px, or negative if don't care * \param[in] height the height in px, or negative if don't care */ void (*update_size)(struct core_window *cw, int width, int height); /** * Scroll the window to make area visible * * \param[in] cw the core window object * \param[in] r rectangle to make visible */ void (*scroll_visible)(struct core_window *cw, const struct rect *r); /** * Get window viewport dimensions * * \param[in] cw the core window object * \param[out] width to be set to viewport width in px * \param[out] height to be set to viewport height in px */ void (*get_window_dimensions)(struct core_window *cw, int *width, int *height); /** * Inform corewindow owner of drag status * * \param[in] cw the core window object * \param[in] ds the current drag status */ void (*drag_status)(struct core_window *cw, core_window_drag_status ds); }; #endif