ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/OpenMD/branches/development/src/mdParser/MDLexer.cpp
(Generate patch)

Comparing:
trunk/src/mdParser/MDLexer.cpp (file contents), Revision 810 by tim, Wed Dec 14 18:02:28 2005 UTC vs.
branches/development/src/mdParser/MDLexer.cpp (file contents), Revision 1776 by gezelter, Thu Aug 9 15:52:59 2012 UTC

# Line 1 | Line 1
1 < /* $ANTLR 2.7.5 (20050406): "MDParser.g" -> "MDLexer.cpp"$ */
1 > /* $ANTLR 2.7.7 (20120725): "MDParser.g" -> "MDLexer.cpp"$ */
2   #include "MDLexer.hpp"
3   #include <antlr/CharBuffer.hpp>
4   #include <antlr/TokenStreamException.hpp>
# Line 30 | Line 30 | void MDLexer::initLiterals()
30  
31   void MDLexer::initLiterals()
32   {
33 <        literals["members"] = 14;
34 <        literals["position"] = 15;
35 <        literals["torsion"] = 10;
36 <        literals["component"] = 4;
37 <        literals["rigidBody"] = 11;
33 >        literals["flucQ"] = 20;
34 >        literals["cutoffGroup"] = 14;
35 >        literals["RNEMD"] = 21;
36 >        literals["rigidBody"] = 13;
37 >        literals["fragment"] = 15;
38          literals["zconstraint"] = 6;
39 <        literals["cutoffGroup"] = 12;
40 <        literals["bend"] = 9;
41 <        literals["orientation"] = 16;
42 <        literals["fragment"] = 13;
43 <        literals["bond"] = 8;
39 >        literals["minimizer"] = 22;
40 >        literals["component"] = 4;
41 >        literals["center"] = 17;
42 >        literals["members"] = 16;
43 >        literals["position"] = 18;
44 >        literals["orientation"] = 19;
45 >        literals["bend"] = 10;
46 >        literals["torsion"] = 11;
47 >        literals["atom"] = 8;
48          literals["molecule"] = 5;
49 <        literals["atom"] = 7;
49 >        literals["restraint"] = 7;
50 >        literals["inversion"] = 12;
51 >        literals["bond"] = 9;
52   }
53  
54   ANTLR_USE_NAMESPACE(antlr)RefToken MDLexer::nextToken()
# Line 149 | Line 155 | ANTLR_USE_NAMESPACE(antlr)RefToken MDLexer::nextToken(
155                                  theRetToken=_returnToken;
156                                  break;
157                          }
152                        case 0x2b /* '+' */ :
153                        case 0x2d /* '-' */ :
154                        case 0x2e /* '.' */ :
155                        case 0x30 /* '0' */ :
156                        case 0x31 /* '1' */ :
157                        case 0x32 /* '2' */ :
158                        case 0x33 /* '3' */ :
159                        case 0x34 /* '4' */ :
160                        case 0x35 /* '5' */ :
161                        case 0x36 /* '6' */ :
162                        case 0x37 /* '7' */ :
163                        case 0x38 /* '8' */ :
164                        case 0x39 /* '9' */ :
165                        {
166                                mNumber(true);
167                                theRetToken=_returnToken;
168                                break;
169                        }
158                          case 0x41 /* 'A' */ :
159                          case 0x42 /* 'B' */ :
160                          case 0x43 /* 'C' */ :
# Line 222 | Line 210 | ANTLR_USE_NAMESPACE(antlr)RefToken MDLexer::nextToken(
210                          case 0x7a /* 'z' */ :
211                          {
212                                  mID(true);
213 +                                theRetToken=_returnToken;
214 +                                break;
215 +                        }
216 +                        case 0x2b /* '+' */ :
217 +                        case 0x2d /* '-' */ :
218 +                        case 0x2e /* '.' */ :
219 +                        case 0x30 /* '0' */ :
220 +                        case 0x31 /* '1' */ :
221 +                        case 0x32 /* '2' */ :
222 +                        case 0x33 /* '3' */ :
223 +                        case 0x34 /* '4' */ :
224 +                        case 0x35 /* '5' */ :
225 +                        case 0x36 /* '6' */ :
226 +                        case 0x37 /* '7' */ :
227 +                        case 0x38 /* '8' */ :
228 +                        case 0x39 /* '9' */ :
229 +                        {
230 +                                mNUM_INT(true);
231                                  theRetToken=_returnToken;
232                                  break;
233                          }
# Line 473 | Line 479 | void MDLexer::mWhitespace(bool _createToken) {
479                  
480                  }
481                  if ( inputState->guessing==0 ) {
482 < #line 259 "MDParser.g"
482 > #line 253 "MDParser.g"
483                          newline();
484 < #line 479 "MDLexer.cpp"
484 > #line 485 "MDLexer.cpp"
485                  }
486                  break;
487          }
# Line 501 | Line 507 | void MDLexer::mWhitespace(bool _createToken) {
507                  
508                  }
509                  if ( inputState->guessing==0 ) {
510 < #line 264 "MDParser.g"
510 > #line 258 "MDParser.g"
511                          printf("CPP_parser.g continuation line detected\n");
512                          deferredNewline();
513 < #line 508 "MDLexer.cpp"
513 > #line 514 "MDLexer.cpp"
514                  }
515                  break;
516          }
# Line 515 | Line 521 | void MDLexer::mWhitespace(bool _createToken) {
521          }
522          }
523          if ( inputState->guessing==0 ) {
524 < #line 267 "MDParser.g"
524 > #line 261 "MDParser.g"
525                  _ttype = ANTLR_USE_NAMESPACE(antlr)Token::SKIP;
526 < #line 521 "MDLexer.cpp"
526 > #line 527 "MDLexer.cpp"
527          }
528          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
529             _token = makeToken(_ttype);
# Line 541 | Line 547 | void MDLexer::mComment(bool _createToken) {
547                  else if ((LA(1) == 0xa /* '\n' */  || LA(1) == 0xd /* '\r' */ )) {
548                          mEndOfLine(false);
549                          if ( inputState->guessing==0 ) {
550 < #line 274 "MDParser.g"
550 > #line 268 "MDParser.g"
551                                  deferredNewline();
552 < #line 547 "MDLexer.cpp"
552 > #line 553 "MDLexer.cpp"
553                          }
554                  }
555                  else if ((_tokenSet_0.member(LA(1)))) {
# Line 552 | Line 558 | void MDLexer::mComment(bool _createToken) {
558                          }
559                  }
560                  else {
561 <                        goto _loop78;
561 >                        goto _loop96;
562                  }
563                  
564          }
565 <        _loop78:;
565 >        _loop96:;
566          } // ( ... )*
567          match("*/");
568          if ( inputState->guessing==0 ) {
569 < #line 277 "MDParser.g"
569 > #line 271 "MDParser.g"
570                  _ttype = ANTLR_USE_NAMESPACE(antlr)Token::SKIP;
571 < #line 566 "MDLexer.cpp"
571 > #line 572 "MDLexer.cpp"
572          }
573          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
574             _token = makeToken(_ttype);
# Line 614 | Line 620 | void MDLexer::mCPPComment(bool _createToken) {
620                          }
621                  }
622                  else {
623 <                        goto _loop82;
623 >                        goto _loop100;
624                  }
625                  
626          }
627 <        _loop82:;
627 >        _loop100:;
628          } // ( ... )*
629          mEndOfLine(false);
630          if ( inputState->guessing==0 ) {
631 < #line 283 "MDParser.g"
631 > #line 277 "MDParser.g"
632                  _ttype = ANTLR_USE_NAMESPACE(antlr)Token::SKIP; newline();
633 < #line 628 "MDLexer.cpp"
633 > #line 634 "MDLexer.cpp"
634          }
635          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
636             _token = makeToken(_ttype);
# Line 642 | Line 648 | void MDLexer::mPREPROC_DIRECTIVE(bool _createToken) {
648          match('#' /* charlit */ );
649          mLineDirective(false);
650          if ( inputState->guessing==0 ) {
651 < #line 290 "MDParser.g"
651 > #line 284 "MDParser.g"
652                  _ttype = ANTLR_USE_NAMESPACE(antlr)Token::SKIP; newline();
653 < #line 648 "MDLexer.cpp"
653 > #line 654 "MDLexer.cpp"
654          }
655          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
656             _token = makeToken(_ttype);
# Line 662 | Line 668 | void MDLexer::mLineDirective(bool _createToken) {
668          ANTLR_USE_NAMESPACE(antlr)RefToken sl;
669          
670          if ( inputState->guessing==0 ) {
671 < #line 296 "MDParser.g"
671 > #line 290 "MDParser.g"
672                  
673                  deferredLineCount = 0;
674                  
675 < #line 670 "MDLexer.cpp"
675 > #line 676 "MDLexer.cpp"
676          }
677          {
678          switch ( LA(1)) {
# Line 688 | Line 694 | void MDLexer::mLineDirective(bool _createToken) {
694          }
695          }
696          { // ( ... )+
697 <        int _cnt87=0;
697 >        int _cnt105=0;
698          for (;;) {
699                  if ((LA(1) == 0x9 /* '\t' */  || LA(1) == 0xc /* '\14' */  || LA(1) == 0x20 /* ' ' */ )) {
700                          mSpace(false);
701                  }
702                  else {
703 <                        if ( _cnt87>=1 ) { goto _loop87; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
703 >                        if ( _cnt105>=1 ) { goto _loop105; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
704                  }
705                  
706 <                _cnt87++;
706 >                _cnt105++;
707          }
708 <        _loop87:;
708 >        _loop105:;
709          }  // ( ... )+
710          mDecimal(true);
711          n=_returnToken;
712          if ( inputState->guessing==0 ) {
713 < #line 301 "MDParser.g"
714 <                setLine(oopse::lexi_cast<int>(n->getText()) - 1);
715 < #line 710 "MDLexer.cpp"
713 > #line 295 "MDParser.g"
714 >                setLine(OpenMD::lexi_cast<int>(n->getText()) - 1);
715 > #line 716 "MDLexer.cpp"
716          }
717          { // ( ... )+
718 <        int _cnt89=0;
718 >        int _cnt107=0;
719          for (;;) {
720                  if ((LA(1) == 0x9 /* '\t' */  || LA(1) == 0xc /* '\14' */  || LA(1) == 0x20 /* ' ' */ )) {
721                          mSpace(false);
722                  }
723                  else {
724 <                        if ( _cnt89>=1 ) { goto _loop89; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
724 >                        if ( _cnt107>=1 ) { goto _loop107; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
725                  }
726                  
727 <                _cnt89++;
727 >                _cnt107++;
728          }
729 <        _loop89:;
729 >        _loop107:;
730          }  // ( ... )+
731          {
732          mStringLiteral(true);
733          sl=_returnToken;
734          }
735          if ( inputState->guessing==0 ) {
736 < #line 303 "MDParser.g"
736 > #line 297 "MDParser.g"
737                  std::string filename = sl->getText().substr(1,sl->getText().length()-2); observer->notify(filename);
738 < #line 733 "MDLexer.cpp"
738 > #line 739 "MDLexer.cpp"
739          }
740          { // ( ... )*
741          for (;;) {
742                  if ((LA(1) == 0x9 /* '\t' */  || LA(1) == 0xc /* '\14' */  || LA(1) == 0x20 /* ' ' */ )) {
743                          { // ( ... )+
744 <                        int _cnt93=0;
744 >                        int _cnt111=0;
745                          for (;;) {
746                                  if ((LA(1) == 0x9 /* '\t' */  || LA(1) == 0xc /* '\14' */  || LA(1) == 0x20 /* ' ' */ )) {
747                                          mSpace(false);
748                                  }
749                                  else {
750 <                                        if ( _cnt93>=1 ) { goto _loop93; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
750 >                                        if ( _cnt111>=1 ) { goto _loop111; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
751                                  }
752                                  
753 <                                _cnt93++;
753 >                                _cnt111++;
754                          }
755 <                        _loop93:;
755 >                        _loop111:;
756                          }  // ( ... )+
757                          mDecimal(false);
758                  }
759                  else {
760 <                        goto _loop94;
760 >                        goto _loop112;
761                  }
762                  
763          }
764 <        _loop94:;
764 >        _loop112:;
765          } // ( ... )*
766          mEndOfLine(false);
767          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
# Line 808 | Line 814 | void MDLexer::mDecimal(bool _createToken) {
814          ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
815          
816          { // ( ... )+
817 <        int _cnt119=0;
817 >        int _cnt142=0;
818          for (;;) {
819                  if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
820                          matchRange('0','9');
821                  }
822                  else {
823 <                        if ( _cnt119>=1 ) { goto _loop119; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
823 >                        if ( _cnt142>=1 ) { goto _loop142; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
824                  }
825                  
826 <                _cnt119++;
826 >                _cnt142++;
827          }
828 <        _loop119:;
828 >        _loop142:;
829          }  // ( ... )+
830          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
831             _token = makeToken(_ttype);
# Line 857 | Line 863 | void MDLexer::mStringLiteral(bool _createToken) {
863                          
864                          }
865                          if ( inputState->guessing==0 ) {
866 < #line 343 "MDParser.g"
866 > #line 337 "MDParser.g"
867                                  deferredNewline();
868 < #line 863 "MDLexer.cpp"
868 > #line 869 "MDLexer.cpp"
869                          }
870                  }
871                  else if ((_tokenSet_3.member(LA(1)))) {
# Line 868 | Line 874 | void MDLexer::mStringLiteral(bool _createToken) {
874                          }
875                  }
876                  else {
877 <                        goto _loop104;
877 >                        goto _loop122;
878                  }
879                  
880          }
881 <        _loop104:;
881 >        _loop122:;
882          } // ( ... )*
883          match('\"' /* charlit */ );
884          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
# Line 1032 | Line 1038 | void MDLexer::mEscape(bool _createToken) {
1038          {
1039                  match('x' /* charlit */ );
1040                  { // ( ... )+
1041 <                int _cnt115=0;
1041 >                int _cnt133=0;
1042                  for (;;) {
1043                          if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ )) && (_tokenSet_1.member(LA(2))) && (true)) {
1044                                  mDigit(false);
# Line 1044 | Line 1050 | void MDLexer::mEscape(bool _createToken) {
1050                                  matchRange('A','F');
1051                          }
1052                          else {
1053 <                                if ( _cnt115>=1 ) { goto _loop115; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1053 >                                if ( _cnt133>=1 ) { goto _loop133; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1054                          }
1055                          
1056 <                        _cnt115++;
1056 >                        _cnt133++;
1057                  }
1058 <                _loop115:;
1058 >                _loop133:;
1059                  }  // ( ... )+
1060                  break;
1061          }
# Line 1081 | Line 1087 | void MDLexer::mDigit(bool _createToken) {
1087          _saveIndex=0;
1088   }
1089  
1090 < void MDLexer::mLongSuffix(bool _createToken) {
1090 > void MDLexer::mVocabulary(bool _createToken) {
1091          int _ttype; ANTLR_USE_NAMESPACE(antlr)RefToken _token; ANTLR_USE_NAMESPACE(std)string::size_type _begin = text.length();
1092 <        _ttype = LongSuffix;
1092 >        _ttype = Vocabulary;
1093          ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
1094          
1095 <        switch ( LA(1)) {
1090 <        case 0x6c /* 'l' */ :
1091 <        {
1092 <                match('l' /* charlit */ );
1093 <                break;
1094 <        }
1095 <        case 0x4c /* 'L' */ :
1096 <        {
1097 <                match('L' /* charlit */ );
1098 <                break;
1099 <        }
1100 <        default:
1101 <        {
1102 <                throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1103 <        }
1104 <        }
1095 >        matchRange('\3',static_cast<unsigned char>('\377'));
1096          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
1097             _token = makeToken(_ttype);
1098             _token->setText(text.substr(_begin, text.length()-_begin));
# Line 1110 | Line 1101 | void MDLexer::mLongSuffix(bool _createToken) {
1101          _saveIndex=0;
1102   }
1103  
1104 < void MDLexer::mUnsignedSuffix(bool _createToken) {
1104 > void MDLexer::mID(bool _createToken) {
1105          int _ttype; ANTLR_USE_NAMESPACE(antlr)RefToken _token; ANTLR_USE_NAMESPACE(std)string::size_type _begin = text.length();
1106 <        _ttype = UnsignedSuffix;
1106 >        _ttype = ID;
1107          ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
1108          
1109 +        {
1110          switch ( LA(1)) {
1111 +        case 0x61 /* 'a' */ :
1112 +        case 0x62 /* 'b' */ :
1113 +        case 0x63 /* 'c' */ :
1114 +        case 0x64 /* 'd' */ :
1115 +        case 0x65 /* 'e' */ :
1116 +        case 0x66 /* 'f' */ :
1117 +        case 0x67 /* 'g' */ :
1118 +        case 0x68 /* 'h' */ :
1119 +        case 0x69 /* 'i' */ :
1120 +        case 0x6a /* 'j' */ :
1121 +        case 0x6b /* 'k' */ :
1122 +        case 0x6c /* 'l' */ :
1123 +        case 0x6d /* 'm' */ :
1124 +        case 0x6e /* 'n' */ :
1125 +        case 0x6f /* 'o' */ :
1126 +        case 0x70 /* 'p' */ :
1127 +        case 0x71 /* 'q' */ :
1128 +        case 0x72 /* 'r' */ :
1129 +        case 0x73 /* 's' */ :
1130 +        case 0x74 /* 't' */ :
1131          case 0x75 /* 'u' */ :
1132 +        case 0x76 /* 'v' */ :
1133 +        case 0x77 /* 'w' */ :
1134 +        case 0x78 /* 'x' */ :
1135 +        case 0x79 /* 'y' */ :
1136 +        case 0x7a /* 'z' */ :
1137          {
1138 <                match('u' /* charlit */ );
1138 >                matchRange('a','z');
1139                  break;
1140          }
1141 +        case 0x41 /* 'A' */ :
1142 +        case 0x42 /* 'B' */ :
1143 +        case 0x43 /* 'C' */ :
1144 +        case 0x44 /* 'D' */ :
1145 +        case 0x45 /* 'E' */ :
1146 +        case 0x46 /* 'F' */ :
1147 +        case 0x47 /* 'G' */ :
1148 +        case 0x48 /* 'H' */ :
1149 +        case 0x49 /* 'I' */ :
1150 +        case 0x4a /* 'J' */ :
1151 +        case 0x4b /* 'K' */ :
1152 +        case 0x4c /* 'L' */ :
1153 +        case 0x4d /* 'M' */ :
1154 +        case 0x4e /* 'N' */ :
1155 +        case 0x4f /* 'O' */ :
1156 +        case 0x50 /* 'P' */ :
1157 +        case 0x51 /* 'Q' */ :
1158 +        case 0x52 /* 'R' */ :
1159 +        case 0x53 /* 'S' */ :
1160 +        case 0x54 /* 'T' */ :
1161          case 0x55 /* 'U' */ :
1162 +        case 0x56 /* 'V' */ :
1163 +        case 0x57 /* 'W' */ :
1164 +        case 0x58 /* 'X' */ :
1165 +        case 0x59 /* 'Y' */ :
1166 +        case 0x5a /* 'Z' */ :
1167          {
1168 <                match('U' /* charlit */ );
1168 >                matchRange('A','Z');
1169                  break;
1170          }
1171 <        default:
1171 >        case 0x5f /* '_' */ :
1172          {
1173 <                throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1132 <        }
1133 <        }
1134 <        if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
1135 <           _token = makeToken(_ttype);
1136 <           _token->setText(text.substr(_begin, text.length()-_begin));
1137 <        }
1138 <        _returnToken = _token;
1139 <        _saveIndex=0;
1140 < }
1141 <
1142 < void MDLexer::mFloatSuffix(bool _createToken) {
1143 <        int _ttype; ANTLR_USE_NAMESPACE(antlr)RefToken _token; ANTLR_USE_NAMESPACE(std)string::size_type _begin = text.length();
1144 <        _ttype = FloatSuffix;
1145 <        ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
1146 <        
1147 <        switch ( LA(1)) {
1148 <        case 0x66 /* 'f' */ :
1149 <        {
1150 <                match('f' /* charlit */ );
1173 >                match('_' /* charlit */ );
1174                  break;
1175          }
1153        case 0x46 /* 'F' */ :
1154        {
1155                match('F' /* charlit */ );
1156                break;
1157        }
1176          default:
1177          {
1178                  throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1179          }
1180          }
1181 +        }
1182 +        { // ( ... )*
1183 +        for (;;) {
1184 +                switch ( LA(1)) {
1185 +                case 0x61 /* 'a' */ :
1186 +                case 0x62 /* 'b' */ :
1187 +                case 0x63 /* 'c' */ :
1188 +                case 0x64 /* 'd' */ :
1189 +                case 0x65 /* 'e' */ :
1190 +                case 0x66 /* 'f' */ :
1191 +                case 0x67 /* 'g' */ :
1192 +                case 0x68 /* 'h' */ :
1193 +                case 0x69 /* 'i' */ :
1194 +                case 0x6a /* 'j' */ :
1195 +                case 0x6b /* 'k' */ :
1196 +                case 0x6c /* 'l' */ :
1197 +                case 0x6d /* 'm' */ :
1198 +                case 0x6e /* 'n' */ :
1199 +                case 0x6f /* 'o' */ :
1200 +                case 0x70 /* 'p' */ :
1201 +                case 0x71 /* 'q' */ :
1202 +                case 0x72 /* 'r' */ :
1203 +                case 0x73 /* 's' */ :
1204 +                case 0x74 /* 't' */ :
1205 +                case 0x75 /* 'u' */ :
1206 +                case 0x76 /* 'v' */ :
1207 +                case 0x77 /* 'w' */ :
1208 +                case 0x78 /* 'x' */ :
1209 +                case 0x79 /* 'y' */ :
1210 +                case 0x7a /* 'z' */ :
1211 +                {
1212 +                        matchRange('a','z');
1213 +                        break;
1214 +                }
1215 +                case 0x41 /* 'A' */ :
1216 +                case 0x42 /* 'B' */ :
1217 +                case 0x43 /* 'C' */ :
1218 +                case 0x44 /* 'D' */ :
1219 +                case 0x45 /* 'E' */ :
1220 +                case 0x46 /* 'F' */ :
1221 +                case 0x47 /* 'G' */ :
1222 +                case 0x48 /* 'H' */ :
1223 +                case 0x49 /* 'I' */ :
1224 +                case 0x4a /* 'J' */ :
1225 +                case 0x4b /* 'K' */ :
1226 +                case 0x4c /* 'L' */ :
1227 +                case 0x4d /* 'M' */ :
1228 +                case 0x4e /* 'N' */ :
1229 +                case 0x4f /* 'O' */ :
1230 +                case 0x50 /* 'P' */ :
1231 +                case 0x51 /* 'Q' */ :
1232 +                case 0x52 /* 'R' */ :
1233 +                case 0x53 /* 'S' */ :
1234 +                case 0x54 /* 'T' */ :
1235 +                case 0x55 /* 'U' */ :
1236 +                case 0x56 /* 'V' */ :
1237 +                case 0x57 /* 'W' */ :
1238 +                case 0x58 /* 'X' */ :
1239 +                case 0x59 /* 'Y' */ :
1240 +                case 0x5a /* 'Z' */ :
1241 +                {
1242 +                        matchRange('A','Z');
1243 +                        break;
1244 +                }
1245 +                case 0x5f /* '_' */ :
1246 +                {
1247 +                        match('_' /* charlit */ );
1248 +                        break;
1249 +                }
1250 +                case 0x30 /* '0' */ :
1251 +                case 0x31 /* '1' */ :
1252 +                case 0x32 /* '2' */ :
1253 +                case 0x33 /* '3' */ :
1254 +                case 0x34 /* '4' */ :
1255 +                case 0x35 /* '5' */ :
1256 +                case 0x36 /* '6' */ :
1257 +                case 0x37 /* '7' */ :
1258 +                case 0x38 /* '8' */ :
1259 +                case 0x39 /* '9' */ :
1260 +                {
1261 +                        matchRange('0','9');
1262 +                        break;
1263 +                }
1264 +                default:
1265 +                {
1266 +                        goto _loop138;
1267 +                }
1268 +                }
1269 +        }
1270 +        _loop138:;
1271 +        } // ( ... )*
1272 +        _ttype = testLiteralsTable(_ttype);
1273          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
1274             _token = makeToken(_ttype);
1275             _token->setText(text.substr(_begin, text.length()-_begin));
# Line 1168 | Line 1278 | void MDLexer::mFloatSuffix(bool _createToken) {
1278          _saveIndex=0;
1279   }
1280  
1281 < void MDLexer::mExponent(bool _createToken) {
1281 > void MDLexer::mHEX_DIGIT(bool _createToken) {
1282          int _ttype; ANTLR_USE_NAMESPACE(antlr)RefToken _token; ANTLR_USE_NAMESPACE(std)string::size_type _begin = text.length();
1283 <        _ttype = Exponent;
1283 >        _ttype = HEX_DIGIT;
1284          ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
1285          
1286          {
1287          switch ( LA(1)) {
1178        case 0x65 /* 'e' */ :
1179        {
1180                match('e' /* charlit */ );
1181                break;
1182        }
1183        case 0x45 /* 'E' */ :
1184        {
1185                match('E' /* charlit */ );
1186                break;
1187        }
1188        case 0x64 /* 'd' */ :
1189        {
1190                match('d' /* charlit */ );
1191                break;
1192        }
1193        case 0x44 /* 'D' */ :
1194        {
1195                match('D' /* charlit */ );
1196                break;
1197        }
1198        default:
1199        {
1200                throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1201        }
1202        }
1203        }
1204        {
1205        switch ( LA(1)) {
1206        case 0x2b /* '+' */ :
1207        {
1208                match('+' /* charlit */ );
1209                break;
1210        }
1211        case 0x2d /* '-' */ :
1212        {
1213                match('-' /* charlit */ );
1214                break;
1215        }
1288          case 0x30 /* '0' */ :
1289          case 0x31 /* '1' */ :
1290          case 0x32 /* '2' */ :
# Line 1224 | Line 1296 | void MDLexer::mExponent(bool _createToken) {
1296          case 0x38 /* '8' */ :
1297          case 0x39 /* '9' */ :
1298          {
1299 +                matchRange('0','9');
1300                  break;
1301          }
1302 +        case 0x41 /* 'A' */ :
1303 +        case 0x42 /* 'B' */ :
1304 +        case 0x43 /* 'C' */ :
1305 +        case 0x44 /* 'D' */ :
1306 +        case 0x45 /* 'E' */ :
1307 +        case 0x46 /* 'F' */ :
1308 +        {
1309 +                matchRange('A','F');
1310 +                break;
1311 +        }
1312 +        case 0x61 /* 'a' */ :
1313 +        case 0x62 /* 'b' */ :
1314 +        case 0x63 /* 'c' */ :
1315 +        case 0x64 /* 'd' */ :
1316 +        case 0x65 /* 'e' */ :
1317 +        case 0x66 /* 'f' */ :
1318 +        {
1319 +                matchRange('a','f');
1320 +                break;
1321 +        }
1322          default:
1323          {
1324                  throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1325          }
1326          }
1327          }
1235        { // ( ... )+
1236        int _cnt127=0;
1237        for (;;) {
1238                if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1239                        mDigit(false);
1240                }
1241                else {
1242                        if ( _cnt127>=1 ) { goto _loop127; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1243                }
1244                
1245                _cnt127++;
1246        }
1247        _loop127:;
1248        }  // ( ... )+
1328          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
1329             _token = makeToken(_ttype);
1330             _token->setText(text.substr(_begin, text.length()-_begin));
# Line 1254 | Line 1333 | void MDLexer::mExponent(bool _createToken) {
1333          _saveIndex=0;
1334   }
1335  
1336 < void MDLexer::mVocabulary(bool _createToken) {
1336 > void MDLexer::mNUM_INT(bool _createToken) {
1337          int _ttype; ANTLR_USE_NAMESPACE(antlr)RefToken _token; ANTLR_USE_NAMESPACE(std)string::size_type _begin = text.length();
1338 <        _ttype = Vocabulary;
1338 >        _ttype = NUM_INT;
1339          ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
1340 +        ANTLR_USE_NAMESPACE(antlr)RefToken f1;
1341 +        ANTLR_USE_NAMESPACE(antlr)RefToken f2;
1342 +        ANTLR_USE_NAMESPACE(antlr)RefToken f3;
1343 +        ANTLR_USE_NAMESPACE(antlr)RefToken f4;
1344 + #line 430 "MDParser.g"
1345          
1346 <        matchRange('\3',static_cast<unsigned char>('\377'));
1347 <        if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
1348 <           _token = makeToken(_ttype);
1349 <           _token->setText(text.substr(_begin, text.length()-_begin));
1266 <        }
1267 <        _returnToken = _token;
1268 <        _saveIndex=0;
1269 < }
1270 <
1271 < void MDLexer::mNumber(bool _createToken) {
1272 <        int _ttype; ANTLR_USE_NAMESPACE(antlr)RefToken _token; ANTLR_USE_NAMESPACE(std)string::size_type _begin = text.length();
1273 <        _ttype = Number;
1274 <        ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
1346 >                        bool isDecimal = false;
1347 >                        ANTLR_USE_NAMESPACE(antlr)RefToken t = ANTLR_USE_NAMESPACE(antlr)nullToken;
1348 >                
1349 > #line 1350 "MDLexer.cpp"
1350          
1351          {
1352          switch ( LA(1)) {
# Line 1306 | Line 1381 | void MDLexer::mNumber(bool _createToken) {
1381          }
1382          }
1383          {
1384 <        bool synPredMatched136 = false;
1385 <        if ((((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ )) && (_tokenSet_6.member(LA(2))) && (true))) {
1386 <                int _m136 = mark();
1387 <                synPredMatched136 = true;
1388 <                inputState->guessing++;
1389 <                try {
1390 <                        {
1384 >        switch ( LA(1)) {
1385 >        case 0x2e /* '.' */ :
1386 >        {
1387 >                match('.' /* charlit */ );
1388 >                if ( inputState->guessing==0 ) {
1389 > #line 437 "MDParser.g"
1390 >                        _ttype = DOT;
1391 > #line 1392 "MDLexer.cpp"
1392 >                }
1393 >                {
1394 >                if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1395                          { // ( ... )+
1396 <                        int _cnt134=0;
1396 >                        int _cnt150=0;
1397                          for (;;) {
1398                                  if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1399 <                                        mDigit(false);
1399 >                                        matchRange('0','9');
1400                                  }
1401                                  else {
1402 <                                        if ( _cnt134>=1 ) { goto _loop134; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1402 >                                        if ( _cnt150>=1 ) { goto _loop150; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1403                                  }
1404                                  
1405 <                                _cnt134++;
1405 >                                _cnt150++;
1406                          }
1407 <                        _loop134:;
1407 >                        _loop150:;
1408                          }  // ( ... )+
1409                          {
1410 <                        switch ( LA(1)) {
1411 <                        case 0x2e /* '.' */ :
1333 <                        {
1334 <                                match('.' /* charlit */ );
1335 <                                break;
1410 >                        if ((_tokenSet_6.member(LA(1))) && (_tokenSet_7.member(LA(2)))) {
1411 >                                mEXPONENT(false);
1412                          }
1413 <                        case 0x65 /* 'e' */ :
1338 <                        {
1339 <                                match('e' /* charlit */ );
1340 <                                break;
1413 >                        else {
1414                          }
1415 <                        case 0x45 /* 'E' */ :
1343 <                        {
1344 <                                match('E' /* charlit */ );
1345 <                                break;
1415 >                        
1416                          }
1347                        case 0x64 /* 'd' */ :
1417                          {
1418 <                                match('d' /* charlit */ );
1419 <                                break;
1420 <                        }
1421 <                        case 0x44 /* 'D' */ :
1422 <                        {
1423 <                                match('D' /* charlit */ );
1424 <                                break;
1356 <                        }
1357 <                        default:
1358 <                        {
1359 <                                throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1360 <                        }
1361 <                        }
1362 <                        }
1363 <                        }
1364 <                }
1365 <                catch (ANTLR_USE_NAMESPACE(antlr)RecognitionException& pe) {
1366 <                        synPredMatched136 = false;
1367 <                }
1368 <                rewind(_m136);
1369 <                inputState->guessing--;
1370 <        }
1371 <        if ( synPredMatched136 ) {
1372 <                { // ( ... )+
1373 <                int _cnt138=0;
1374 <                for (;;) {
1375 <                        if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1376 <                                mDigit(false);
1377 <                        }
1378 <                        else {
1379 <                                if ( _cnt138>=1 ) { goto _loop138; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1380 <                        }
1381 <                        
1382 <                        _cnt138++;
1383 <                }
1384 <                _loop138:;
1385 <                }  // ( ... )+
1386 <                {
1387 <                switch ( LA(1)) {
1388 <                case 0x2e /* '.' */ :
1389 <                {
1390 <                        match('.' /* charlit */ );
1391 <                        { // ( ... )*
1392 <                        for (;;) {
1393 <                                if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1394 <                                        mDigit(false);
1418 >                        if ((_tokenSet_8.member(LA(1)))) {
1419 >                                mFLOAT_SUFFIX(true);
1420 >                                f1=_returnToken;
1421 >                                if ( inputState->guessing==0 ) {
1422 > #line 438 "MDParser.g"
1423 >                                        t=f1;
1424 > #line 1425 "MDLexer.cpp"
1425                                  }
1396                                else {
1397                                        goto _loop141;
1398                                }
1399                                
1426                          }
1401                        _loop141:;
1402                        } // ( ... )*
1403                        {
1404                        if ((_tokenSet_7.member(LA(1)))) {
1405                                mExponent(false);
1406                        }
1427                          else {
1428                          }
1429                          
1430                          }
1431                          if ( inputState->guessing==0 ) {
1432 < #line 450 "MDParser.g"
1433 <                                _ttype = FLOATONE;
1434 < #line 1415 "MDLexer.cpp"
1432 > #line 439 "MDParser.g"
1433 >                                
1434 >                                                                        if ( t &&
1435 >                                                                                  (t->getText().find('f') != ANTLR_USE_NAMESPACE(std)string::npos ||
1436 >                                                                                        t->getText().find('F') != ANTLR_USE_NAMESPACE(std)string::npos ) ) {
1437 >                                                                                _ttype = NUM_FLOAT;
1438 >                                                                        }
1439 >                                                                        else {
1440 >                                                                                _ttype = NUM_DOUBLE; // assume double
1441 >                                                                        }
1442 >                                                                
1443 > #line 1444 "MDLexer.cpp"
1444                          }
1416                        break;
1445                  }
1446 <                case 0x44 /* 'D' */ :
1419 <                case 0x45 /* 'E' */ :
1420 <                case 0x64 /* 'd' */ :
1421 <                case 0x65 /* 'e' */ :
1422 <                {
1423 <                        mExponent(false);
1424 <                        if ( inputState->guessing==0 ) {
1425 < #line 451 "MDParser.g"
1426 <                                _ttype = FLOATTWO;
1427 < #line 1428 "MDLexer.cpp"
1428 <                        }
1429 <                        break;
1446 >                else {
1447                  }
1448 <                default:
1432 <                {
1433 <                        throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1448 >                
1449                  }
1450 <                }
1436 <                }
1437 <                {
1438 <                switch ( LA(1)) {
1439 <                case 0x46 /* 'F' */ :
1440 <                case 0x66 /* 'f' */ :
1441 <                {
1442 <                        mFloatSuffix(false);
1443 <                        break;
1444 <                }
1445 <                case 0x4c /* 'L' */ :
1446 <                case 0x6c /* 'l' */ :
1447 <                {
1448 <                        mLongSuffix(false);
1449 <                        break;
1450 <                }
1451 <                default:
1452 <                        {
1453 <                        }
1454 <                }
1455 <                }
1450 >                break;
1451          }
1452 <        else if ((LA(1) == 0x30 /* '0' */ ) && (LA(2) == 0x58 /* 'X' */  || LA(2) == 0x78 /* 'x' */ )) {
1453 <                match('0' /* charlit */ );
1452 >        case 0x30 /* '0' */ :
1453 >        case 0x31 /* '1' */ :
1454 >        case 0x32 /* '2' */ :
1455 >        case 0x33 /* '3' */ :
1456 >        case 0x34 /* '4' */ :
1457 >        case 0x35 /* '5' */ :
1458 >        case 0x36 /* '6' */ :
1459 >        case 0x37 /* '7' */ :
1460 >        case 0x38 /* '8' */ :
1461 >        case 0x39 /* '9' */ :
1462 >        {
1463                  {
1464                  switch ( LA(1)) {
1465 <                case 0x78 /* 'x' */ :
1465 >                case 0x30 /* '0' */ :
1466                  {
1467 <                        match('x' /* charlit */ );
1468 <                        break;
1469 <                }
1470 <                case 0x58 /* 'X' */ :
1471 <                {
1468 <                        match('X' /* charlit */ );
1469 <                        break;
1470 <                }
1471 <                default:
1472 <                {
1473 <                        throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1474 <                }
1475 <                }
1476 <                }
1477 <                { // ( ... )+
1478 <                int _cnt159=0;
1479 <                for (;;) {
1480 <                        switch ( LA(1)) {
1481 <                        case 0x61 /* 'a' */ :
1482 <                        case 0x62 /* 'b' */ :
1483 <                        case 0x63 /* 'c' */ :
1484 <                        case 0x64 /* 'd' */ :
1485 <                        case 0x65 /* 'e' */ :
1486 <                        case 0x66 /* 'f' */ :
1487 <                        {
1488 <                                matchRange('a','f');
1489 <                                break;
1467 >                        match('0' /* charlit */ );
1468 >                        if ( inputState->guessing==0 ) {
1469 > #line 451 "MDParser.g"
1470 >                                isDecimal = true;
1471 > #line 1472 "MDLexer.cpp"
1472                          }
1491                        case 0x41 /* 'A' */ :
1492                        case 0x42 /* 'B' */ :
1493                        case 0x43 /* 'C' */ :
1494                        case 0x44 /* 'D' */ :
1495                        case 0x45 /* 'E' */ :
1496                        case 0x46 /* 'F' */ :
1473                          {
1474 <                                matchRange('A','F');
1475 <                                break;
1474 >                        if ((LA(1) == 0x58 /* 'X' */  || LA(1) == 0x78 /* 'x' */ )) {
1475 >                                {
1476 >                                switch ( LA(1)) {
1477 >                                case 0x78 /* 'x' */ :
1478 >                                {
1479 >                                        match('x' /* charlit */ );
1480 >                                        break;
1481 >                                }
1482 >                                case 0x58 /* 'X' */ :
1483 >                                {
1484 >                                        match('X' /* charlit */ );
1485 >                                        break;
1486 >                                }
1487 >                                default:
1488 >                                {
1489 >                                        throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1490 >                                }
1491 >                                }
1492 >                                }
1493 >                                { // ( ... )+
1494 >                                int _cnt157=0;
1495 >                                for (;;) {
1496 >                                        if ((_tokenSet_9.member(LA(1))) && (true) && (true)) {
1497 >                                                mHEX_DIGIT(false);
1498 >                                        }
1499 >                                        else {
1500 >                                                if ( _cnt157>=1 ) { goto _loop157; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1501 >                                        }
1502 >                                        
1503 >                                        _cnt157++;
1504 >                                }
1505 >                                _loop157:;
1506 >                                }  // ( ... )+
1507                          }
1508 <                        case 0x30 /* '0' */ :
1509 <                        case 0x31 /* '1' */ :
1510 <                        case 0x32 /* '2' */ :
1511 <                        case 0x33 /* '3' */ :
1512 <                        case 0x34 /* '4' */ :
1513 <                        case 0x35 /* '5' */ :
1514 <                        case 0x36 /* '6' */ :
1515 <                        case 0x37 /* '7' */ :
1516 <                        case 0x38 /* '8' */ :
1517 <                        case 0x39 /* '9' */ :
1518 <                        {
1519 <                                mDigit(false);
1520 <                                break;
1508 >                        else {
1509 >                                bool synPredMatched162 = false;
1510 >                                if ((((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ )) && (true) && (true))) {
1511 >                                        int _m162 = mark();
1512 >                                        synPredMatched162 = true;
1513 >                                        inputState->guessing++;
1514 >                                        try {
1515 >                                                {
1516 >                                                { // ( ... )+
1517 >                                                int _cnt160=0;
1518 >                                                for (;;) {
1519 >                                                        if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1520 >                                                                matchRange('0','9');
1521 >                                                        }
1522 >                                                        else {
1523 >                                                                if ( _cnt160>=1 ) { goto _loop160; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1524 >                                                        }
1525 >                                                        
1526 >                                                        _cnt160++;
1527 >                                                }
1528 >                                                _loop160:;
1529 >                                                }  // ( ... )+
1530 >                                                {
1531 >                                                if ((_tokenSet_6.member(LA(1))) && (_tokenSet_7.member(LA(2)))) {
1532 >                                                        mEXPONENT(false);
1533 >                                                }
1534 >                                                else if ((LA(1) == 0x2e /* '.' */ )) {
1535 >                                                        match('.' /* charlit */ );
1536 >                                                }
1537 >                                                else if ((_tokenSet_8.member(LA(1))) && (true)) {
1538 >                                                        mFLOAT_SUFFIX(false);
1539 >                                                }
1540 >                                                else {
1541 >                                                        throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1542 >                                                }
1543 >                                                
1544 >                                                }
1545 >                                                }
1546 >                                        }
1547 >                                        catch (ANTLR_USE_NAMESPACE(antlr)RecognitionException& pe) {
1548 >                                                synPredMatched162 = false;
1549 >                                        }
1550 >                                        rewind(_m162);
1551 >                                        inputState->guessing--;
1552 >                                }
1553 >                                if ( synPredMatched162 ) {
1554 >                                        { // ( ... )+
1555 >                                        int _cnt164=0;
1556 >                                        for (;;) {
1557 >                                                if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1558 >                                                        matchRange('0','9');
1559 >                                                }
1560 >                                                else {
1561 >                                                        if ( _cnt164>=1 ) { goto _loop164; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1562 >                                                }
1563 >                                                
1564 >                                                _cnt164++;
1565 >                                        }
1566 >                                        _loop164:;
1567 >                                        }  // ( ... )+
1568 >                                }
1569 >                                else if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x37 /* '7' */ )) && (true) && (true)) {
1570 >                                        { // ( ... )+
1571 >                                        int _cnt166=0;
1572 >                                        for (;;) {
1573 >                                                if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x37 /* '7' */ ))) {
1574 >                                                        matchRange('0','7');
1575 >                                                }
1576 >                                                else {
1577 >                                                        if ( _cnt166>=1 ) { goto _loop166; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1578 >                                                }
1579 >                                                
1580 >                                                _cnt166++;
1581 >                                        }
1582 >                                        _loop166:;
1583 >                                        }  // ( ... )+
1584 >                                }
1585 >                                else {
1586 >                                }
1587                          }
1515                        default:
1516                        {
1517                                if ( _cnt159>=1 ) { goto _loop159; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1588                          }
1589 <                        }
1520 <                        _cnt159++;
1589 >                        break;
1590                  }
1591 <                _loop159:;
1592 <                }  // ( ... )+
1593 <                { // ( ... )*
1594 <                for (;;) {
1595 <                        switch ( LA(1)) {
1596 <                        case 0x4c /* 'L' */ :
1597 <                        case 0x6c /* 'l' */ :
1591 >                case 0x31 /* '1' */ :
1592 >                case 0x32 /* '2' */ :
1593 >                case 0x33 /* '3' */ :
1594 >                case 0x34 /* '4' */ :
1595 >                case 0x35 /* '5' */ :
1596 >                case 0x36 /* '6' */ :
1597 >                case 0x37 /* '7' */ :
1598 >                case 0x38 /* '8' */ :
1599 >                case 0x39 /* '9' */ :
1600 >                {
1601                          {
1602 <                                mLongSuffix(false);
1531 <                                break;
1602 >                        matchRange('1','9');
1603                          }
1604 <                        case 0x55 /* 'U' */ :
1534 <                        case 0x75 /* 'u' */ :
1535 <                        {
1536 <                                mUnsignedSuffix(false);
1537 <                                break;
1538 <                        }
1539 <                        default:
1540 <                        {
1541 <                                goto _loop161;
1542 <                        }
1543 <                        }
1544 <                }
1545 <                _loop161:;
1546 <                } // ( ... )*
1547 <                if ( inputState->guessing==0 ) {
1548 < #line 479 "MDParser.g"
1549 <                        _ttype = HEXADECIMALINT;
1550 < #line 1551 "MDLexer.cpp"
1551 <                }
1552 <        }
1553 <        else if ((LA(1) == 0x2e /* '.' */ )) {
1554 <                match('.' /* charlit */ );
1555 <                if ( inputState->guessing==0 ) {
1556 < #line 457 "MDParser.g"
1557 <                        _ttype = DOT;
1558 < #line 1559 "MDLexer.cpp"
1559 <                }
1560 <                {
1561 <                if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1562 <                        { // ( ... )+
1563 <                        int _cnt146=0;
1604 >                        { // ( ... )*
1605                          for (;;) {
1606                                  if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1607 <                                        mDigit(false);
1607 >                                        matchRange('0','9');
1608                                  }
1609                                  else {
1610 <                                        if ( _cnt146>=1 ) { goto _loop146; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1610 >                                        goto _loop169;
1611                                  }
1612                                  
1572                                _cnt146++;
1613                          }
1614 <                        _loop146:;
1615 <                        }  // ( ... )+
1576 <                        {
1577 <                        if ((_tokenSet_7.member(LA(1)))) {
1578 <                                mExponent(false);
1579 <                        }
1580 <                        else {
1581 <                        }
1582 <                        
1583 <                        }
1614 >                        _loop169:;
1615 >                        } // ( ... )*
1616                          if ( inputState->guessing==0 ) {
1617 < #line 458 "MDParser.g"
1618 <                                _ttype = FLOATONE;
1619 < #line 1588 "MDLexer.cpp"
1617 > #line 468 "MDParser.g"
1618 >                                isDecimal=true;
1619 > #line 1620 "MDLexer.cpp"
1620                          }
1621 <                        {
1590 <                        switch ( LA(1)) {
1591 <                        case 0x46 /* 'F' */ :
1592 <                        case 0x66 /* 'f' */ :
1593 <                        {
1594 <                                mFloatSuffix(false);
1595 <                                break;
1596 <                        }
1597 <                        case 0x4c /* 'L' */ :
1598 <                        case 0x6c /* 'l' */ :
1599 <                        {
1600 <                                mLongSuffix(false);
1601 <                                break;
1602 <                        }
1603 <                        default:
1604 <                                {
1605 <                                }
1606 <                        }
1607 <                        }
1621 >                        break;
1622                  }
1623 <                else {
1623 >                default:
1624 >                {
1625 >                        throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1626                  }
1611                
1627                  }
1613        }
1614        else if ((LA(1) == 0x30 /* '0' */ ) && (true) && (true)) {
1615                match('0' /* charlit */ );
1616                { // ( ... )*
1617                for (;;) {
1618                        if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x37 /* '7' */ ))) {
1619                                matchRange('0','7');
1620                        }
1621                        else {
1622                                goto _loop150;
1623                        }
1624                        
1628                  }
1629 <                _loop150:;
1630 <                } // ( ... )*
1631 <                { // ( ... )*
1629 <                for (;;) {
1629 >                {
1630 >                if ((LA(1) == 0x4c /* 'L' */  || LA(1) == 0x6c /* 'l' */ )) {
1631 >                        {
1632                          switch ( LA(1)) {
1631                        case 0x4c /* 'L' */ :
1633                          case 0x6c /* 'l' */ :
1634                          {
1635 <                                mLongSuffix(false);
1635 >                                match('l' /* charlit */ );
1636                                  break;
1637                          }
1638 <                        case 0x55 /* 'U' */ :
1638 <                        case 0x75 /* 'u' */ :
1638 >                        case 0x4c /* 'L' */ :
1639                          {
1640 <                                mUnsignedSuffix(false);
1640 >                                match('L' /* charlit */ );
1641                                  break;
1642                          }
1643                          default:
1644                          {
1645 <                                goto _loop152;
1645 >                                throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1646                          }
1647                          }
1648                }
1649                _loop152:;
1650                } // ( ... )*
1651                if ( inputState->guessing==0 ) {
1652 #line 468 "MDParser.g"
1653                        _ttype = OCTALINT;
1654 #line 1655 "MDLexer.cpp"
1655                }
1656        }
1657        else if (((LA(1) >= 0x31 /* '1' */  && LA(1) <= 0x39 /* '9' */ )) && (true) && (true)) {
1658                matchRange('1','9');
1659                { // ( ... )*
1660                for (;;) {
1661                        if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1662                                mDigit(false);
1648                          }
1649 <                        else {
1650 <                                goto _loop154;
1649 >                        if ( inputState->guessing==0 ) {
1650 > #line 470 "MDParser.g"
1651 >                                _ttype = NUM_LONG;
1652 > #line 1653 "MDLexer.cpp"
1653                          }
1667                        
1654                  }
1655 <                _loop154:;
1670 <                } // ( ... )*
1671 <                { // ( ... )*
1672 <                for (;;) {
1673 <                        switch ( LA(1)) {
1674 <                        case 0x4c /* 'L' */ :
1675 <                        case 0x6c /* 'l' */ :
1655 >                else if (((_tokenSet_10.member(LA(1))))&&(isDecimal)) {
1656                          {
1657 <                                mLongSuffix(false);
1658 <                                break;
1657 >                        if ((_tokenSet_6.member(LA(1))) && (_tokenSet_7.member(LA(2)))) {
1658 >                                mEXPONENT(false);
1659 >                                {
1660 >                                if ((_tokenSet_8.member(LA(1)))) {
1661 >                                        mFLOAT_SUFFIX(true);
1662 >                                        f3=_returnToken;
1663 >                                        if ( inputState->guessing==0 ) {
1664 > #line 475 "MDParser.g"
1665 >                                                t=f3;
1666 > #line 1667 "MDLexer.cpp"
1667 >                                        }
1668 >                                }
1669 >                                else {
1670 >                                }
1671 >                                
1672 >                                }
1673                          }
1674 <                        case 0x55 /* 'U' */ :
1675 <                        case 0x75 /* 'u' */ :
1676 <                        {
1677 <                                mUnsignedSuffix(false);
1678 <                                break;
1679 <                        }
1680 <                        default:
1681 <                        {
1682 <                                goto _loop156;
1674 >                        else if ((LA(1) == 0x2e /* '.' */ )) {
1675 >                                match('.' /* charlit */ );
1676 >                                { // ( ... )*
1677 >                                for (;;) {
1678 >                                        if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1679 >                                                matchRange('0','9');
1680 >                                        }
1681 >                                        else {
1682 >                                                goto _loop174;
1683 >                                        }
1684 >                                        
1685 >                                }
1686 >                                _loop174:;
1687 >                                } // ( ... )*
1688 >                                {
1689 >                                if ((_tokenSet_6.member(LA(1))) && (_tokenSet_7.member(LA(2)))) {
1690 >                                        mEXPONENT(false);
1691 >                                }
1692 >                                else {
1693 >                                }
1694 >                                
1695 >                                }
1696 >                                {
1697 >                                if ((_tokenSet_8.member(LA(1)))) {
1698 >                                        mFLOAT_SUFFIX(true);
1699 >                                        f2=_returnToken;
1700 >                                        if ( inputState->guessing==0 ) {
1701 > #line 474 "MDParser.g"
1702 >                                                t=f2;
1703 > #line 1704 "MDLexer.cpp"
1704 >                                        }
1705 >                                }
1706 >                                else {
1707 >                                }
1708 >                                
1709 >                                }
1710                          }
1711 +                        else if ((_tokenSet_8.member(LA(1))) && (true)) {
1712 +                                mFLOAT_SUFFIX(true);
1713 +                                f4=_returnToken;
1714 +                                if ( inputState->guessing==0 ) {
1715 + #line 476 "MDParser.g"
1716 +                                        t=f4;
1717 + #line 1718 "MDLexer.cpp"
1718 +                                }
1719                          }
1720 +                        else {
1721 +                                throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1722 +                        }
1723 +                        
1724 +                        }
1725 +                        if ( inputState->guessing==0 ) {
1726 + #line 478 "MDParser.g"
1727 +                                
1728 +                                                                        if ( t &&
1729 +                                                                                  (t->getText().find('f') != ANTLR_USE_NAMESPACE(std)string::npos ||
1730 +                                                                                        t->getText().find('F') != ANTLR_USE_NAMESPACE(std)string::npos ) ) {
1731 +                                                                                _ttype = NUM_FLOAT;
1732 +                                                                        }
1733 +                                                                        else {
1734 +                                                                                _ttype = NUM_DOUBLE; // assume double
1735 +                                                                        }
1736 +                                                                
1737 + #line 1738 "MDLexer.cpp"
1738 +                        }
1739                  }
1740 <                _loop156:;
1693 <                } // ( ... )*
1694 <                if ( inputState->guessing==0 ) {
1695 < #line 473 "MDParser.g"
1696 <                        _ttype = DECIMALINT;
1697 < #line 1698 "MDLexer.cpp"
1740 >                else {
1741                  }
1742 +                
1743 +                }
1744 +                break;
1745          }
1746 <        else {
1746 >        default:
1747 >        {
1748                  throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1749          }
1703        
1750          }
1751 +        }
1752          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
1753             _token = makeToken(_ttype);
1754             _token->setText(text.substr(_begin, text.length()-_begin));
# Line 1710 | Line 1757 | void MDLexer::mNumber(bool _createToken) {
1757          _saveIndex=0;
1758   }
1759  
1760 < void MDLexer::mID(bool _createToken) {
1760 > void MDLexer::mEXPONENT(bool _createToken) {
1761          int _ttype; ANTLR_USE_NAMESPACE(antlr)RefToken _token; ANTLR_USE_NAMESPACE(std)string::size_type _begin = text.length();
1762 <        _ttype = ID;
1762 >        _ttype = EXPONENT;
1763          ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
1764          
1765          {
1766          switch ( LA(1)) {
1720        case 0x61 /* 'a' */ :
1721        case 0x62 /* 'b' */ :
1722        case 0x63 /* 'c' */ :
1723        case 0x64 /* 'd' */ :
1767          case 0x65 /* 'e' */ :
1725        case 0x66 /* 'f' */ :
1726        case 0x67 /* 'g' */ :
1727        case 0x68 /* 'h' */ :
1728        case 0x69 /* 'i' */ :
1729        case 0x6a /* 'j' */ :
1730        case 0x6b /* 'k' */ :
1731        case 0x6c /* 'l' */ :
1732        case 0x6d /* 'm' */ :
1733        case 0x6e /* 'n' */ :
1734        case 0x6f /* 'o' */ :
1735        case 0x70 /* 'p' */ :
1736        case 0x71 /* 'q' */ :
1737        case 0x72 /* 'r' */ :
1738        case 0x73 /* 's' */ :
1739        case 0x74 /* 't' */ :
1740        case 0x75 /* 'u' */ :
1741        case 0x76 /* 'v' */ :
1742        case 0x77 /* 'w' */ :
1743        case 0x78 /* 'x' */ :
1744        case 0x79 /* 'y' */ :
1745        case 0x7a /* 'z' */ :
1768          {
1769 <                matchRange('a','z');
1769 >                match('e' /* charlit */ );
1770                  break;
1771          }
1750        case 0x41 /* 'A' */ :
1751        case 0x42 /* 'B' */ :
1752        case 0x43 /* 'C' */ :
1753        case 0x44 /* 'D' */ :
1772          case 0x45 /* 'E' */ :
1755        case 0x46 /* 'F' */ :
1756        case 0x47 /* 'G' */ :
1757        case 0x48 /* 'H' */ :
1758        case 0x49 /* 'I' */ :
1759        case 0x4a /* 'J' */ :
1760        case 0x4b /* 'K' */ :
1761        case 0x4c /* 'L' */ :
1762        case 0x4d /* 'M' */ :
1763        case 0x4e /* 'N' */ :
1764        case 0x4f /* 'O' */ :
1765        case 0x50 /* 'P' */ :
1766        case 0x51 /* 'Q' */ :
1767        case 0x52 /* 'R' */ :
1768        case 0x53 /* 'S' */ :
1769        case 0x54 /* 'T' */ :
1770        case 0x55 /* 'U' */ :
1771        case 0x56 /* 'V' */ :
1772        case 0x57 /* 'W' */ :
1773        case 0x58 /* 'X' */ :
1774        case 0x59 /* 'Y' */ :
1775        case 0x5a /* 'Z' */ :
1773          {
1774 <                matchRange('A','Z');
1774 >                match('E' /* charlit */ );
1775                  break;
1776          }
1777 <        case 0x5f /* '_' */ :
1777 >        case 0x64 /* 'd' */ :
1778          {
1779 <                match('_' /* charlit */ );
1779 >                match('d' /* charlit */ );
1780                  break;
1781          }
1782 +        case 0x44 /* 'D' */ :
1783 +        {
1784 +                match('D' /* charlit */ );
1785 +                break;
1786 +        }
1787          default:
1788          {
1789                  throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1790          }
1791          }
1792          }
1793 <        { // ( ... )*
1793 >        {
1794 >        switch ( LA(1)) {
1795 >        case 0x2b /* '+' */ :
1796 >        {
1797 >                match('+' /* charlit */ );
1798 >                break;
1799 >        }
1800 >        case 0x2d /* '-' */ :
1801 >        {
1802 >                match('-' /* charlit */ );
1803 >                break;
1804 >        }
1805 >        case 0x30 /* '0' */ :
1806 >        case 0x31 /* '1' */ :
1807 >        case 0x32 /* '2' */ :
1808 >        case 0x33 /* '3' */ :
1809 >        case 0x34 /* '4' */ :
1810 >        case 0x35 /* '5' */ :
1811 >        case 0x36 /* '6' */ :
1812 >        case 0x37 /* '7' */ :
1813 >        case 0x38 /* '8' */ :
1814 >        case 0x39 /* '9' */ :
1815 >        {
1816 >                break;
1817 >        }
1818 >        default:
1819 >        {
1820 >                throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1821 >        }
1822 >        }
1823 >        }
1824 >        { // ( ... )+
1825 >        int _cnt182=0;
1826          for (;;) {
1827 <                switch ( LA(1)) {
1794 <                case 0x61 /* 'a' */ :
1795 <                case 0x62 /* 'b' */ :
1796 <                case 0x63 /* 'c' */ :
1797 <                case 0x64 /* 'd' */ :
1798 <                case 0x65 /* 'e' */ :
1799 <                case 0x66 /* 'f' */ :
1800 <                case 0x67 /* 'g' */ :
1801 <                case 0x68 /* 'h' */ :
1802 <                case 0x69 /* 'i' */ :
1803 <                case 0x6a /* 'j' */ :
1804 <                case 0x6b /* 'k' */ :
1805 <                case 0x6c /* 'l' */ :
1806 <                case 0x6d /* 'm' */ :
1807 <                case 0x6e /* 'n' */ :
1808 <                case 0x6f /* 'o' */ :
1809 <                case 0x70 /* 'p' */ :
1810 <                case 0x71 /* 'q' */ :
1811 <                case 0x72 /* 'r' */ :
1812 <                case 0x73 /* 's' */ :
1813 <                case 0x74 /* 't' */ :
1814 <                case 0x75 /* 'u' */ :
1815 <                case 0x76 /* 'v' */ :
1816 <                case 0x77 /* 'w' */ :
1817 <                case 0x78 /* 'x' */ :
1818 <                case 0x79 /* 'y' */ :
1819 <                case 0x7a /* 'z' */ :
1820 <                {
1821 <                        matchRange('a','z');
1822 <                        break;
1823 <                }
1824 <                case 0x41 /* 'A' */ :
1825 <                case 0x42 /* 'B' */ :
1826 <                case 0x43 /* 'C' */ :
1827 <                case 0x44 /* 'D' */ :
1828 <                case 0x45 /* 'E' */ :
1829 <                case 0x46 /* 'F' */ :
1830 <                case 0x47 /* 'G' */ :
1831 <                case 0x48 /* 'H' */ :
1832 <                case 0x49 /* 'I' */ :
1833 <                case 0x4a /* 'J' */ :
1834 <                case 0x4b /* 'K' */ :
1835 <                case 0x4c /* 'L' */ :
1836 <                case 0x4d /* 'M' */ :
1837 <                case 0x4e /* 'N' */ :
1838 <                case 0x4f /* 'O' */ :
1839 <                case 0x50 /* 'P' */ :
1840 <                case 0x51 /* 'Q' */ :
1841 <                case 0x52 /* 'R' */ :
1842 <                case 0x53 /* 'S' */ :
1843 <                case 0x54 /* 'T' */ :
1844 <                case 0x55 /* 'U' */ :
1845 <                case 0x56 /* 'V' */ :
1846 <                case 0x57 /* 'W' */ :
1847 <                case 0x58 /* 'X' */ :
1848 <                case 0x59 /* 'Y' */ :
1849 <                case 0x5a /* 'Z' */ :
1850 <                {
1851 <                        matchRange('A','Z');
1852 <                        break;
1853 <                }
1854 <                case 0x5f /* '_' */ :
1855 <                {
1856 <                        match('_' /* charlit */ );
1857 <                        break;
1858 <                }
1859 <                case 0x30 /* '0' */ :
1860 <                case 0x31 /* '1' */ :
1861 <                case 0x32 /* '2' */ :
1862 <                case 0x33 /* '3' */ :
1863 <                case 0x34 /* '4' */ :
1864 <                case 0x35 /* '5' */ :
1865 <                case 0x36 /* '6' */ :
1866 <                case 0x37 /* '7' */ :
1867 <                case 0x38 /* '8' */ :
1868 <                case 0x39 /* '9' */ :
1869 <                {
1827 >                if (((LA(1) >= 0x30 /* '0' */  && LA(1) <= 0x39 /* '9' */ ))) {
1828                          matchRange('0','9');
1871                        break;
1829                  }
1830 <                default:
1831 <                {
1875 <                        goto _loop165;
1830 >                else {
1831 >                        if ( _cnt182>=1 ) { goto _loop182; } else {throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());}
1832                  }
1833 <                }
1833 >                
1834 >                _cnt182++;
1835          }
1836 <        _loop165:;
1837 <        } // ( ... )*
1881 <        _ttype = testLiteralsTable(_ttype);
1836 >        _loop182:;
1837 >        }  // ( ... )+
1838          if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
1839             _token = makeToken(_ttype);
1840             _token->setText(text.substr(_begin, text.length()-_begin));
# Line 1887 | Line 1843 | void MDLexer::mID(bool _createToken) {
1843          _saveIndex=0;
1844   }
1845  
1846 + void MDLexer::mFLOAT_SUFFIX(bool _createToken) {
1847 +        int _ttype; ANTLR_USE_NAMESPACE(antlr)RefToken _token; ANTLR_USE_NAMESPACE(std)string::size_type _begin = text.length();
1848 +        _ttype = FLOAT_SUFFIX;
1849 +        ANTLR_USE_NAMESPACE(std)string::size_type _saveIndex;
1850 +        
1851 +        switch ( LA(1)) {
1852 +        case 0x66 /* 'f' */ :
1853 +        {
1854 +                match('f' /* charlit */ );
1855 +                break;
1856 +        }
1857 +        case 0x46 /* 'F' */ :
1858 +        {
1859 +                match('F' /* charlit */ );
1860 +                break;
1861 +        }
1862 +        case 0x64 /* 'd' */ :
1863 +        {
1864 +                match('d' /* charlit */ );
1865 +                break;
1866 +        }
1867 +        case 0x44 /* 'D' */ :
1868 +        {
1869 +                match('D' /* charlit */ );
1870 +                break;
1871 +        }
1872 +        default:
1873 +        {
1874 +                throw ANTLR_USE_NAMESPACE(antlr)NoViableAltForCharException(LA(1), getFilename(), getLine(), getColumn());
1875 +        }
1876 +        }
1877 +        if ( _createToken && _token==ANTLR_USE_NAMESPACE(antlr)nullToken && _ttype!=ANTLR_USE_NAMESPACE(antlr)Token::SKIP ) {
1878 +           _token = makeToken(_ttype);
1879 +           _token->setText(text.substr(_begin, text.length()-_begin));
1880 +        }
1881 +        _returnToken = _token;
1882 +        _saveIndex=0;
1883 + }
1884  
1885 +
1886   const unsigned long MDLexer::_tokenSet_0_data_[] = { 4294958079UL, 4294966271UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1887   // 0x0 0x1 0x2 0x3 0x4 0x5 0x6 0x7 0x8 0x9 0xb 0xc 0xe 0xf 0x10 0x11 0x12
1888   // 0x13 0x14 0x15 0x16 0x17 0x18 0x19 0x1a 0x1b 0x1c 0x1d 0x1e 0x1f   !
1889 < // \" # $ % & \' ( ) + , - . / 0 1 2 3 4 5
1889 > // \" # $ % & \' ( ) + , - . / 0 1 2 3 4 5 6 7 8
1890   const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_0(_tokenSet_0_data_,16);
1891   const unsigned long MDLexer::_tokenSet_1_data_[] = { 4294958079UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1892   // 0x0 0x1 0x2 0x3 0x4 0x5 0x6 0x7 0x8 0x9 0xb 0xc 0xe 0xf 0x10 0x11 0x12
1893   // 0x13 0x14 0x15 0x16 0x17 0x18 0x19 0x1a 0x1b 0x1c 0x1d 0x1e 0x1f   !
1894 < // \" # $ % & \' ( ) * + , - . / 0 1 2 3 4 5
1894 > // \" # $ % & \' ( ) * + , - . / 0 1 2 3 4 5 6 7 8
1895   const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_1(_tokenSet_1_data_,16);
1896   const unsigned long MDLexer::_tokenSet_2_data_[] = { 0UL, 2164195460UL, 268435456UL, 22298694UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1897 < // \" \' 0 1 2 3 4 5
1897 > // \" \' 0 1 2 3 4 5 6 7
1898   const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_2(_tokenSet_2_data_,10);
1899   const unsigned long MDLexer::_tokenSet_3_data_[] = { 4294958079UL, 4294967291UL, 4026531839UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1900   // 0x0 0x1 0x2 0x3 0x4 0x5 0x6 0x7 0x8 0x9 0xb 0xc 0xe 0xf 0x10 0x11 0x12
1901   // 0x13 0x14 0x15 0x16 0x17 0x18 0x19 0x1a 0x1b 0x1c 0x1d 0x1e 0x1f   !
1902 < // # $ % & \' ( ) * + , - . / 0 1 2 3 4 5
1902 > // # $ % & \' ( ) * + , - . / 0 1 2 3 4 5 6 7 8
1903   const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_3(_tokenSet_3_data_,16);
1904   const unsigned long MDLexer::_tokenSet_4_data_[] = { 0UL, 67043456UL, 126UL, 126UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1905 < // \' 0 1 2 3 4 5
1905 > // \' 0 1 2 3 4 5 6 7 8
1906   const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_4(_tokenSet_4_data_,10);
1907   const unsigned long MDLexer::_tokenSet_5_data_[] = { 4294967295UL, 4294967167UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 4294967295UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1908   // 0x0 0x1 0x2 0x3 0x4 0x5 0x6 0x7 0x8 0x9 0xa 0xb 0xc 0xd 0xe 0xf 0x10
1909   // 0x11 0x12 0x13 0x14 0x15 0x16 0x17 0x18 0x19 0x1a 0x1b 0x1c 0x1d 0x1e
1910 < // 0x1f   ! \" # $ % & ( ) * + , - . / 0 1 2 3 4 5
1910 > // 0x1f   ! \" # $ % & ( ) * + , - . / 0 1 2 3 4 5 6 7 8
1911   const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_5(_tokenSet_5_data_,16);
1912 < const unsigned long MDLexer::_tokenSet_6_data_[] = { 0UL, 67059712UL, 48UL, 48UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1918 < // . 0 1 2 3 4 5
1912 > const unsigned long MDLexer::_tokenSet_6_data_[] = { 0UL, 0UL, 48UL, 48UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1913   const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_6(_tokenSet_6_data_,10);
1914 < const unsigned long MDLexer::_tokenSet_7_data_[] = { 0UL, 0UL, 48UL, 48UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1914 > const unsigned long MDLexer::_tokenSet_7_data_[] = { 0UL, 67053568UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1915 > // + - 0 1 2 3 4 5 6 7 8
1916   const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_7(_tokenSet_7_data_,10);
1917 + const unsigned long MDLexer::_tokenSet_8_data_[] = { 0UL, 0UL, 80UL, 80UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1918 + const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_8(_tokenSet_8_data_,10);
1919 + const unsigned long MDLexer::_tokenSet_9_data_[] = { 0UL, 67043328UL, 126UL, 126UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1920 + // 0 1 2 3 4 5 6 7 8
1921 + const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_9(_tokenSet_9_data_,10);
1922 + const unsigned long MDLexer::_tokenSet_10_data_[] = { 0UL, 16384UL, 112UL, 112UL, 0UL, 0UL, 0UL, 0UL, 0UL, 0UL };
1923 + // .
1924 + const ANTLR_USE_NAMESPACE(antlr)BitSet MDLexer::_tokenSet_10(_tokenSet_10_data_,10);
1925  

Comparing:
trunk/src/mdParser/MDLexer.cpp (property svn:keywords), Revision 810 by tim, Wed Dec 14 18:02:28 2005 UTC vs.
branches/development/src/mdParser/MDLexer.cpp (property svn:keywords), Revision 1776 by gezelter, Thu Aug 9 15:52:59 2012 UTC

# Line 0 | Line 1
1 + Author Id Revision Date

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines