// -*- C++ -*- /*************************************************************************** * Copyright (C) 2005 by Stefan Kebekus * * kebekus@kde.org * * * * This program 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; either version 2 of the License, or * * (at your option) any later version. * * * * This program 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, write to the * * Free Software Foundation, Inc., * * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #ifndef _bookmarks_h_ #define _bookmarks_h_ #include "anchor.h" #include <tqptrlist.h> #include <tqstring.h> /** \brief Bookmark This class represents a bookmark. It contains the bookmark text, an anchor that represents the target of the bookmark, and a list of subordinate bookmarks. @warning The list of subordinate bookmarks owns its entries, i.e. autoDelete() is set to true. Thus, extra care must be taken when copying bookmarks. Otherwise, a segfault could result. */ class Bookmark { public: /** Default constructor. Constructs an invalid bookmark with an empty bookMarkText and an invalid position */ Bookmark() {subordinateBookmarks.setAutoDelete(true);} /** Constructs a bookmark with given a text and anchor @param text name of the bookmark, as it appears in the GUI @param pos an Anchor that specifies the position of the bookmark */ Bookmark(const TQString &text, const Anchor &pos) { Bookmark(); bookmarkText = text; position = pos; } /** Convenience funtion, behaves as Bookmark(const TQString &text, const Anchor &pos) @param text name of the bookmark, as it appears in the GUI @param page number of the where the bookmark lives. Recall the convention that '0' is an invalid page, the first page is '1' @param distance_from_top position on the page, distance from top of the page */ Bookmark(const TQString& text, const PageNumber& page, const Length& distance_from_top) { Bookmark(); bookmarkText = text; position.page = page; position.distance_from_top = distance_from_top; } /** Label of the bookmark as it will appear in the GUI to the user, such as "Section 1", "Theorem 12", etc. */ TQString bookmarkText; /** The anchor that specifies the position of the bookmark */ Anchor position; /** List of subordinate bookmarks Bookmarks generally come in trees, and some bookmarks can have subordinate bookmarks. For instance, the bookmark that respresents a chapter heading would have headings of subsections as subordinate bookmarks. These are contained in this list. @warning This list owns its entries, e.g. autoDelete() is set to true. Thus, extra care must be taken when copying this list. Otherwise, a segfault could result. */ TQPtrList<Bookmark> subordinateBookmarks; // Returns true if the bookmark is valid, false otherwise. A // bookmark is valid if the text is not empty and the anchor is // valid. bool isValid() const {return (!bookmarkText.isEmpty()) && position.isValid();} }; #endif