/* -*-mode:c++; c-file-style: "gnu";-*- */ /* * $Id: HTMLAtomicElement.h,v 1.7 2007/07/02 18:48:18 sebdiaz Exp $ * * Copyright (C) 1996 - 2004 Stephen F. Booth * 2007 Sebastien DIAZ * Part of the GNU cgicc library, http://www.gnu.org/software/cgicc * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA */ #ifndef _HTMLATOMICELEMENT_H_ #define _HTMLATOMICELEMENT_H_ 1 /*! \file HTMLAtomicElement.h * \brief Template class for concrete atomic HTMLElement subclasses * */ #include #include "cgicc/HTMLElement.h" namespace cgicc { // ============================================================ // Template for concrete atomic HTML element classes // ============================================================ /*! \class HTMLAtomicElement HTMLAtomicElement.h cgicc/HTMLAtomicElement.h * \brief Template for concrete atomic HTMLElement subclasses * * An atomic HTML element is an element in which the opening and closing * tags are combined. For example, in the HTML code \verbatim \endverbatim * The \c meta tag is an atomic HTML element because the opening and closing * tags appear together. * \sa HTMLElement * \sa HTMLBooleanElement */ template class HTMLAtomicElement : public HTMLElement { public: // ============================================================ /*! \name Constructors and Destructor */ //@{ /*! * \brief Create a new empty atomic element. * */ HTMLAtomicElement() : HTMLElement(0, 0, 0, eAtomic) {} /*! * \brief Create a new element, specifying the HTMLAttributes. * * \param attributes The HTMLAttributes contained within the element. */ HTMLAtomicElement(const HTMLAttributeList& attributes) : HTMLElement(&attributes, 0, 0, eAtomic) {} /*! * \brief Destructor * */ virtual ~HTMLAtomicElement() {} //@} /*! * \brief Clone this element * * \return A newly-allocated copy of this element */ virtual inline HTMLElement* clone() const { return new HTMLAtomicElement(*this); } /*! * \brief Get the name of this element. * * For example, \c meta. * \return The name of this element */ virtual inline const char* getName() const { return Tag::getName(); } }; } // namespace cgicc #endif /* ! _HTMLATOMICELEMENT_H_ */