2005-04-15 09:51:32 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2005 Adrian Lees <adrianl@users.sourceforge.net>
|
2007-08-08 20:16:03 +04:00
|
|
|
*
|
|
|
|
* 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/>.
|
2005-04-15 09:51:32 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
/** \file
|
2008-04-13 22:21:22 +04:00
|
|
|
* Text selection within browser windows (interface).
|
2005-04-15 09:51:32 +04:00
|
|
|
*/
|
|
|
|
|
2020-05-24 00:59:40 +03:00
|
|
|
#ifndef NETSURF_DESKTOP_SELECTION_H_
|
|
|
|
#define NETSURF_DESKTOP_SELECTION_H_
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2012-08-22 15:22:58 +04:00
|
|
|
#include <stdbool.h>
|
2016-05-30 14:07:16 +03:00
|
|
|
#include "netsurf/mouse.h"
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2012-03-24 21:42:29 +04:00
|
|
|
struct box;
|
2020-05-21 01:17:48 +03:00
|
|
|
struct browser_window;
|
2020-05-23 22:38:41 +03:00
|
|
|
struct plot_font_style;
|
|
|
|
struct selection_string;
|
2020-05-24 01:33:52 +03:00
|
|
|
struct selection;
|
|
|
|
struct content;
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2020-05-24 00:59:40 +03:00
|
|
|
/**
|
|
|
|
* determine if a selecion is active
|
|
|
|
*/
|
|
|
|
bool selection_active(struct selection *s);
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2020-05-24 00:59:40 +03:00
|
|
|
bool selection_dragging(struct selection *s);
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2020-05-24 00:59:40 +03:00
|
|
|
bool selection_dragging_start(struct selection *s);
|
2005-07-24 22:35:57 +04:00
|
|
|
|
2020-05-24 00:59:40 +03:00
|
|
|
/**
|
|
|
|
* Handles completion of a drag operation
|
|
|
|
*/
|
|
|
|
void selection_drag_end(struct selection *s);
|
2020-05-21 00:15:33 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a new selection object associated with a browser window.
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers
|
|
|
|
*
|
|
|
|
* \return new selection context
|
|
|
|
*/
|
2020-05-24 00:09:40 +03:00
|
|
|
struct selection *selection_create(struct content *c);
|
2020-05-21 00:15:33 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Destroys a selection object clearing it if nesessary
|
|
|
|
*
|
|
|
|
* Used from content textsearch
|
|
|
|
*
|
|
|
|
* \param s selection object
|
|
|
|
*/
|
|
|
|
void selection_destroy(struct selection *s);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialise the selection object to use the given box subtree as its root,
|
|
|
|
* ie. selections are confined to that subtree.
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers
|
|
|
|
*
|
|
|
|
* \param s selection object
|
|
|
|
*/
|
2020-05-24 00:00:00 +03:00
|
|
|
void selection_init(struct selection *s);
|
2020-05-21 00:15:33 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialise the selection object to use the given box subtree as its root,
|
|
|
|
* ie. selections are confined to that subtree, whilst maintaining the current
|
|
|
|
* selection whenever possible because, for example, it's just the page being
|
|
|
|
* resized causing the layout to change.
|
|
|
|
*
|
|
|
|
* Used from html content handler
|
|
|
|
*
|
|
|
|
* \param s selection object
|
|
|
|
*/
|
2020-05-24 00:00:00 +03:00
|
|
|
void selection_reinit(struct selection *s);
|
2020-05-21 00:15:33 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Clears the current selection, optionally causing the screen to be updated.
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers
|
|
|
|
*
|
|
|
|
* \param s selection object
|
|
|
|
* \param redraw true iff the previously selected region of the browser
|
|
|
|
* window should be redrawn
|
2020-05-24 00:59:40 +03:00
|
|
|
* \return true if selection was cleared false if not
|
2020-05-21 00:15:33 +03:00
|
|
|
*/
|
2020-05-24 00:59:40 +03:00
|
|
|
bool selection_clear(struct selection *s, bool redraw);
|
2020-05-21 00:15:33 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Selects all the text within the box subtree controlled by
|
|
|
|
* this selection object, updating the screen accordingly.
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers
|
|
|
|
*
|
|
|
|
* \param s selection object
|
|
|
|
*/
|
2005-04-15 09:51:32 +04:00
|
|
|
void selection_select_all(struct selection *s);
|
2005-07-21 03:27:28 +04:00
|
|
|
|
2020-05-21 00:15:33 +03:00
|
|
|
/**
|
|
|
|
* Set the position of the current selection, updating the screen.
|
|
|
|
*
|
|
|
|
* Used from content textsearch
|
|
|
|
*
|
|
|
|
* \param s selection object
|
|
|
|
* \param start byte offset within textual representation
|
|
|
|
* \param end byte offset within textual representation
|
|
|
|
*/
|
|
|
|
void selection_set_position(struct selection *s, unsigned start, unsigned end);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handles mouse clicks (including drag starts) in or near a selection
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers
|
|
|
|
*
|
|
|
|
* \param s selection object
|
|
|
|
* \param mouse state of mouse buttons and modifier keys
|
|
|
|
* \param idx byte offset within textual representation
|
|
|
|
* \return true iff the click has been handled by the selection code
|
|
|
|
*/
|
2020-05-21 01:17:48 +03:00
|
|
|
bool selection_click(struct selection *s, struct browser_window *top, browser_mouse_state mouse, unsigned idx);
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2020-05-21 00:15:33 +03:00
|
|
|
/**
|
|
|
|
* Handles movements related to the selection, eg. dragging of start and
|
|
|
|
* end points.
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers
|
|
|
|
*
|
|
|
|
* \param s selection object
|
|
|
|
* \param mouse state of mouse buttons and modifier keys
|
|
|
|
* \param idx byte offset within text representation
|
|
|
|
*/
|
|
|
|
void selection_track(struct selection *s, browser_mouse_state mouse, unsigned idx);
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2020-05-21 00:15:33 +03:00
|
|
|
/**
|
|
|
|
* Copy the selected contents to the clipboard
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers
|
|
|
|
*
|
|
|
|
* \param s selection
|
|
|
|
* \return true iff successful
|
|
|
|
*/
|
2012-08-02 17:23:42 +04:00
|
|
|
bool selection_copy_to_clipboard(struct selection *s);
|
|
|
|
|
2020-05-21 00:15:33 +03:00
|
|
|
/**
|
|
|
|
* Get copy of selection as string
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers
|
|
|
|
*
|
|
|
|
* \param s selection
|
|
|
|
* \return string of selected text, or NULL. Ownership passed to caller.
|
|
|
|
*/
|
|
|
|
char *selection_get_copy(struct selection *s);
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2020-05-21 00:15:33 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests whether a text range lies partially within the selection, if there is
|
|
|
|
* a selection defined, returning the start and end indexes of the bytes
|
|
|
|
* that should be selected.
|
|
|
|
*
|
|
|
|
* Used from text and html content handlers, content textsearch
|
|
|
|
*
|
|
|
|
* \param s the selection object
|
|
|
|
* \param start byte offset of start of text
|
|
|
|
* \param end byte offset of end of text
|
|
|
|
* \param start_idx receives the start index (in bytes) of the highlighted portion
|
|
|
|
* \param end_idx receives the end index (in bytes)
|
|
|
|
* \return true iff part of the given box lies within the selection
|
|
|
|
*/
|
|
|
|
bool selection_highlighted(const struct selection *s, unsigned start, unsigned end, unsigned *start_idx, unsigned *end_idx);
|
2005-04-15 09:51:32 +04:00
|
|
|
|
2020-05-23 22:38:41 +03:00
|
|
|
bool
|
|
|
|
selection_string_append(const char *text,
|
|
|
|
size_t length,
|
|
|
|
bool space,
|
|
|
|
struct plot_font_style *style,
|
|
|
|
struct selection_string *sel_string);
|
|
|
|
|
2005-04-15 09:51:32 +04:00
|
|
|
#endif
|