1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxHtmlTag class (represents single tag) 
   4 // Author:      Vaclav Slavik 
   6 // Copyright:   (c) 1999 Vaclav Slavik 
   7 // Licence:     wxWindows Licence 
   8 ///////////////////////////////////////////////////////////////////////////// 
  11 #ifndef _WX_HTMLTAG_H_ 
  12 #define _WX_HTMLTAG_H_ 
  15 #pragma interface "htmltag.h" 
  22 #include "wx/object.h" 
  24 class WXDLLEXPORT wxColour
; 
  25 class WXDLLEXPORT wxHtmlEntitiesParser
; 
  27 //----------------------------------------------------------------------------- 
  29 //          - internal wxHTML class, do not use! 
  30 //----------------------------------------------------------------------------- 
  32 struct wxHtmlCacheItem
; 
  34 class WXDLLEXPORT wxHtmlTagsCache 
: public wxObject
 
  36     DECLARE_DYNAMIC_CLASS(wxHtmlTagsCache
) 
  39     wxHtmlCacheItem 
*m_Cache
; 
  44     wxHtmlTagsCache() : wxObject() {m_CacheSize 
= 0; m_Cache 
= NULL
;} 
  45     wxHtmlTagsCache(const wxString
& source
); 
  46     ~wxHtmlTagsCache() {free(m_Cache
);} 
  48     // Finds parameters for tag starting at at and fills the variables 
  49     void QueryTag(int at
, int* end1
, int* end2
); 
  53 //-------------------------------------------------------------------------------- 
  55 //                  This represents single tag. It is used as internal structure 
  57 //-------------------------------------------------------------------------------- 
  59 class WXDLLEXPORT wxHtmlTag 
: public wxObject
 
  61     DECLARE_CLASS(wxHtmlTag
) 
  64     // constructs wxHtmlTag object based on HTML tag. 
  65     // The tag begins (with '<' character) at position pos in source 
  66     // end_pos is position where parsing ends (usually end of document) 
  67     wxHtmlTag(wxHtmlTag 
*parent
, 
  68               const wxString
& source
, int pos
, int end_pos
, 
  69               wxHtmlTagsCache 
*cache
, 
  70               wxHtmlEntitiesParser 
*entParser
); 
  71     friend class wxHtmlParser
; 
  75     wxHtmlTag 
*GetParent() const {return m_Parent
;} 
  76     wxHtmlTag 
*GetFirstSibling() const; 
  77     wxHtmlTag 
*GetLastSibling() const; 
  78     wxHtmlTag 
*GetChildren() const { return m_FirstChild
; } 
  79     wxHtmlTag 
*GetPreviousSibling() const { return m_Prev
; } 
  80     wxHtmlTag 
*GetNextSibling() const {return m_Next
; } 
  81     // Return next tag, as if tree had been flattened 
  82     wxHtmlTag 
*GetNextTag() const; 
  84     // Returns tag's name in uppercase. 
  85     inline wxString 
GetName() const {return m_Name
;} 
  87     // Returns TRUE if the tag has given parameter. Parameter 
  88     // should always be in uppercase. 
  89     // Example : <IMG SRC="test.jpg"> HasParam("SRC") returns TRUE 
  90     bool HasParam(const wxString
& par
) const; 
  92     // Returns value of the param. Value is in uppercase unless it is 
  94     // Example : <P align=right> GetParam("ALIGN") returns (RIGHT) 
  95     //           <P IMG SRC="WhaT.jpg"> GetParam("SRC") returns (WhaT.jpg) 
  96     //                           (or ("WhaT.jpg") if with_commas == TRUE) 
  97     wxString 
GetParam(const wxString
& par
, bool with_commas 
= FALSE
) const; 
  99     // Convenience functions: 
 100     bool GetParamAsColour(const wxString
& par
, wxColour 
*clr
) const; 
 101     bool GetParamAsInt(const wxString
& par
, int *clr
) const; 
 103     // Scans param like scanf() functions family does. 
 104     // Example : ScanParam("COLOR", "\"#%X\"", &clr); 
 105     // This is always with with_commas=FALSE 
 106     // Returns number of scanned values 
 107     // (like sscanf() does) 
 108     // NOTE: unlike scanf family, this function only accepts 
 110     int ScanParam(const wxString
& par
, const wxChar 
*format
, void *param
) const; 
 112     // Returns string containing all params. 
 113     wxString 
GetAllParams() const; 
 115 #if WXWIN_COMPATIBILITY_2_2 
 116     // return TRUE if this is ending tag (</something>) or FALSE 
 117     // if it isn't (<something>) 
 118     inline bool IsEnding() const {return FALSE
;} 
 121     // return TRUE if this there is matching ending tag 
 122     inline bool HasEnding() const {return m_End1 
>= 0;} 
 124     // returns beginning position of _internal_ block of text 
 125     // See explanation (returned value is marked with *): 
 126     // bla bla bla <MYTAG>* bla bla intenal text</MYTAG> bla bla 
 127     inline int GetBeginPos() const {return m_Begin
;} 
 128     // returns ending position of _internal_ block of text. 
 129     // bla bla bla <MYTAG> bla bla intenal text*</MYTAG> bla bla 
 130     inline int GetEndPos1() const {return m_End1
;} 
 131     // returns end position 2 : 
 132     // bla bla bla <MYTAG> bla bla internal text</MYTAG>* bla bla 
 133     inline int GetEndPos2() const {return m_End2
;} 
 137     int m_Begin
, m_End1
, m_End2
; 
 138     wxArrayString m_ParamNames
, m_ParamValues
; 
 140     // DOM tree relations: 
 143     wxHtmlTag 
*m_FirstChild
, *m_LastChild
; 
 153 #endif // _WX_HTMLTAG_H_