⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 htmlparser.h

📁 monqueror一个很具有参考价值的源玛
💻 H
字号:
/*    This file is part of the KDE libraries    Copyright (C) 1997 Martin Jones (mjones@kde.org)              (C) 1997 Torben Weis (weis@kde.org)              (C) 1998 Waldo Bastian (bastian@kde.org)              (C) 1999 Lars Knoll (knoll@kde.org)    This library is free software; you can redistribute it and/or    modify it under the terms of the GNU Library General Public    License as published by the Free Software Foundation; either    version 2 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    Library General Public License for more details.    You should have received a copy of the GNU Library General Public License    along with this library; see the file COPYING.LIB.  If not, write to    the Free Software Foundation, Inc., 59 Temple Place - Suite 330,    Boston, MA 02111-1307, USA.*///----------------------------------------------------------------------------//// KDE HTML Widget -- HTML Parser// $Id: htmlparser.h,v 1.1.1.1 2002/01/16 10:39:56 ymwei Exp $#ifndef HTMLPARSER_H#define HTMLPARSER_H#include "dom_string.h"class MGHTMLView;class HTMLStackElem;namespace DOM {    class HTMLDocumentImpl;    class HTMLElementImpl;    class NodeImpl;    class HTMLFormElementImpl;    class HTMLMapElementImpl;    class HTMLHeadElementImpl;}namespace khtml {    class Token;};class KHTMLParser;/** * The parser for html. It receives a stream of tokens from the HTMLTokenizer, and * builds up the Document structure form it. */class KHTMLParser{public:    KHTMLParser( MGHTMLView *w, DOM::HTMLDocumentImpl *i );    virtual ~KHTMLParser();    /**     * parses one token delivered by the tokenizer     */    void parseToken(khtml::Token *_t);    /**     * resets the parser     */    void reset();    bool parsingBody() { return inBody; }    DOM::HTMLDocumentImpl *doc() { return document; }protected:    MGHTMLView *HTMLWidget;    DOM::HTMLDocumentImpl *document;    /*     * generate an element from the token     */    DOM::NodeImpl *getElement(khtml::Token *);    void processCloseTag(khtml::Token *);    void insertNode(DOM::NodeImpl *n);    /*     * The currently active element (the one new elements will be added to)     */    DOM::NodeImpl *current;    HTMLStackElem *blockStack;    void pushBlock( int _id, int _level);    void popBlock( int _id );    void popOneBlock();    void popInlineBlocks();    void freeBlock( void);    void createHead();    ushort *forbiddenTag;    /*     * currently active form     */    DOM::HTMLFormElementImpl *form;    /*     * current map     */    DOM::HTMLMapElementImpl *map;    /*     * the head element. Needed for crappy html which defines <base> after </head>     */    DOM::HTMLHeadElementImpl *head;    bool inBody;    bool haveFrameSet;    bool _inline;    bool end;    /*     * tells the parser to discard all tags, until it reaches the one specified     */    int discard_until;    bool headLoaded;};#endif // HTMLPARSER_H

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -