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

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

?? nodes.cpp

?? khtml在gtk上的移植版本
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
// -*- c-basic-offset: 2 -*-/* *  This file is part of the KDE libraries *  Copyright (C) 1999-2002 Harri Porten (porten@kde.org) *  Copyright (C) 2001 Peter Kelly (pmk@post.com) *  Copyright (C) 2003 Apple Computer, Inc. * *  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. * */#include "nodes.h"//#include <iostream>#include <math.h>#include <assert.h>#ifdef KJS_DEBUG_MEM#include <stdio.h>#include <typeinfo>#endif#include "collector.h"#include "context.h"#include "debugger.h"#include "function_object.h"#include "internal.h"#include "value.h"#include "object.h"#include "types.h"#include "interpreter.h"#include "lexer.h"#include "operations.h"#include "ustring.h"using namespace KJS;#define KJS_BREAKPOINT \  if (!hitStatement(exec)) \    return Completion(Normal);#define KJS_ABORTPOINT \  if (exec->dynamicInterpreter()->imp()->debugger() && \      exec->dynamicInterpreter()->imp()->debugger()->imp()->aborted()) \    return Completion(Normal);#define KJS_CHECKEXCEPTION \  if (exec->hadException()) \    return Completion(Throw, exec->exception()); \  if (Collector::outOfMemory()) \    return Completion(Throw, Error::create(exec,GeneralError,"Out of memory"));#define KJS_CHECKEXCEPTIONVALUE \  if (exec->hadException()) \    return exec->exception(); \  if (Collector::outOfMemory()) \    return Undefined(); // will be picked up by KJS_CHECKEXCEPTION#define KJS_CHECKEXCEPTIONREFERENCE \  if (exec->hadException()) \    return Reference::makeValueReference(Undefined());; \  if (Collector::outOfMemory()) \    return Reference::makeValueReference(Undefined()); // will be picked up by KJS_CHECKEXCEPTION#define KJS_CHECKEXCEPTIONLIST \  if (exec->hadException()) \    return List(); \  if (Collector::outOfMemory()) \    return List(); // will be picked up by KJS_CHECKEXCEPTION#ifdef KJS_DEBUG_MEMstd::list<Node *> * Node::s_nodes = 0L;#endif// ------------------------------ Node -----------------------------------------Node::Node(){  line = Lexer::curr()->lineNo();  sourceURL = Lexer::curr()->sourceURL();  refcount = 0;#ifdef KJS_DEBUG_MEM  if (!s_nodes)    s_nodes = new std::list<Node *>;  s_nodes->push_back(this);#endif}Node::~Node(){#ifdef KJS_DEBUG_MEM  s_nodes->remove( this );#endif}Reference Node::evaluateReference(ExecState *exec){  Value v = evaluate(exec);  KJS_CHECKEXCEPTIONREFERENCE  return Reference::makeValueReference(v);}#ifdef KJS_DEBUG_MEMvoid Node::finalCheck(){  fprintf( stderr, "Node::finalCheck(): list count       : %d\n", (int)s_nodes.size() );  std::list<Node *>::iterator it = s_nodes->begin();  for ( uint i = 0; it != s_nodes->end() ; ++it, ++i )    fprintf( stderr, "[%d] Still having node %p (%s) (refcount %d)\n", i, (void*)*it, typeid( **it ).name(), (*it)->refcount );  delete s_nodes;  s_nodes = 0L;}#endifValue Node::throwError(ExecState *exec, ErrorType e, const char *msg){  Object err = Error::create(exec, e, msg, lineNo(), sourceId(), &sourceURL);  exec->setException(err);  return err;}Value Node::throwError(ExecState *exec, ErrorType e, const char *msg, Value v, Node *expr){  char *vStr = strdup(v.toString(exec).ascii());  char *exprStr = strdup(expr->toString().ascii());    int length =  strlen(msg) - 4 /* two %s */ + strlen(vStr) + strlen(exprStr) + 1 /* null terminator */;  char *str = new char[length];  sprintf(str, msg, vStr, exprStr);  free(vStr);  free(exprStr);  Value result = throwError(exec, e, str);  delete [] str;    return result;}Value Node::throwError(ExecState *exec, ErrorType e, const char *msg, Identifier label){  const char *l = label.ascii();  int length = strlen(msg) - 2 /* %s */ + strlen(l) + 1 /* null terminator */;  char *message = new char[length];  sprintf(message, msg, l);  Value result = throwError(exec, e, message);  delete [] message;  return result;}// ------------------------------ StatementNode --------------------------------StatementNode::StatementNode() : l0(-1), l1(-1), sid(-1), breakPoint(false){}void StatementNode::setLoc(int line0, int line1, int sourceId){    l0 = line0;    l1 = line1;    sid = sourceId;}// return true if the debugger wants us to stop at this pointbool StatementNode::hitStatement(ExecState *exec){  Debugger *dbg = exec->dynamicInterpreter()->imp()->debugger();  if (dbg)    return dbg->atStatement(exec,sid,l0,l1);  else    return true; // continue}// return true if the debugger wants us to stop at this pointbool StatementNode::abortStatement(ExecState *exec){  Debugger *dbg = exec->dynamicInterpreter()->imp()->debugger();  if (dbg)    return dbg->imp()->aborted();  else    return false;}void StatementNode::processFuncDecl(ExecState *exec){}// ------------------------------ NullNode -------------------------------------Value NullNode::evaluate(ExecState */*exec*/){  return Null();}// ------------------------------ BooleanNode ----------------------------------Value BooleanNode::evaluate(ExecState */*exec*/){  return Boolean(value);}// ------------------------------ NumberNode -----------------------------------Value NumberNode::evaluate(ExecState */*exec*/){  return Number(value);}// ------------------------------ StringNode -----------------------------------Value StringNode::evaluate(ExecState */*exec*/){  return String(value);}// ------------------------------ RegExpNode -----------------------------------Value RegExpNode::evaluate(ExecState *exec){  List list;  String p(pattern);  String f(flags);  list.append(p);  list.append(f);  Object reg = exec->lexicalInterpreter()->imp()->builtinRegExp();  return reg.construct(exec,list);}// ------------------------------ ThisNode -------------------------------------// ECMA 11.1.1Value ThisNode::evaluate(ExecState *exec){  return exec->context().imp()->thisValue();}// ------------------------------ ResolveNode ----------------------------------// ECMA 11.1.2 & 10.1.4Value ResolveNode::evaluate(ExecState *exec){  return evaluateReference(exec).getValue(exec);}Reference ResolveNode::evaluateReference(ExecState *exec){  ScopeChain chain = exec->context().imp()->scopeChain();  while (!chain.isEmpty()) {    ObjectImp *o = chain.top();    //cout << "Resolve: looking at '" << ident.ascii() << "'"    //     << " in " << (void*)o << " " << o->classInfo()->className << endl;    if (o->hasProperty(exec,ident)) {      //cout << "Resolve: FOUND '" << ident.ascii() << "'"      //     << " in " << (void*)o << " " << o->classInfo()->className << endl;      return Reference(o, ident);    }        chain.pop();  }  // identifier not found  //cout << "Resolve: didn't find '" << ident.ascii() << "'" << endl;  return Reference(Null(), ident);}// ------------------------------ GroupNode ------------------------------------void GroupNode::ref(){  Node::ref();  if ( group )    group->ref();}bool GroupNode::deref(){  if ( group && group->deref() )    delete group;  return Node::deref();}// ECMA 11.1.6Value GroupNode::evaluate(ExecState *exec){  return group->evaluate(exec);}// ------------------------------ ElementNode ----------------------------------void ElementNode::ref(){  for (ElementNode *n = this; n; n = n->list) {    n->Node::ref();    if (n->node)      n->node->ref();  }}bool ElementNode::deref(){  ElementNode *next;  for (ElementNode *n = this; n; n = next) {    next = n->list;    if (n->node && n->node->deref())      delete n->node;    if (n != this && n->Node::deref())      delete n;  }  return Node::deref();}// ECMA 11.1.4Value ElementNode::evaluate(ExecState *exec){  Object array = exec->lexicalInterpreter()->builtinArray().construct(exec, List::empty());  int length = 0;  for (ElementNode *n = this; n; n = n->list) {    Value val = n->node->evaluate(exec);    KJS_CHECKEXCEPTIONVALUE    length += n->elision;    array.put(exec, length++, val);  }  return array;}// ------------------------------ ArrayNode ------------------------------------void ArrayNode::ref(){  Node::ref();  if ( element )    element->ref();}bool ArrayNode::deref(){  if ( element && element->deref() )    delete element;  return Node::deref();}// ECMA 11.1.4Value ArrayNode::evaluate(ExecState *exec){  Object array;  int length;  if (element) {    array = Object(static_cast<ObjectImp*>(element->evaluate(exec).imp()));    KJS_CHECKEXCEPTIONVALUE    length = opt ? array.get(exec,lengthPropertyName).toInt32(exec) : 0;  } else {    Value newArr = exec->lexicalInterpreter()->builtinArray().construct(exec,List::empty());    array = Object(static_cast<ObjectImp*>(newArr.imp()));    length = 0;  }  if (opt)    array.put(exec,lengthPropertyName, Number(elision + length), DontEnum | DontDelete);  return array;}// ------------------------------ ObjectLiteralNode ----------------------------void ObjectLiteralNode::ref(){  Node::ref();  if ( list )    list->ref();}bool ObjectLiteralNode::deref(){  if ( list && list->deref() )    delete list;  return Node::deref();}// ECMA 11.1.5Value ObjectLiteralNode::evaluate(ExecState *exec){  if (list)    return list->evaluate(exec);  return exec->lexicalInterpreter()->builtinObject().construct(exec,List::empty());}// ------------------------------ PropertyValueNode ----------------------------void PropertyValueNode::ref(){  for (PropertyValueNode *n = this; n; n = n->list) {    n->Node::ref();    if (n->name)      n->name->ref();    if (n->assign)      n->assign->ref();  }}bool PropertyValueNode::deref(){  PropertyValueNode *next;  for (PropertyValueNode *n = this; n; n = next) {    next = n->list;    if ( n->name && n->name->deref() )      delete n->name;    if ( n->assign && n->assign->deref() )      delete n->assign;    if (n != this && n->Node::deref() )      delete n;  }  return Node::deref();}// ECMA 11.1.5Value PropertyValueNode::evaluate(ExecState *exec){  Object obj = exec->lexicalInterpreter()->builtinObject().construct(exec, List::empty());    for (PropertyValueNode *p = this; p; p = p->list) {    Value n = p->name->evaluate(exec);    KJS_CHECKEXCEPTIONVALUE    Value v = p->assign->evaluate(exec);    KJS_CHECKEXCEPTIONVALUE    obj.put(exec, Identifier(n.toString(exec)), v);  }  return obj;}// ------------------------------ PropertyNode ---------------------------------// ECMA 11.1.5Value PropertyNode::evaluate(ExecState */*exec*/){  Value s;  if (str.isNull()) {    s = String(UString::from(numeric));  } else {    s = String(str.ustring());  }  return s;}// ------------------------------ AccessorNode1 --------------------------------void AccessorNode1::ref(){  Node::ref();  if ( expr1 )    expr1->ref();  if ( expr2 )    expr2->ref();}bool AccessorNode1::deref(){  if ( expr1 && expr1->deref() )    delete expr1;  if ( expr2 && expr2->deref() )    delete expr2;  return Node::deref();}// ECMA 11.2.1aValue AccessorNode1::evaluate(ExecState *exec){  return evaluateReference(exec).getValue(exec);}Reference AccessorNode1::evaluateReference(ExecState *exec){  Value v1 = expr1->evaluate(exec);  KJS_CHECKEXCEPTIONREFERENCE  Value v2 = expr2->evaluate(exec);  KJS_CHECKEXCEPTIONREFERENCE  Object o = v1.toObject(exec);  unsigned i;  if (v2.toUInt32(i))    return Reference(o, i);  String s = v2.toString(exec);  return Reference(o, Identifier(s.value()));}// ------------------------------ AccessorNode2 --------------------------------void AccessorNode2::ref(){  Node::ref();  if ( expr )    expr->ref();}bool AccessorNode2::deref(){  if ( expr && expr->deref() )    delete expr;  return Node::deref();}// ECMA 11.2.1bValue AccessorNode2::evaluate(ExecState *exec){  return evaluateReference(exec).getValue(exec);}Reference AccessorNode2::evaluateReference(ExecState *exec){  Value v = expr->evaluate(exec);  KJS_CHECKEXCEPTIONREFERENCE  Object o = v.toObject(exec);  return Reference(o, ident);}// ------------------------------ ArgumentListNode -----------------------------void ArgumentListNode::ref(){  for (ArgumentListNode *n = this; n; n = n->list) {    n->Node::ref();    if (n->expr)      n->expr->ref();  }}bool ArgumentListNode::deref(){  ArgumentListNode *next;  for (ArgumentListNode *n = this; n; n = next) {    next = n->list;    if (n->expr && n->expr->deref())      delete n->expr;    if (n != this && n->Node::deref())      delete n;  }  return Node::deref();}Value ArgumentListNode::evaluate(ExecState */*exec*/){  assert(0);  return Value(); // dummy, see evaluateList()}// ECMA 11.2.4List ArgumentListNode::evaluateList(ExecState *exec){  List l;  for (ArgumentListNode *n = this; n; n = n->list) {    Value v = n->expr->evaluate(exec);    KJS_CHECKEXCEPTIONLIST    l.append(v);  }  return l;}// ------------------------------ ArgumentsNode --------------------------------void ArgumentsNode::ref(){  Node::ref();  if ( list )    list->ref();}bool ArgumentsNode::deref(){  if ( list && list->deref() )    delete list;  return Node::deref();}Value ArgumentsNode::evaluate(ExecState */*exec*/){  assert(0);  return Value(); // dummy, see evaluateList()}// ECMA 11.2.4List ArgumentsNode::evaluateList(ExecState *exec){  if (!list)    return List();  return list->evaluateList(exec);}// ------------------------------ NewExprNode ----------------------------------// ECMA 11.2.2void NewExprNode::ref(){  Node::ref();  if ( expr )    expr->ref();  if ( args )    args->ref();}bool NewExprNode::deref(){  if ( expr && expr->deref() )    delete expr;  if ( args && args->deref() )    delete args;  return Node::deref();}Value NewExprNode::evaluate(ExecState *exec){  Value v = expr->evaluate(exec);  KJS_CHECKEXCEPTIONVALUE  List argList;  if (args) {    argList = args->evaluateList(exec);    KJS_CHECKEXCEPTIONVALUE  }  if (v.type() != ObjectType) {    return throwError(exec, TypeError, "Value %s (result of expression %s) is not an object. Cannot be used with new.", v, expr);  }  Object constr = Object(static_cast<ObjectImp*>(v.imp()));  if (!constr.implementsConstruct()) {    return throwError(exec, TypeError, "Value %s (result of expression %s) is not a constructor. Cannot be used with new.", v, expr);  }  Value res = constr.construct(exec,argList);  return res;}// ------------------------------ FunctionCallNode -----------------------------void FunctionCallNode::ref(){  Node::ref();  if ( expr )    expr->ref();  if ( args )    args->ref();}bool FunctionCallNode::deref(){  if ( expr && expr->deref() )    delete expr;  if ( args && args->deref() )    delete args;  return Node::deref();}// ECMA 11.2.3Value FunctionCallNode::evaluate(ExecState *exec){  Reference ref = expr->evaluateReference(exec);  KJS_CHECKEXCEPTIONVALUE  List argList = args->evaluateList(exec);  KJS_CHECKEXCEPTIONVALUE  Value v = ref.getValue(exec);  if (v.type() != ObjectType) {    return throwError(exec, TypeError, "Value %s (result of expression %s) is not object.", v, expr);  }  Object func = Object(static_cast<ObjectImp*>(v.imp()));  if (!func.implementsCall()) {    return throwError(exec, TypeError, "Object %s (result of expression %s) does not allow calls.", v, expr);  }  Value thisVal;  if (ref.isMutable())    thisVal = ref.getBase(exec);  else    thisVal = Null();  if (thisVal.type() == ObjectType &&      Object::dynamicCast(thisVal).inherits(&ActivationImp::info))    thisVal = Null();  if (thisVal.type() != ObjectType) {    // ECMA 11.2.3 says that in this situation the this value should be null.    // However, section 10.2.3 says that in the case where the value provided    // by the caller is null, the global object should be used. It also says    // that the section does not apply to interal functions, but for simplicity    // of implementation we use the global object anyway here. This guarantees    // that in host objects you always get a valid object for this.    // thisVal = Null();    thisVal = exec->dynamicInterpreter()->globalObject();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2021久久国产精品不只是精品| 奇米影视在线99精品| 欧美一卡二卡在线观看| 色94色欧美sute亚洲线路一久| 国产suv精品一区二区三区| 精品无人码麻豆乱码1区2区 | 精品国产免费久久| 精品久久久久久无| 欧美成人猛片aaaaaaa| 欧美一区二区三区喷汁尤物| 日韩欧美一级二级| 精品国产91九色蝌蚪| 国产网红主播福利一区二区| 国产午夜一区二区三区| 最新热久久免费视频| 亚洲乱码国产乱码精品精可以看 | 91在线看国产| 色哦色哦哦色天天综合| 欧美日韩高清一区二区三区| 欧美肥妇free| 久久久99久久| 亚洲一区二区偷拍精品| 九色综合狠狠综合久久| 粉嫩aⅴ一区二区三区四区五区 | 欧美videos中文字幕| 国产三级精品在线| 亚洲免费观看高清完整版在线观看| 一区二区三区国产| 免费视频最近日韩| 国产成人av一区二区三区在线| 99re成人精品视频| 欧美一区二区三区性视频| 久久久精品tv| 国产精品成人网| 奇米影视7777精品一区二区| 国产suv精品一区二区6| 欧美日韩精品系列| 久久久亚洲精华液精华液精华液| 亚洲色欲色欲www在线观看| 秋霞国产午夜精品免费视频| 成人av网址在线观看| 日韩欧美精品在线视频| 一个色在线综合| 国产传媒欧美日韩成人| 8v天堂国产在线一区二区| 国产精品欧美综合在线| 麻豆精品一区二区三区| 色呦呦一区二区三区| 国产喂奶挤奶一区二区三区| 天天做天天摸天天爽国产一区| 国产超碰在线一区| 精品久久久久久综合日本欧美| 亚洲久草在线视频| 成人午夜短视频| 亚洲伦理在线免费看| 国产二区国产一区在线观看| 91精品国产欧美日韩| 日韩欧美在线一区二区三区| 亚洲风情在线资源站| 99国产精品视频免费观看| 国产欧美精品一区二区色综合| 青草国产精品久久久久久| 欧美日韩视频一区二区| 亚洲天堂成人网| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 欧美一二三区在线| 最新不卡av在线| 国产综合久久久久久久久久久久| 色狠狠桃花综合| 久久伊人蜜桃av一区二区| 一区二区三区在线免费| 激情亚洲综合在线| 欧美精选午夜久久久乱码6080| 一区二区成人在线观看| 一本大道久久精品懂色aⅴ| 精品日韩成人av| 日本不卡免费在线视频| 日韩一级片网址| 美女网站在线免费欧美精品| 成人蜜臀av电影| 亚洲天堂精品在线观看| 91久久国产最好的精华液| 一区二区三区四区在线播放| 欧美制服丝袜第一页| 国产精品二区一区二区aⅴ污介绍| 亚洲国产精品一区二区久久恐怖片| 国产盗摄女厕一区二区三区| 91女厕偷拍女厕偷拍高清| 精品乱人伦一区二区三区| 国产乱淫av一区二区三区| 91精品国产免费久久综合| 亚洲免费看黄网站| 国内精品久久久久影院色| 在线观看91精品国产入口| 亚洲午夜av在线| 日韩欧美电影一二三| 丰满亚洲少妇av| 亚洲午夜激情av| 欧美精品一区男女天堂| 97久久超碰精品国产| 日日欢夜夜爽一区| 久久精品一区二区三区不卡牛牛| 暴力调教一区二区三区| 亚洲图片一区二区| 欧美一区二区三区影视| 99久久婷婷国产精品综合| 婷婷激情综合网| 中文字幕亚洲一区二区va在线| 欧美三级在线视频| 国产精品一区二区在线观看网站| 亚洲免费观看高清完整| 欧美大胆一级视频| 一本一道久久a久久精品| 日韩av不卡一区二区| 国产精品久久久久婷婷| 欧美一区二区三区免费观看视频| 成人久久视频在线观看| 久久综合成人精品亚洲另类欧美 | 欧美男男青年gay1069videost| 国产一区二区不卡老阿姨| 亚洲国产日韩在线一区模特| 欧美精品一区二区三区很污很色的 | 国产成人免费9x9x人网站视频| 国产精品久久久久影视| 欧美一区二区三区视频| 亚洲精品视频观看| 国产欧美一区二区精品性色超碰| 国产91精品入口| 日韩二区三区在线观看| 日韩视频一区二区| 91国在线观看| 成人永久免费视频| 樱花影视一区二区| 国产午夜三级一区二区三| 欧美一个色资源| 欧美色图第一页| 日韩av高清在线观看| 国产性做久久久久久| 在线免费观看一区| 亚洲午夜在线视频| 中文成人综合网| 欧美电影免费观看完整版| 欧美日本一区二区三区四区 | 精品国产免费人成电影在线观看四季| 久久精品国产精品青草| 亚洲高清免费在线| 一区二区三区中文在线| 精品精品国产高清一毛片一天堂| 色婷婷精品大在线视频| 成人动漫一区二区三区| 成人一道本在线| 久久av资源网| 国产美女在线观看一区| 国产经典欧美精品| 大陆成人av片| 日韩成人午夜精品| 日韩成人午夜电影| 国产在线视频不卡二| 国产一区二区在线免费观看| 肉肉av福利一精品导航| 日本在线不卡视频| 精品无码三级在线观看视频 | 久久影院视频免费| 中文在线一区二区 | 成人精品一区二区三区四区| 日本美女一区二区| 精品一区在线看| 久久99精品久久只有精品| 国内外成人在线| 久久av老司机精品网站导航| 国产精品亚洲一区二区三区在线 | 国产乱理伦片在线观看夜一区| 日韩国产欧美在线观看| 久久av老司机精品网站导航| 国产精品66部| 91在线观看污| 国产精品一区二区在线播放| 成人高清免费观看| 在线免费观看视频一区| 欧美va日韩va| 久久久噜噜噜久久中文字幕色伊伊| 亚洲国产成人私人影院tom| 亚洲欧美一区二区久久| 日精品一区二区三区| 日本在线播放一区二区三区| 国内精品免费**视频| 在线免费不卡视频| 精品成人一区二区| 久久婷婷一区二区三区| 亚洲免费资源在线播放| 久久99精品久久久久| 成人免费看的视频| 日韩亚洲欧美一区| 国产日韩精品一区二区三区| 一区二区三区精密机械公司| 国产黄人亚洲片| 91精品国产综合久久婷婷香蕉| 这里是久久伊人| 国产精品乱码一区二区三区软件 | 欧美精品久久久久久久多人混战|