2014-02-15 22:43:59 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2006 James Bursa <bursa@users.sourceforge.net>
|
|
|
|
*
|
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
/**
|
|
|
|
* \file
|
|
|
|
* Interface to browser history operations
|
|
|
|
*
|
|
|
|
* The are operations on a browsing contexts history. These interfaces
|
|
|
|
* allow navigation forward and backwards in the history as well as
|
|
|
|
* enumerating the entries.
|
|
|
|
*
|
|
|
|
* The local history viewing is distinct via corewindow defined in
|
|
|
|
* desktop/local_history.h
|
2014-02-15 22:43:59 +04:00
|
|
|
*/
|
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
#ifndef NETSURF_DESKTOP_BROWSER_HISTORY_H
|
|
|
|
#define NETSURF_DESKTOP_BROWSER_HISTORY_H
|
2014-02-15 22:43:59 +04:00
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
|
|
#include "utils/errors.h"
|
|
|
|
|
|
|
|
struct browser_window;
|
|
|
|
struct history_entry;
|
2017-09-11 18:44:46 +03:00
|
|
|
struct bitmap;
|
2014-10-31 01:19:42 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Go back in the history.
|
|
|
|
*
|
|
|
|
* \param bw A browser window to navigate the history in.
|
|
|
|
* \param new_window whether to open in new window.
|
|
|
|
* \return NSERROR_OK or error code on faliure.
|
|
|
|
*/
|
|
|
|
nserror browser_window_history_back(struct browser_window *bw, bool new_window);
|
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-10-31 01:19:42 +03:00
|
|
|
/**
|
|
|
|
* Go forward in the history.
|
|
|
|
*
|
|
|
|
* \param bw A browser window to navigate the history in.
|
|
|
|
* \param new_window whether to open in new window.
|
|
|
|
* \return NSERROR_OK or error code on faliure.
|
|
|
|
*/
|
|
|
|
nserror browser_window_history_forward(struct browser_window *bw, bool new_window);
|
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-10-31 01:19:42 +03:00
|
|
|
/**
|
|
|
|
* Check whether it is pssible to go back in the history.
|
|
|
|
*
|
|
|
|
* \param bw A browser window to check the history navigation in.
|
|
|
|
* \return true if the history can go back, false otherwise
|
|
|
|
*/
|
2014-02-15 22:43:59 +04:00
|
|
|
bool browser_window_history_back_available(struct browser_window *bw);
|
2014-10-31 01:19:42 +03:00
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-10-31 01:19:42 +03:00
|
|
|
/**
|
|
|
|
* Check whether it is pssible to go forwards in the history.
|
|
|
|
*
|
|
|
|
* \param bw A browser window to check the history navigation in.
|
|
|
|
* \return true if the history can go forwards, false otherwise
|
|
|
|
*/
|
2014-02-15 22:43:59 +04:00
|
|
|
bool browser_window_history_forward_available(struct browser_window *bw);
|
2014-10-31 01:19:42 +03:00
|
|
|
|
2017-09-10 18:05:41 +03:00
|
|
|
/**
|
|
|
|
* Get the thumbnail bitmap for the current history entry
|
|
|
|
*
|
|
|
|
* \param bw The browser window
|
|
|
|
* \param bitmap The bitmat for the current history entry.
|
|
|
|
* \return NSERROR_OK or error code on faliure.
|
|
|
|
*/
|
|
|
|
nserror browser_window_history_get_thumbnail(struct browser_window *bw, struct bitmap **bitmap_out);
|
2014-02-15 22:43:59 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Callback function type for history enumeration
|
|
|
|
*
|
|
|
|
* \param bw The browser window with history being enumerated
|
|
|
|
* \param x0, y0, x1, y1 Coordinates of entry in history tree view
|
|
|
|
* \param entry Current history entry
|
|
|
|
* \return true to continue enumeration, false to cancel enumeration
|
|
|
|
*/
|
|
|
|
typedef bool (*browser_window_history_enumerate_cb)(
|
|
|
|
const struct browser_window *bw,
|
|
|
|
int x0, int y0, int x1, int y1,
|
|
|
|
const struct history_entry *entry, void *user_data);
|
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-02-15 22:43:59 +04:00
|
|
|
/**
|
|
|
|
* Enumerate all entries in the history.
|
|
|
|
* Do not change the history while it is being enumerated.
|
|
|
|
*
|
|
|
|
* \param bw The browser window to enumerate history of
|
|
|
|
* \param cb callback function
|
|
|
|
* \param user_data context pointer passed to cb
|
|
|
|
*/
|
|
|
|
void browser_window_history_enumerate(const struct browser_window *bw,
|
|
|
|
browser_window_history_enumerate_cb cb, void *user_data);
|
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-02-15 22:43:59 +04:00
|
|
|
/**
|
|
|
|
* Enumerate all entries that will be reached by the 'forward' button
|
|
|
|
*
|
|
|
|
* \param bw The browser window to enumerate history of
|
|
|
|
* \param cb The callback function
|
|
|
|
* \param user_data Data passed to the callback
|
|
|
|
*/
|
|
|
|
void browser_window_history_enumerate_forward(const struct browser_window *bw,
|
|
|
|
browser_window_history_enumerate_cb cb, void *user_data);
|
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-02-15 22:43:59 +04:00
|
|
|
/**
|
|
|
|
* Enumerate all entries that will be reached by the 'back' button
|
|
|
|
*
|
|
|
|
* \param bw The browser window to enumerate history of
|
|
|
|
* \param cb The callback function
|
|
|
|
* \param user_data Data passed to the callback
|
|
|
|
*/
|
|
|
|
void browser_window_history_enumerate_back(const struct browser_window *bw,
|
|
|
|
browser_window_history_enumerate_cb cb, void *user_data);
|
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-02-15 22:43:59 +04:00
|
|
|
/**
|
|
|
|
* Returns the URL to a history entry
|
|
|
|
*
|
2017-06-10 20:34:05 +03:00
|
|
|
* \param entry the history entry to retrieve the URL from
|
|
|
|
* \return A referenced nsurl URL
|
2014-02-15 22:43:59 +04:00
|
|
|
*/
|
2017-06-10 20:34:05 +03:00
|
|
|
struct nsurl *browser_window_history_entry_get_url(const struct history_entry *entry);
|
|
|
|
|
2014-02-15 22:43:59 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the URL to a history entry
|
|
|
|
*
|
2017-09-10 18:05:41 +03:00
|
|
|
* \param entry the history entry to retrieve the fragment id from
|
|
|
|
* \return the fragment id
|
2014-02-15 22:43:59 +04:00
|
|
|
*/
|
2017-09-10 18:05:41 +03:00
|
|
|
const char *browser_window_history_entry_get_fragment_id(const struct history_entry *entry);
|
2014-02-15 22:43:59 +04:00
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-02-15 22:43:59 +04:00
|
|
|
/**
|
|
|
|
* Returns the title of a history entry
|
|
|
|
*
|
2017-09-10 18:05:41 +03:00
|
|
|
* \param entry The history entry to retrieve the title from
|
|
|
|
* \return the title
|
2014-02-15 22:43:59 +04:00
|
|
|
*/
|
2017-09-10 18:05:41 +03:00
|
|
|
const char *browser_window_history_entry_get_title(const struct history_entry *entry);
|
2014-02-15 22:43:59 +04:00
|
|
|
|
2017-06-10 20:34:05 +03:00
|
|
|
|
2014-02-15 22:43:59 +04:00
|
|
|
/**
|
|
|
|
* Navigate to specified history entry, optionally in new window
|
|
|
|
*
|
|
|
|
* \param bw browser window
|
|
|
|
* \param entry entry to open
|
|
|
|
* \param new_window open entry in new window
|
2014-10-31 01:19:42 +03:00
|
|
|
* \return NSERROR_OK or error code on faliure.
|
2014-02-15 22:43:59 +04:00
|
|
|
*/
|
2017-09-10 18:05:41 +03:00
|
|
|
nserror browser_window_history_go(struct browser_window *bw, struct history_entry *entry, bool new_window);
|
2014-02-15 22:43:59 +04:00
|
|
|
|
|
|
|
#endif
|