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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? markup.cpp

?? It is WEB browser core module with source code. Very good!
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
 * Copyright (C) 2004 Apple Computer, Inc.  All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE COMPUTER, INC. OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
 */

#include "markup.h"

#include "htmlediting.h"

#include "css/css_computedstyle.h"
#include "css/css_valueimpl.h"
#include "editing/visible_position.h"
#include "editing/visible_units.h"
#include "html/html_elementimpl.h"
#include "xml/dom_position.h"
#include "xml/dom2_rangeimpl.h"
#include "rendering/render_text.h"
#include "misc/htmlattrs.h"
#include "misc/htmltags.h"
#include "html/dtd.h"

using DOM::AttributeImpl;
using DOM::CommentImpl;
using DOM::CSSComputedStyleDeclarationImpl;
using DOM::CSSMutableStyleDeclarationImpl;
using DOM::DocumentFragmentImpl;
using DOM::DocumentImpl;
using DOM::DOMString;
using DOM::ElementImpl;
using DOM::FORBIDDEN;
using DOM::endTagRequirement;
using DOM::HTMLElementImpl;
using DOM::NamedAttrMapImpl;
using DOM::Node;
using DOM::NodeImpl;
using DOM::Position;
using DOM::RangeImpl;
using DOM::TextImpl;

#if APPLE_CHANGES
#include "KWQAssertions.h"
#include "KWQLogging.h"
#else
#define ASSERT(assertion) ((void)0)
#define ASSERT_WITH_MESSAGE(assertion, formatAndArgs...) ((void)0)
#define ASSERT_NOT_REACHED() ((void)0)
#define LOG(channel, formatAndArgs...) ((void)0)
#define ERROR(formatAndArgs...) ((void)0)
#define ASSERT(assertion) assert(assertion)
#endif

namespace khtml {

static QString escapeHTML(const QString &in)
{
    QString s = "";

    unsigned len = in.length();
    for (unsigned i = 0; i < len; ++i) {
        switch (in[i].latin1()) {
            case '&':
                s += "&amp;";
                break;
            case '<':
                s += "&lt;";
                break;
            case '>':
                s += "&gt;";
                break;
            default:
                s += in[i];
        }
    }

    return s;
}

static QString stringValueForRange(const NodeImpl *node, const RangeImpl *range)
{
    DOMString str = node->nodeValue().copy();
    if (range) {
        int exceptionCode;
        if (node == range->endContainer(exceptionCode)) {
            str.truncate(range->endOffset(exceptionCode));
        }
        if (node == range->startContainer(exceptionCode)) {
            str.remove(0, range->startOffset(exceptionCode));
        }
    }
    return str.string();
}

static QString renderedText(const NodeImpl *node, const RangeImpl *range)
{
    RenderObject *r = node->renderer();
    if (!r)
        return QString();
    
    if (!node->isTextNode())
        return QString();

    QString result = "";

    int exceptionCode;
    const TextImpl *textNode = static_cast<const TextImpl *>(node);
    unsigned startOffset = 0;
    unsigned endOffset = textNode->length();

    if (range && node == range->startContainer(exceptionCode))
        startOffset = range->startOffset(exceptionCode);
    if (range && node == range->endContainer(exceptionCode))
        endOffset = range->endOffset(exceptionCode);
    
    RenderText *textRenderer = static_cast<RenderText *>(r);
    QString str = node->nodeValue().string();
    for (InlineTextBox *box = textRenderer->firstTextBox(); box; box = box->nextTextBox()) {
        unsigned start = box->m_start;
        unsigned end = box->m_start + box->m_len;
        if (endOffset < start)
            break;
        if (startOffset <= end) {
            unsigned s = kMax(start, startOffset);
            unsigned e = kMin(end, endOffset);
            result.append(str.mid(s, e-s));
            if (e == end) {
                // now add in collapsed-away spaces if at the end of the line
                InlineTextBox *nextBox = box->nextTextBox();
                if (nextBox && box->root() != nextBox->root()) {
                    const char nonBreakingSpace = '\xa0';
                    // count the number of characters between the end of the
                    // current box and the start of the next box.
                    int collapsedStart = e;
                    int collapsedPastEnd = kMin((unsigned)nextBox->m_start, endOffset + 1);
                    bool addNextNonNBSP = true;
                    for (int i = collapsedStart; i < collapsedPastEnd; i++) {
                        if (str[i] == nonBreakingSpace) {
                            result.append(str[i]);
                            addNextNonNBSP = true;
                        }
                        else if (addNextNonNBSP) {
                            result.append(str[i]);
                            addNextNonNBSP = false;
                        }
                    }
                }
            }
        }

    }
    
    return result;
}

static QString startMarkup(const NodeImpl *node, const RangeImpl *range, EAnnotateForInterchange annotate, CSSMutableStyleDeclarationImpl *defaultStyle)
{
    unsigned short type = node->nodeType();
    switch (type) {
        case Node::TEXT_NODE: {
            if (node->parentNode()) {
                switch (node->parentNode()->id()) {
                    case ID_PRE:
                    case ID_SCRIPT:
                    case ID_STYLE:
                    case ID_TEXTAREA:
                        return stringValueForRange(node, range);
                }
            }
            QString markup = annotate ? escapeHTML(renderedText(node, range)) : escapeHTML(stringValueForRange(node, range));            
            if (defaultStyle) {
                NodeImpl *element = node->parentNode();
                if (element) {
                    CSSMutableStyleDeclarationImpl *style = Position(element, 0).computedStyle()->copyInheritableProperties();
                    style->ref();
                    defaultStyle->diff(style);
                    if (style->length() > 0) {
                        // FIXME: Handle case where style->cssText() has illegal characters in it, like "
                        QString openTag = QString("<span class=\"") + AppleStyleSpanClass + "\" style=\"" + style->cssText().string() + "\">";
                        markup = openTag + markup + "</span>";
                    }
                    style->deref();
                }            
            }
            return annotate ? convertHTMLTextToInterchangeFormat(markup) : markup;
        }
        case Node::COMMENT_NODE:
            return static_cast<const CommentImpl *>(node)->toString().string();
        case Node::DOCUMENT_NODE:
            return "";
        default: {
            QString markup = QChar('<') + node->nodeName().string();
            if (type == Node::ELEMENT_NODE) {
                const ElementImpl *el = static_cast<const ElementImpl *>(node);
                DOMString additionalStyle;
                if (defaultStyle && el->isHTMLElement()) {
                    CSSMutableStyleDeclarationImpl *style = Position(const_cast<ElementImpl *>(el), 0).computedStyle()->copyInheritableProperties();
                    style->ref();
                    defaultStyle->diff(style);
                    if (style->length() > 0) {
                        CSSMutableStyleDeclarationImpl *inlineStyleDecl = static_cast<const HTMLElementImpl *>(el)->inlineStyleDecl();
                        if (inlineStyleDecl)
                            inlineStyleDecl->diff(style);
                        additionalStyle = style->cssText();
                    }
                    style->deref();
                }
                NamedAttrMapImpl *attrs = el->attributes();
                unsigned long length = attrs->length();
                if (length == 0 && additionalStyle.length() > 0) {
                    // FIXME: Handle case where additionalStyle has illegal characters in it, like "
                    markup += " " + node->getDocument()->attrName(ATTR_STYLE).string() + "=\"" + additionalStyle.string() + "\"";
                }
                else {
                    for (unsigned int i=0; i<length; i++) {
                        AttributeImpl *attr = attrs->attributeItem(i);
                        DOMString value = attr->value();
                        if (attr->id() == ATTR_STYLE && additionalStyle.length() > 0)
                            value += "; " + additionalStyle;
                        // FIXME: Handle case where value has illegal characters in it, like "
                        markup += " " + node->getDocument()->attrName(attr->id()).string() + "=\"" + value.string() + "\"";
                    }
                }
            }
            markup += node->isHTMLElement() ? ">" : "/>";
            return markup;
        }
    }
}

static QString endMarkup(const NodeImpl *node)
{
    if ((!node->isHTMLElement() || endTagRequirement(node->id()) != FORBIDDEN) && node->nodeType() != Node::TEXT_NODE && node->nodeType() != Node::DOCUMENT_NODE) {
        return "</" + node->nodeName().string() + ">";
    }
    return "";
}

static QString markup(const NodeImpl *startNode, bool onlyIncludeChildren, bool includeSiblings, QPtrList<NodeImpl> *nodes)
{
    // Doesn't make sense to only include children and include siblings.
    ASSERT(!(onlyIncludeChildren && includeSiblings));
    QString me = "";
    for (const NodeImpl *current = startNode; current != NULL; current = includeSiblings ? current->nextSibling() : NULL) {
        if (!onlyIncludeChildren) {
            if (nodes) {
                nodes->append(current);
            }
            me += startMarkup(current, 0, DoNotAnnotateForInterchange, 0);
        }        
        if (!current->isHTMLElement() || endTagRequirement(current->id()) != FORBIDDEN) {
            // print children
            if (NodeImpl *n = current->firstChild()) {
                me += markup(n, false, true, nodes);
            }
            // Print my ending tag
            if (!onlyIncludeChildren) {
                me += endMarkup(current);
            }
        }
    }
    return me;
}

static void completeURLs(NodeImpl *node, const QString &baseURL)
{
    NodeImpl *end = node->traverseNextSibling();
    for (NodeImpl *n = node; n != end; n = n->traverseNextNode()) {
        if (n->nodeType() == Node::ELEMENT_NODE) {
            ElementImpl *e = static_cast<ElementImpl *>(n);
            NamedAttrMapImpl *attrs = e->attributes();
            unsigned long length = attrs->length();

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美人xxxx| 亚洲男帅同性gay1069| 亚洲欧美综合另类在线卡通| 亚洲不卡av一区二区三区| 国产自产v一区二区三区c| 在线观看三级视频欧美| 久久久久久久久久久久久女国产乱| 亚洲男人电影天堂| 国产精品综合久久| 欧美色网一区二区| 国产精品素人一区二区| 久久国产精品72免费观看| 欧美网站一区二区| 亚洲色大成网站www久久九九| 狠狠色丁香婷婷综合久久片| 欧美日韩黄视频| 亚洲女性喷水在线观看一区| 国产精品自拍三区| 日韩一卡二卡三卡| 日韩不卡一二三区| 欧美情侣在线播放| 亚洲午夜久久久久久久久电影院 | 亚洲一区在线免费观看| 国v精品久久久网| 欧美精品一区二区三区蜜臀| 美女网站视频久久| 777色狠狠一区二区三区| 亚洲综合一区二区三区| 色婷婷久久久综合中文字幕| 亚洲色图视频网站| 91亚洲精品一区二区乱码| 一区二区中文字幕在线| 不卡高清视频专区| 亚洲三级在线免费观看| 成人动漫一区二区| 久久嫩草精品久久久久| 免费成人美女在线观看| 欧美日韩精品免费| 国产精品成人一区二区三区夜夜夜| 国产伦理精品不卡| 欧美日韩在线不卡| 亚洲国产日韩a在线播放性色| 99久久精品99国产精品| 国产亚洲一区二区三区四区 | 另类中文字幕网| 欧美日韩国产精选| 亚洲欧美激情视频在线观看一区二区三区 | 在线成人小视频| 一区二区三区加勒比av| 91久久国产综合久久| 一区二区三区.www| 欧美性淫爽ww久久久久无| 国产精品国产馆在线真实露脸| 国产福利不卡视频| 中文字幕亚洲在| 成人美女在线观看| 亚洲色图都市小说| 欧美日韩色一区| 日韩成人伦理电影在线观看| 日韩欧美一区二区在线视频| 午夜精彩视频在线观看不卡| 欧美日韩一区二区在线观看 | 日本亚洲电影天堂| 日韩一二三区不卡| 久久国产剧场电影| 日本一区二区三区国色天香 | 亚洲蜜臀av乱码久久精品蜜桃| 色伊人久久综合中文字幕| 成人av手机在线观看| 欧美精品一区二区三区蜜桃| 国产高清在线精品| 国产精品久久精品日日| 欧美做爰猛烈大尺度电影无法无天| 亚洲高清视频的网址| 欧美一区午夜视频在线观看 | 欧美一区二区三区性视频| 日韩av高清在线观看| 精品国产乱码久久| 99久久婷婷国产精品综合| 无吗不卡中文字幕| 国产日韩三级在线| 91成人看片片| 国产真实乱对白精彩久久| 国产精品精品国产色婷婷| 777午夜精品视频在线播放| 国产成人精品在线看| 亚洲第一在线综合网站| 国产亚洲美州欧州综合国| 欧美三级日韩三级国产三级| 狠狠网亚洲精品| 一区二区三区在线观看国产| 日韩欧美一区二区视频| 成a人片亚洲日本久久| 国产一区二区三区综合| 亚洲午夜精品在线| 中文字幕成人网| 欧美日韩一区二区三区视频| 国产成人精品一区二区三区网站观看| 亚洲精品中文在线影院| 久久女同精品一区二区| 欧美性色综合网| 成人爱爱电影网址| 国产资源在线一区| 男女激情视频一区| 亚洲精品成人a在线观看| 久久久不卡影院| 欧美日韩国产高清一区二区 | 亚洲一区在线看| 国产精品情趣视频| 精品伦理精品一区| 欧美精品tushy高清| 色94色欧美sute亚洲线路一ni | 日韩亚洲欧美在线| 欧美三级乱人伦电影| 9久草视频在线视频精品| 国产精品99久久久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲一区二区美女| 亚洲色图在线播放| 中文字幕日韩精品一区| 欧美国产精品中文字幕| 精品999在线播放| 欧美大片在线观看| 日韩欧美一级在线播放| 日韩一区二区免费在线电影 | 久久久精品国产免大香伊| 欧美一区二区三区小说| 555夜色666亚洲国产免| www激情久久| 91精品国产91热久久久做人人| 欧美日韩国产系列| 88在线观看91蜜桃国自产| 91精品国产综合久久小美女| 欧美色视频在线| 在线观看一区日韩| 在线亚洲一区观看| 精品视频一区二区不卡| 88在线观看91蜜桃国自产| 欧美一区二区三区小说| 久久久久久久精| 中文字幕亚洲在| 亚洲影院久久精品| 午夜精品福利一区二区蜜股av| 天天色综合天天| 久久国产精品99精品国产 | 日韩免费观看高清完整版| 日韩欧美一级二级| 久久精品人人做人人爽人人| 国产欧美日韩不卡免费| 亚洲激情网站免费观看| 婷婷中文字幕综合| 久久国产精品一区二区| 成人国产视频在线观看| 欧美日精品一区视频| 亚洲精品一线二线三线无人区| 国产亚洲欧美色| 一区二区激情视频| 日韩不卡一区二区| 国产不卡一区视频| 欧美亚洲日本国产| 精品国产乱码久久久久久牛牛| 精品美女一区二区三区| 精品久久久久99| 2023国产一二三区日本精品2022| 国产香蕉久久精品综合网| 国产精品视频第一区| 午夜精品免费在线观看| 国产乱码精品一区二区三 | 裸体健美xxxx欧美裸体表演| 久久精品国产99| av资源网一区| 欧美日韩五月天| 欧美极品xxx| 香港成人在线视频| 成人av在线一区二区三区| 91麻豆精品国产91久久久资源速度| 精品国一区二区三区| 亚洲狠狠丁香婷婷综合久久久| 久久精品国产在热久久| 91在线免费播放| 欧美一区二区在线看| 亚洲香肠在线观看| 成人午夜免费av| 6080国产精品一区二区| 亚洲久草在线视频| 国产成人三级在线观看| 欧美成人精品二区三区99精品| 亚洲人精品午夜| 丁香婷婷综合色啪| 欧美一区二区免费| 亚洲成人动漫一区| 91丨九色porny丨蝌蚪| 久久婷婷综合激情| 蜜桃视频一区二区三区在线观看 | 91麻豆文化传媒在线观看| 欧美亚洲动漫制服丝袜| 亚洲精品成人悠悠色影视| 国产成人av自拍| 欧美哺乳videos| 美女视频第一区二区三区免费观看网站|