ReaderDispatch.java 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. // Copyright (c) 2001 Per M.A. Bothner
  2. // This is free software; for terms and warranty disclaimer see ./COPYING.
  3. package gnu.kawa.lispexpr;
  4. import gnu.kawa.util.RangeTable;
  5. import gnu.text.*;
  6. import gnu.mapping.Values;
  7. public class ReaderDispatch extends ReadTableEntry
  8. {
  9. RangeTable table = new RangeTable();
  10. int kind;
  11. public int getKind()
  12. {
  13. return kind;
  14. }
  15. public void set(int key, Object value)
  16. {
  17. table.set(key, key, value);
  18. }
  19. public ReadTableEntry lookup(int key)
  20. {
  21. return (ReadTableEntry) table.lookup(key, null);
  22. }
  23. public ReaderDispatch()
  24. {
  25. kind = ReadTable.TERMINATING_MACRO;
  26. }
  27. public ReaderDispatch(boolean nonTerminating)
  28. {
  29. this.kind = nonTerminating ? ReadTable.NON_TERMINATING_MACRO
  30. : ReadTable.TERMINATING_MACRO;
  31. }
  32. /** Create a fresh instance and initialize it appropriately for Common Lisp.
  33. */
  34. public static ReaderDispatch create(ReadTable rtable, boolean nonTerminating)
  35. {
  36. ReaderDispatch tab = new ReaderDispatch(nonTerminating);
  37. ReaderDispatchMisc entry = ReaderDispatchMisc.getInstance();
  38. tab.set(':', entry);
  39. tab.set('A', entry);
  40. tab.set('B', entry);
  41. tab.set('D', entry);
  42. tab.set('E', entry);
  43. tab.set('F', entry);
  44. tab.set('I', entry);
  45. tab.set('O', entry);
  46. tab.set('R', entry);
  47. tab.set('S', entry);
  48. tab.set('T', entry);
  49. tab.set('U', entry);
  50. tab.set('X', entry);
  51. tab.set(';', entry);
  52. tab.set('!', entry);
  53. tab.set('\\', entry);
  54. tab.set('=', entry);
  55. tab.set('#', entry);
  56. tab.set('*', entry);
  57. /* #ifdef use:java.util.regex */
  58. tab.set('/', entry);
  59. /* #endif */
  60. tab.set('|', ReaderNestedComment.getLispInstance());
  61. tab.set('\'', new ReaderQuote(rtable.makeSymbol("function")));
  62. tab.set('(', new ReaderVector(')'));
  63. /* #ifdef enable:XML */
  64. tab.set('<', new ReaderXmlElement());
  65. /* #endif */
  66. return tab;
  67. }
  68. public Object read (Lexer in, int ch, int count, int sharingIndex)
  69. throws java.io.IOException, SyntaxException
  70. {
  71. count = in.readIntDigits();
  72. ch = in.read();
  73. if (ch < 0)
  74. in.eofError("unexpected EOF after "+ (char) ch);
  75. if (ch < 0x10000)
  76. ch = Character.toUpperCase((char) ch);
  77. ReadTableEntry entry = (ReadTableEntry) table.lookup(ch, null);
  78. if (entry == null)
  79. {
  80. // Effectively subtracting 1 from the column number.
  81. in.error('e', in.getName(),
  82. in.getLineNumber() + 1, in.getColumnNumber(),
  83. "invalid dispatch character '"+((char) ch)+'\'');
  84. return Char.make('?');
  85. }
  86. return entry.read(in, ch, count, sharingIndex);
  87. }
  88. }