亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? xbl_tokenizer.cpp

?? It is WEB browser core module with source code. Very good!
?? CPP
字號:
#ifndef KHTML_NO_XBL

#include "dom/dom_node.h"
#include "xml/dom_elementimpl.h"
#include "misc/htmlattrs.h"

#include "xbl_tokenizer.h"
#include "xbl_docimpl.h"
#include "xbl_protobinding.h"
#include "xbl_protohandler.h"
#include "xbl_protoimplementation.h"

using DOM::DocumentPtr;
using DOM::ElementImpl;
using DOM::Node;

namespace XBL {

const char xblNS[] = "http://www.mozilla.org/xbl";
    
XBLTokenHandler::XBLTokenHandler(DocumentPtr* doc)
:   XMLHandler(doc, 0),
    m_state(eXBL_InDocument),
    m_secondaryState(eXBL_None),
    m_binding(0),
    m_handler(0),
    m_implementation(0),
    m_member(0),
    m_property(0),
    m_method(0),
    m_field(0)
{
}

XBLTokenHandler::~XBLTokenHandler()
{
}

XBLDocumentImpl* XBLTokenHandler::xblDocument() const
{
    return static_cast<XBLDocumentImpl*>(m_doc->document());
}

bool XBLTokenHandler::startElement(const QString& namespaceURI, const QString& localName, const QString& qName, 
                                   const QXmlAttributes& attrs)
{
    if (namespaceURI == xblNS) {
        if (localName == "binding")
            m_state = eXBL_InBinding;
        else if (localName == "content")
            m_state = eXBL_InContent;
        else if (localName == "handlers") {
            m_state = eXBL_InHandlers;
            return true;
        }
        else if (localName == "handler") {
            m_secondaryState = eXBL_InHandler;
            createHandler(attrs);
            return true;
        }
        else if (localName == "resources") {
            m_state = eXBL_InResources;
            return true;
        }
        else if (m_state == eXBL_InResources) {
            if (localName == "stylesheet" || localName == "image")
                createResource(localName, attrs);
            return true;
        }
        else if (localName == "implementation") {
            m_state = eXBL_InImplementation;
            createImplementation(attrs);
            return true;
        }
        else if (m_state == eXBL_InImplementation) {
            if (localName == "constructor") {
                m_secondaryState = eXBL_InConstructor;
                createConstructor();
            }
            else if (localName == "destructor") {
                m_secondaryState = eXBL_InDestructor;
                createDestructor();
            }
            else if (localName == "field") {
                m_secondaryState = eXBL_InField;
                createField(attrs);
            }
            else if (localName == "property") {
                m_secondaryState = eXBL_InProperty;
                createProperty(attrs);
            }
            else if (localName == "getter")
                m_secondaryState = eXBL_InGetter;
            else if (localName == "setter")
                m_secondaryState = eXBL_InSetter;
            else if (localName == "method") {
                m_secondaryState = eXBL_InMethod;
                createMethod(attrs);
            }
            else if (localName == "parameter")
                createParameter(attrs);
            else if (localName == "body")
                m_secondaryState = eXBL_InBody;
            
            return true; // Ignore everything we encounter inside an <implementation> block.
        }        
    }
    
    if (!XMLHandler::startElement(namespaceURI, localName, qName, attrs))
        return false;
    
    // Create our binding if it doesn't exist already.
    if (m_state == eXBL_InBinding && !m_binding)
        createBinding();
    
    return true;
}

bool XBLTokenHandler::endElement(const QString& namespaceURI, const QString& localName, const QString& qName)
{
    if (m_state != eXBL_InDocument) {
        if (namespaceURI == xblNS) {
            if (m_state == eXBL_InContent && localName == "content")
                m_state = eXBL_InBinding;
            else if (m_state == eXBL_InHandlers) {
                if (localName == "handlers") {
                    m_state = eXBL_InBinding;
                    m_handler = 0;
                }
                else if (localName == "handler")
                    m_secondaryState = eXBL_None;
                return true;
            }
            else if (m_state == eXBL_InResources) {
                if (localName == "resources")
                    m_state = eXBL_InBinding;
                return true;
            }
            else if (m_state == eXBL_InImplementation) {
                if (localName == "implementation")
                    m_state = eXBL_InBinding;
                else if (localName == "property") {
                    m_secondaryState = eXBL_None;
                    m_property = 0;
                }
                else if (localName == "method") {
                    m_secondaryState = eXBL_None;
                    m_method = 0;
                }
                else if (localName == "field") {
                    m_secondaryState = eXBL_None;
                    m_field = 0;
                }
                else if (localName == "constructor" ||
                         localName == "destructor")
                    m_secondaryState = eXBL_None;
                else if (localName == "getter" ||
                         localName == "setter")
                    m_secondaryState = eXBL_InProperty;
                else if (localName == "parameter" ||
                         localName == "body")
                    m_secondaryState = eXBL_InMethod;
                return true;
            }
            
            if (!XMLHandler::endElement(namespaceURI, localName, qName))
                return false;
            
            if (m_state == eXBL_InImplementation && localName == "implementation")
                m_state = eXBL_InBinding;
            else if (m_state == eXBL_InBinding && localName == "binding") {
                m_state = eXBL_InDocument;
                m_binding->initialize();
                m_binding = 0;
            }
            return true;
        }
    }
    
    return XMLHandler::endElement(namespaceURI, localName, qName);
}

bool XBLTokenHandler::characters(const QString& text)
{
    if (text.length() == 0)
        return true;
    
    if (m_state == eXBL_InHandlers) {
        // Get the text and add it to the event handler.
        if (m_secondaryState == eXBL_InHandler)
            m_handler->appendData(text);
        return true;
    }
    else if (m_state == eXBL_InImplementation) {
        if (m_secondaryState == eXBL_InConstructor || m_secondaryState == eXBL_InDestructor || m_secondaryState == eXBL_InBody) {
            if (m_method)
                m_method->appendData(text);
        }
        else if (m_secondaryState == eXBL_InGetter)
            m_property->appendGetterText(text);
        else if (m_secondaryState == eXBL_InSetter)
            m_property->appendSetterText(text);
        else if (m_secondaryState == eXBL_InField)
            m_field->appendData(text);
        return true;
    }

    // XBL files munch all whitespace, except when inside an anonymous content template (<content>).
    if (m_state != eXBL_InContent) {
        uint l = text.length();
        uint i;
        for (i = 0; i < l; i++) {
	    if (!isspace(text[i].unicode()))
	        break;
	}
        if (i == l)
            return true;
    }
    
    return XMLHandler::characters(text);
}

void XBLTokenHandler::createBinding()
{
    if (!m_currentNode || m_currentNode->nodeType() != Node::ELEMENT_NODE)
        return;
    
    ElementImpl* elt = static_cast<ElementImpl*>(m_currentNode);
    DOMString id = elt->getAttribute(ATTR_ID);
    if (!id.isEmpty()) {
        m_binding = new XBLPrototypeBinding(id, elt);
        int exCode;
        elt->removeAttribute(ATTR_ID, exCode);
    }
}

void XBLTokenHandler::createHandler(const QXmlAttributes& attrs)
{
    DOMString event;
    DOMString modifiers;
    DOMString button;
    DOMString clickcount;
    DOMString keycode;
    DOMString charcode;
    DOMString phase;
    DOMString action;
    DOMString preventdefault;
    
    int i;
    for (i = 0; i < attrs.length(); i++) {
        if (attrs.uri(i).length() > 0)
            continue; // Only care about attributes with no namespace.
        
        if (attrs.qName(i) == "event")
            event = attrs.value(i);
        else if (attrs.qName(i) == "modifiers")
            modifiers = attrs.value(i);
        else if (attrs.qName(i) == "button")
            button = attrs.value(i);
        else if (attrs.qName(i) == "clickcount")
            clickcount = attrs.value(i);
        else if (attrs.qName(i) == "keycode")
            keycode = attrs.value(i);
        else if (attrs.qName(i) == "key" || attrs.qName(i) == "charcode")
            charcode = attrs.value(i);
        else if (attrs.qName(i) == "phase")
            phase = attrs.value(i);
        else if (attrs.qName(i) == "action")
            action = attrs.value(i);
        else if (attrs.qName(i) == "preventdefault")
            preventdefault = attrs.value(i);
    }
    
    XBLPrototypeHandler* newHandler = new XBLPrototypeHandler(event, phase, action, keycode, 
                                                              charcode, modifiers, button,
                                                              clickcount, preventdefault, m_binding);
    if (newHandler) {
        // Add this handler to our chain of handlers.
        if (m_handler)
            m_handler->setNext(newHandler); // Already have a chain. Just append to the end.
        else
            m_binding->setHandler(newHandler); // We're the first handler in the chain.
        m_handler = newHandler; // Adjust our m_handler pointer to point to the new last handler in the chain.
    }
}

void XBLTokenHandler::createResource(const QString& localName, const QXmlAttributes& attrs)
{
    if (!m_binding)
        return;
    
    for (int i = 0; i < attrs.length(); i++) {
        if (attrs.uri(i).length() > 0)
            continue;
        
        if (attrs.qName(i) == "src") {
            m_binding->addResource(localName, attrs.value(i));
            break;
        }
    }
}

void XBLTokenHandler::createImplementation(const QXmlAttributes& attrs)
{
    m_implementation = 0;
    m_member = 0;
    
    if (!m_binding)
        return;
    
    DOMString name;    
    for (int i = 0; i < attrs.length(); i++) {
        if (attrs.uri(i).length() > 0)
            continue;
        
        if (attrs.qName(i) == "name")
            name = attrs.value(i);
        else if (attrs.qName(i) == "implements") {
            // FIXME: If we implement any sort of interface language binding, then we can parse the list of
            // implemented interfaces here.
            // m_binding->constructInterfaceTable(attrs.value(i));
        }
    }
    
    m_implementation = new XBLPrototypeImplementation(name, m_binding);
}

void XBLTokenHandler::addMember(XBLPrototypeMember* member)
{
    if (m_member)
        m_member->setNext(member);
    else
        m_implementation->setMember(member);
    m_member = member;
}

void XBLTokenHandler::createConstructor()
{
    m_method = new XBLPrototypeConstructor();
    addMember(m_method);
}

void XBLTokenHandler::createDestructor()
{
    m_method = new XBLPrototypeDestructor();
    addMember(m_method);
}

void XBLTokenHandler::createField(const QXmlAttributes& attrs)
{
    DOMString name;
    bool readonly = false;
    for (int i = 0; i < attrs.length(); i++) {
        if (attrs.uri(i).length() > 0)
            continue;
        if (attrs.qName(i) == "name")
            name = attrs.value(i);
        else if (attrs.qName(i) == "readonly")
            readonly = !(strcasecmp(attrs.value(i), "true"));
    }
    
    m_field = new XBLPrototypeField(name, readonly);
    addMember(m_field);
}

void XBLTokenHandler::createProperty(const QXmlAttributes& attrs)
{
    DOMString name, onget, onset;
    bool readonly = false;
    for (int i = 0; i < attrs.length(); i++) {
        if (attrs.uri(i).length() > 0)
            continue;
        if (attrs.qName(i) == "name")
            name = attrs.value(i);
        else if (attrs.qName(i) == "readonly")
            readonly = !(strcasecmp(attrs.value(i), "true"));
        else if (attrs.qName(i) == "onget")
            onget = attrs.value(i);
        else if (attrs.qName(i) == "onset")
            onset = attrs.value(i);
    }
    
    m_property = new XBLPrototypeProperty(name, readonly, onget, onset);
    addMember(m_property);
}

void XBLTokenHandler::createMethod(const QXmlAttributes& attrs)
{
    DOMString name;
    for (int i = 0; i < attrs.length(); i++) {
        if (attrs.uri(i).length() > 0)
            continue;
        if (attrs.qName(i) == "name")
            name = attrs.value(i);
    }
    
    m_method = new XBLPrototypeMethod(name);
    addMember(m_method);
}

void XBLTokenHandler::createParameter(const QXmlAttributes& attrs)
{
    if (!m_method) return;

    for (int i = 0; i < attrs.length(); i++) {
        if (attrs.uri(i).length() > 0)
            continue;
        
        if (attrs.qName(i) == "name") {
            m_method->addParameter(attrs.value(i));
            break;
        }
    }
}

}

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区2区视频在线观看| 91精品国产欧美一区二区18| 性做久久久久久| 国产精品久久久久久久久动漫 | 中文字幕日韩一区二区| 日韩精品最新网址| 日韩丝袜情趣美女图片| 56国语精品自产拍在线观看| 欧美日精品一区视频| 欧美唯美清纯偷拍| 欧美色窝79yyyycom| 欧美日韩成人一区| 欧美久久一二区| 日韩丝袜情趣美女图片| 精品粉嫩超白一线天av| 久久综合网色—综合色88| 久久色中文字幕| 中文av一区二区| 亚洲欧美日韩电影| 亚洲一区二区视频| 蜜臀精品一区二区三区在线观看| 美女视频网站黄色亚洲| 国产馆精品极品| 色综合久久中文字幕| 欧美亚洲高清一区| 日韩欧美精品三级| 中文幕一区二区三区久久蜜桃| 亚洲欧美一区二区三区孕妇| 香蕉成人啪国产精品视频综合网| 另类综合日韩欧美亚洲| 成人国产精品视频| 欧美日韩情趣电影| 久久精品亚洲精品国产欧美| 亚洲欧洲日韩在线| 日韩国产在线观看一区| 国内精品伊人久久久久av一坑| 成人av网在线| 欧美大片在线观看| 综合av第一页| 久久av资源网| 91国偷自产一区二区三区成为亚洲经典| 欧美日韩专区在线| 欧美激情在线一区二区| 亚洲第一福利视频在线| 国产福利一区二区三区视频| 欧美日韩亚洲综合一区| 国产精品久久久久影院色老大| 亚洲成人免费av| 99久久免费国产| 欧美精品一区二区三| 亚洲成人先锋电影| 波多野结衣中文字幕一区| 日韩小视频在线观看专区| 亚洲激情在线激情| 成人福利视频在线看| 精品久久久久久亚洲综合网 | 首页综合国产亚洲丝袜| 成人免费观看视频| www国产亚洲精品久久麻豆| 一区二区三区国产豹纹内裤在线| 国产伦理精品不卡| 日韩一区二区精品葵司在线| 亚洲成人动漫精品| 在线观看国产一区二区| 亚洲视频图片小说| 成人午夜视频网站| 国产嫩草影院久久久久| 韩国精品主播一区二区在线观看| 欧美精品在线一区二区三区| 亚洲精品视频在线观看网站| 成人av影视在线观看| 国产日韩欧美综合在线| 国产很黄免费观看久久| 久久久综合精品| 国产一区二区三区在线观看免费 | 亚洲激情综合网| 91亚洲大成网污www| 国产精品第五页| 不卡影院免费观看| 亚洲国产精品成人综合| 国产成人亚洲精品狼色在线| 久久麻豆一区二区| 高清不卡一区二区在线| 国产精品你懂的在线| 国产a区久久久| 国产精品女主播av| 色综合久久天天综合网| 亚洲综合色自拍一区| 欧美日韩国产综合一区二区三区| 午夜精品成人在线视频| 日韩午夜激情免费电影| 麻豆精品在线视频| 久久久综合激的五月天| 成人涩涩免费视频| 亚洲精品菠萝久久久久久久| 欧美人狂配大交3d怪物一区| 久久99久久精品欧美| 国产偷国产偷精品高清尤物| jiyouzz国产精品久久| 亚洲线精品一区二区三区| 宅男噜噜噜66一区二区66| 精品一区二区三区视频在线观看| 亚洲国产精品99久久久久久久久 | 亚洲综合一区在线| 欧美精品日日鲁夜夜添| 日韩黄色免费网站| 国产日韩影视精品| 欧美午夜视频网站| 国产精品2024| 一区二区视频在线看| 欧美一区二区三区不卡| 国产精品18久久久| 一区二区三区高清在线| 日韩一本二本av| 色综合 综合色| 日本在线播放一区二区三区| 中国av一区二区三区| 欧美精品在欧美一区二区少妇| 韩国v欧美v日本v亚洲v| 一区二区三区四区亚洲| 精品少妇一区二区三区免费观看| 91亚洲精品久久久蜜桃| 激情文学综合丁香| 亚洲小说欧美激情另类| 中文字幕免费观看一区| 日韩欧美专区在线| 91黄色免费看| 成人国产精品视频| 国产在线国偷精品产拍免费yy | 欧美成人一级视频| 一本一道波多野结衣一区二区| 精品一区二区三区香蕉蜜桃| 亚洲bdsm女犯bdsm网站| 中文字幕中文字幕一区二区| 精品乱码亚洲一区二区不卡| 欧美日韩一级视频| 99久久99久久精品免费观看| 国产美女精品在线| 免费观看日韩av| 三级一区在线视频先锋 | 日韩精品一二区| 一区二区三区av电影 | 91成人看片片| www.欧美.com| 丁香激情综合国产| 国产乱码精品一区二区三区av| 天堂午夜影视日韩欧美一区二区| 亚洲欧美日韩国产手机在线| 亚洲国产成人午夜在线一区| 国产日韩欧美精品一区| www国产亚洲精品久久麻豆| 欧美电影免费观看高清完整版在线 | 国产精品一区二区男女羞羞无遮挡 | 中文字幕国产一区| 国产亚洲成aⅴ人片在线观看| 精品久久久久久久久久久久久久久久久| 色综合婷婷久久| 99精品视频在线播放观看| 97精品久久久午夜一区二区三区| 成人av集中营| 色吧成人激情小说| 日本韩国欧美在线| 欧美日韩国产一区| 欧美一区二区在线免费播放 | 精品一区精品二区高清| 青椒成人免费视频| 精品中文字幕一区二区小辣椒| 精东粉嫩av免费一区二区三区| 国模一区二区三区白浆| 99视频精品全部免费在线| 91免费在线播放| 欧美日韩国产一级片| 日韩精品一区二区三区中文不卡| 精品国产乱码久久久久久牛牛| 久久久综合视频| 亚洲女同ⅹxx女同tv| 亚洲动漫第一页| 久久99精品久久久久久动态图| 国产高清不卡一区| 91一区二区三区在线观看| 欧洲国内综合视频| 精品欧美黑人一区二区三区| 国产三级一区二区| 亚洲一线二线三线久久久| 日韩av高清在线观看| 高清不卡一区二区| 欧美美女bb生活片| 国产亚洲短视频| 一区二区三区国产精华| 韩日精品视频一区| 色婷婷综合久久久久中文一区二区| 6080日韩午夜伦伦午夜伦| 久久久一区二区三区| 夜夜操天天操亚洲| 精品一区二区av| 色国产综合视频| 久久免费美女视频| 丝袜亚洲另类丝袜在线| 不卡av在线免费观看| 欧美va天堂va视频va在线|