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

📄 lookup.h

📁 khtml在gtk上的移植版本
💻 H
字号:
// -*- c-basic-offset: 2 -*-/* *  This file is part of the KDE libraries *  Copyright (C) 1999-2000 Harri Porten (porten@kde.org) *  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 Lesser 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 *  Lesser General Public License for more details. * *  You should have received a copy of the GNU Lesser General Public *  License along with this library; if not, write to the Free Software *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * */#ifndef _KJSLOOKUP_H_#define _KJSLOOKUP_H_#include "identifier.h"#include "value.h"#include <stdio.h>namespace KJS {  /**   * An entry in a hash table.   */  struct HashEntry {    /**     * s is the key (e.g. a property name)     */    const char *s;    /**     * value is the result value (usually an enum value)     */    int value;    /**     * attr is a set for flags (e.g. the property flags, see object.h)     */    short int attr;    /**     * params is another number. For property hashtables, it is used to     * denote the number of argument of the function     */    short int params;    /**     * next is the pointer to the next entry for the same hash value     */    const HashEntry *next;  };  /**   * A hash table   * Usually the hashtable is generated by the create_hash_table script, from a .table file.   *   * The implementation uses an array of entries, "size" is the total size of that array.   * The entries between 0 and hashSize-1 are the entry points   * for each hash value, and the entries between hashSize and size-1   * are the overflow entries for the hash values that need one.   * The "next" pointer of the entry links entry points to overflow entries,   * and links overflow entries between them.   */  struct HashTable {    /**     * type is a version number. Currently always 2     */    int type;    /**     * size is the total number of entries in the hashtable, including the null entries,     * i.e. the size of the "entries" array.     * Used to iterate over all entries in the table     */    int size;    /**     * pointer to the array of entries     * Mind that some entries in the array are null (0,0,0,0).     */    const HashEntry *entries;    /**     * the maximum value for the hash. Always smaller than size.     */    int hashSize;  };  /**   * @short Fast keyword lookup.   */  class Lookup {  public:    /**     * Find an entry in the table, and return its value (i.e. the value field of HashEntry)     */    static int find(const struct HashTable *table, const Identifier &s);    static int find(const struct HashTable *table,		    const UChar *c, unsigned int len);    /**     * Find an entry in the table, and return the entry     * This variant gives access to the other attributes of the entry,     * especially the attr field.     */    static const HashEntry* findEntry(const struct HashTable *table,                                      const Identifier &s);    static const HashEntry* findEntry(const struct HashTable *table,                                      const UChar *c, unsigned int len);    /**     * Calculate the hash value for a given key     */    static unsigned int hash(const Identifier &key);    static unsigned int hash(const UChar *c, unsigned int len);    static unsigned int hash(const char *s);  };  class ExecState;  class UString;  /**   * @internal   * Helper for lookupFunction and lookupValueOrFunction   */  template <class FuncImp>  inline Value lookupOrCreateFunction(ExecState *exec, const Identifier &propertyName,                                      const ObjectImp *thisObj, int token, int params, int attr)  {      // Look for cached value in dynamic map of properties (in ObjectImp)      ValueImp * cachedVal = thisObj->ObjectImp::getDirect(propertyName);      /*if (cachedVal)        fprintf(stderr, "lookupOrCreateFunction: Function -> looked up in ObjectImp, found type=%d\n", cachedVal->type());*/      if (cachedVal)        return Value(cachedVal);      Value val = Value(new FuncImp(exec,token, params));      ObjectImp *thatObj = const_cast<ObjectImp *>(thisObj);      thatObj->ObjectImp::put(exec, propertyName, val, attr);      return val;  }  /**   * Helper method for property lookups   *   * This method does it all (looking in the hashtable, checking for function   * overrides, creating the function or retrieving from cache, calling   * getValueProperty in case of a non-function property, forwarding to parent if   * unknown property).   *   * Template arguments:   * @param FuncImp the class which implements this object's functions   * @param ThisImp the class of "this". It must implement the getValueProperty(exec,token) method,   * for non-function properties.   * @param ParentImp the class of the parent, to propagate the lookup.   *   * Method arguments:   * @param exec execution state, as usual   * @param propertyName the property we're looking for   * @param table the static hashtable for this class   * @param thisObj "this"   */  template <class FuncImp, class ThisImp, class ParentImp>  inline Value lookupGet(ExecState *exec, const Identifier &propertyName,                         const HashTable* table, const ThisImp* thisObj)  {    const HashEntry* entry = Lookup::findEntry(table, propertyName);    if (!entry) // not found, forward to parent      return thisObj->ParentImp::get(exec, propertyName);    //fprintf(stderr, "lookupGet: found value=%d attr=%d\n", entry->value, entry->attr);    if (entry->attr & Function)      return lookupOrCreateFunction<FuncImp>(exec, propertyName, thisObj, entry->value, entry->params, entry->attr);    return thisObj->getValueProperty(exec, entry->value);  }  /**   * Simplified version of lookupGet in case there are only functions.   * Using this instead of lookupGet prevents 'this' from implementing a dummy getValueProperty.   */  template <class FuncImp, class ParentImp>  inline Value lookupGetFunction(ExecState *exec, const Identifier &propertyName,                         const HashTable* table, const ObjectImp* thisObj)  {    const HashEntry* entry = Lookup::findEntry(table, propertyName);    if (!entry) // not found, forward to parent      return static_cast<const ParentImp *>(thisObj)->ParentImp::get(exec, propertyName);    if (entry->attr & Function)      return lookupOrCreateFunction<FuncImp>(exec, propertyName, thisObj, entry->value, entry->params, entry->attr);    fprintf(stderr, "Function bit not set! Shouldn't happen in lookupGetFunction!\n" );    return Undefined();  }  /**   * Simplified version of lookupGet in case there are no functions, only "values".   * Using this instead of lookupGet removes the need for a FuncImp class.   */  template <class ThisImp, class ParentImp>  inline Value lookupGetValue(ExecState *exec, const Identifier &propertyName,                           const HashTable* table, const ThisImp* thisObj)  {    const HashEntry* entry = Lookup::findEntry(table, propertyName);    if (!entry) // not found, forward to parent      return thisObj->ParentImp::get(exec, propertyName);    if (entry->attr & Function)      fprintf(stderr, "Function bit set! Shouldn't happen in lookupGetValue! propertyName was %s\n", propertyName.ascii() );    return thisObj->getValueProperty(exec, entry->value);  }  /**   * This one is for "put".   * Lookup hash entry for property to be set, and set the value.   */  template <class ThisImp, class ParentImp>  inline void lookupPut(ExecState *exec, const Identifier &propertyName,                        const Value& value, int attr,                        const HashTable* table, const ThisImp* thisObj)  {    const HashEntry* entry = Lookup::findEntry(table, propertyName);    if (!entry) // not found: forward to parent      thisObj->ParentImp::put(exec, propertyName, value, attr);    else if (entry->attr & Function) // function: put as override property      thisObj->ObjectImp::put(exec, propertyName, value, attr);    else if (entry->attr & ReadOnly) // readonly! Can't put!#ifdef KJS_VERBOSE      fprintf(stderr,"WARNING: Attempt to change value of readonly property '%s'\n",propertyName.ascii());#else      ; // do nothing#endif    else      thisObj->putValueProperty(exec, entry->value, value, attr);  }  /*   * List of things to do when porting an objectimp to the 'static hashtable' mechanism:   * - write the hashtable source, between @begin and @end   * - add a rule to build the .lut.h   * - include the .lut.h   * - mention the table in the classinfo (add a classinfo if necessary)   * - write/update the class enum (for the tokens)   * - turn get() into getValueProperty(), put() into putValueProperty(), using a switch and removing funcs   * - write get() and/or put() using a template method   * - cleanup old stuff (e.g. hasProperty)   * - compile, test, commit ;)   */}; // namespace#endif

⌨️ 快捷键说明

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