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

📄 nodes.java

📁 A framework written in Java for implementing high-level and dynamic languages, compiling them into J
💻 JAVA
字号:
// Copyright (c) 2003  Per M.A. Bothner.// This is free software;  for terms and warranty disclaimer see ./COPYING.package gnu.kawa.xml;import gnu.mapping.Values;import gnu.lists.*;import gnu.xml.*;/* #ifdef use:org.w3c.dom.Node */// import org.w3c.dom.*;/* #endif *//** Manages a sequence of node references. */public class Nodes extends Values  /* #ifdef use:org.w3c.dom.Node */  // implements org.w3c.dom.NodeList  /* #endif */{  /** Number of data elements for a POSITION_PAIR_FOLLOWS node reference. */  static final int POS_SIZE = 5;  int count;  int nesting = 0;  boolean inAttribute;  NodeTree curNode;  XMLFilter curFragment;  public void writePosition (AbstractSequence seq, int ipos)  {    count++;    super.writePosition(seq, ipos);  }  public int find (Object seq)  {    // See if can re-use the object index of the position before the gap.    if (gapStart > 0)      {	int oindex = getIntN(gapStart - POS_SIZE + 1);	if (objects[oindex] == seq)	  return oindex;      }    // See if can re-use the object index of the position after the gap.    if (gapEnd < data.length)      {	int oindex = getIntN(gapEnd + 1);	if (objects[oindex] == seq)	  return oindex;      }    return super.find(seq);  }  public void writeObject(Object v)  {    if (curFragment != null)      {	if (nesting == 0	    && (v instanceof SeqPosition || v instanceof TreeList))	  finishFragment();	else	  {	    curFragment.writeObject(v);	    return;	  }      }    if (v instanceof SeqPosition)      {	SeqPosition seq = (SeqPosition) v;	writePosition(seq.sequence, seq.ipos);	return;      }    if (v instanceof TreeList)      {	TreeList tlist = (TreeList) v;	writePosition(tlist, 0);	return;      }    handleNonNode();    curFragment.writeObject(v);    return;  }  void maybeStartTextNode ()  {    if (curFragment == null)      {        throw new IllegalArgumentException("non-node where node required");      }  }  void handleNonNode ()  {    if (curFragment == null)      {        throw new ClassCastException("atomic value where node is required");      }  }  public void writeFloat (float v)  {    handleNonNode();    curFragment.writeFloat(v);  }  public void writeDouble (double v)  {    handleNonNode();    curFragment.writeDouble(v);  }  public void writeLong(long v)  {    handleNonNode();    curFragment.writeLong(v);  }  public void writeInt(int v)  {    handleNonNode();    curFragment.writeInt(v);  }  public void writeBoolean (boolean v)  {    handleNonNode();    curFragment.writeBoolean(v);  }  public void write (int v)  {    maybeStartTextNode();    curFragment.write(v);  }  /* #ifdef use:java.lang.CharSequence */  public Consumer append (CharSequence csq, int start, int end)  {     maybeStartTextNode();    curFragment.write(csq, start, end);    return this;  }  /* #endif */  public void write(char[] buf, int off, int len)  {    maybeStartTextNode();    curFragment.write(buf, off, len);  }  /* #ifdef use:java.lang.CharSequence */  public void write(CharSequence str, int start, int length)  /* #else */  // public void write(String str, int start, int length)  /* #endif */  {    maybeStartTextNode();    curFragment.write(str, start, length);  }  public void write (String str)  {    maybeStartTextNode();    curFragment.write(str);  }  private void maybeStartNonTextNode ()  {    if (curFragment != null && nesting == 0)      finishFragment();    if (curFragment == null)      startFragment();    nesting++;  }  private void maybeEndNonTextNode ()  {    if (--nesting == 0)      finishFragment();  }  public void startElement (Object type)  {    maybeStartNonTextNode();    curFragment.startElement(type);  }  public void endElement ()  {    curFragment.endElement();    maybeEndNonTextNode();  }  public void startAttribute(Object attrType)  {    maybeStartNonTextNode();    curFragment.startAttribute(attrType);    inAttribute = true;  }  public void endAttribute()  {    if (! inAttribute)      return;    inAttribute = false;    curFragment.endAttribute();    maybeEndNonTextNode();  }  public void writeComment(char[] chars, int offset, int length)  {    maybeStartNonTextNode();    curFragment.writeComment(chars, offset, length);    maybeEndNonTextNode();  }  public void writeCDATA(char[] chars, int offset, int length)  {    maybeStartNonTextNode();    curFragment.writeCDATA(chars, offset, length);  }  public void writeProcessingInstruction(String target, char[] content,					 int offset, int length)  {    maybeStartNonTextNode();    curFragment.writeProcessingInstruction(target, content, offset, length);    maybeEndNonTextNode();  }  public void startDocument()  {    maybeStartNonTextNode();    curFragment.startDocument();  }  public void endDocument()  {    curFragment.endDocument();    maybeEndNonTextNode();  }  public void beginEntity(Object base)  {    maybeStartNonTextNode();    curFragment.beginEntity(base);  }  public void endEntity()  {    curFragment.endEntity();    maybeEndNonTextNode();  }  void startFragment ()  {    curNode = new NodeTree();    curFragment = new XMLFilter(curNode);    writePosition(curNode, 0);  }  void finishFragment ()  {    curNode = null;    curFragment = null;  }  public int size()  {    return count;  }  public int getLength()  {    return count;  }  public Object get (int index)  {    int i = POS_SIZE * index;    if (i >= gapStart)      i += gapEnd - gapStart;    if (i < 0 || i >= data.length)      throw new IndexOutOfBoundsException();    // Inline of: return getPosNext(i << 1)    if (data[i] != POSITION_PAIR_FOLLOWS)      throw new RuntimeException("internal error - unexpected data");    return KNode.make((NodeTree) objects[getIntN(i+1)], getIntN(i+3));  }  /* #ifdef use:org.w3c.dom.Node */  // public Node item(int index)  // {  //   if (index >= count)  //     return null;  //   else  //     return (Node) get(index);  // }  /* #endif */  public Object getPosNext(int ipos)  {    int index = posToDataIndex(ipos);    if (index == data.length)      return Sequence.eofValue;    if (data[index] != POSITION_PAIR_FOLLOWS)      throw new RuntimeException("internal error - unexpected data");    return KNode.make((NodeTree) objects[getIntN(index+1)], getIntN(index+3));  }  /** Optimization of ((SeqPosition) get(index)).sequence.   * However returns null instead of throwing IndexOutOfBoundsException   * if index >= count. */  public AbstractSequence getSeq (int index)  {    int i = POS_SIZE * index;    if (i >= gapStart)      i += gapEnd - gapStart;    if (i < 0 || i >= data.length)      return null;    // Inline of: return getPosNext(i << 1)    if (data[i] != POSITION_PAIR_FOLLOWS)      throw new RuntimeException("internal error - unexpected data");    return (AbstractSequence) objects[getIntN(i+1)];  }  /** Optimization of ((SeqPosition) get(index)). ipos. */  public int getPos (int index)  {    int i = POS_SIZE * index;    if (i >= gapStart)      i += gapEnd - gapStart;    // Inline of: return getPosNext(i << 1)    if (data[i] != POSITION_PAIR_FOLLOWS)      throw new RuntimeException("internal error - unexpected data");    return getIntN(i+3);  }  public static KNode root (NodeTree seq, int ipos)  {    int root;    if (seq.gapStart > TreeList.BEGIN_ENTITY_SIZE        && seq.data[0] == TreeList.BEGIN_ENTITY)      root = TreeList.BEGIN_ENTITY_SIZE << 1;    else      root = 0;    return KNode.make(seq, root);    /*    int end = seq.endPos();    for (;;)      {	int parent = seq.parentPos(ipos);	if (parent == end)	  return KNode.make(seq, ipos);	ipos = parent;      }    */  }}

⌨️ 快捷键说明

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