Diff for /Amaya/amaya/XHTMLbuilder.c between versions 1.22 and 1.23

version 1.22, 2000/10/05 08:11:25 version 1.23, 2000/10/23 09:27:12
Line 7 Line 7
   
 /*  /*
  *   *
  * html2thot parses a HTML file and builds the corresponding abstract tree   * Builds the corresponding abstract tree for a Thot document of type HTML.
  * for a Thot document of type HTML.  
  *   *
  * Authors: L. Carcone   * Authors: L. Carcone
  *          V. Quint    *          V. Quint 
Line 37 Line 36
 /* maximum length of a Thot structure schema name */  /* maximum length of a Thot structure schema name */
 #define MAX_SS_NAME_LENGTH 32  #define MAX_SS_NAME_LENGTH 32
   
 XhtmlEntity        XhtmlEntityTable[] =  XmlEntity     XhtmlEntityTable[] =
 {  {
 /* This table MUST be in alphabetical order */  /* This table MUST be in alphabetical order */
 {TEXT("AElig"), 198},   /* latin capital letter AE = */   {TEXT("AElig"), 198, TEXT(' ')},   /* latin capital letter AE = */ 
                         /* latin capital ligature AE, U+00C6 ISOlat1 */                                     /* latin capital ligature AE, U+00C6 ISOlat1 */
 {TEXT("Aacute"), 193},  /* latin capital letter A with acute, U+00C1 ISOlat1 */  {TEXT("Aacute"), 193, TEXT(' ')},  /* latin capital letter A with acute, U+00C1 ISOlat1 */
 {TEXT("Acirc"), 194},   /* latin capital letter A with circumflex, U+00C2 ISOlat1 */  {TEXT("Acirc"), 194, TEXT(' ')},   /* latin capital letter A with circumflex, U+00C2 ISOlat1 */
 {TEXT("Agrave"), 192},  /* latin capital letter A with grave = */  {TEXT("Agrave"), 192, TEXT(' ')},  /* latin capital letter A with grave = */
                         /* latin capital letter A grave, U+00C0 ISOlat1 */                                     /* latin capital letter A grave, U+00C0 ISOlat1 */
 {TEXT("Alpha"), 913},   /* greek capital letter alpha, U+0391 */  {TEXT("Alpha"), 913, TEXT(' ')},   /* greek capital letter alpha, U+0391 */
 {TEXT("Aring"), 197},   /* latin capital letter A with ring above = */   {TEXT("Aring"), 197, TEXT(' ')},   /* latin capital letter A with ring above = */ 
                         /* latin capital letter A ring, U+00C5 ISOlat1 */                                     /* latin capital letter A ring, U+00C5 ISOlat1 */
 {TEXT("Atilde"), 195},  /* latin capital letter A with tilde, U+00C3 ISOlat1 */  {TEXT("Atilde"), 195, TEXT(' ')},  /* latin capital letter A with tilde, U+00C3 ISOlat1 */
 {TEXT("Auml"), 196},    /* latin capital letter A with diaeresis, U+00C4 ISOlat1 */  {TEXT("Auml"), 196, TEXT(' ')},    /* latin capital letter A with diaeresis, U+00C4 ISOlat1 */
 {TEXT("Beta"), 914},    /* greek capital letter beta, U+0392 */  {TEXT("Beta"), 914, TEXT(' ')},    /* greek capital letter beta, U+0392 */
 {TEXT("Ccedil"), 199},  /* latin capital letter C with cedilla, U+00C7 ISOlat1 */  {TEXT("Ccedil"), 199, TEXT(' ')},  /* latin capital letter C with cedilla, U+00C7 ISOlat1 */
 {TEXT("Chi"), 935},     /* greek capital letter chi, U+03A7 */  {TEXT("Chi"), 935, TEXT(' ')},     /* greek capital letter chi, U+03A7 */
 {TEXT("Dagger"), 8225}, /* double dagger, U+2021 ISOpub */  {TEXT("Dagger"), 8225, TEXT(' ')}, /* double dagger, U+2021 ISOpub */
 {TEXT("Delta"), 916},   /* greek capital letter delta, U+0394 ISOgrk3 */  {TEXT("Delta"), 916, TEXT(' ')},   /* greek capital letter delta, U+0394 ISOgrk3 */
 {TEXT("ETH"), 208},     /* latin capital letter ETH, U+00D0 ISOlat1 */  {TEXT("ETH"), 208, TEXT(' ')},     /* latin capital letter ETH, U+00D0 ISOlat1 */
 {TEXT("Eacute"), 201},  /* latin capital letter E with acute, U+00C9 ISOlat1 */  {TEXT("Eacute"), 201, TEXT(' ')},  /* latin capital letter E with acute, U+00C9 ISOlat1 */
 {TEXT("Ecirc"), 202},   /* latin capital letter E with circumflex, U+00CA ISOlat1 */  {TEXT("Ecirc"), 202, TEXT(' ')},   /* latin capital letter E with circumflex, U+00CA ISOlat1 */
 {TEXT("Egrave"), 200},  /* latin capital letter E with grave, U+00C8 ISOlat1 */  {TEXT("Egrave"), 200, TEXT(' ')},  /* latin capital letter E with grave, U+00C8 ISOlat1 */
 {TEXT("Epsilon"), 917}, /* greek capital letter epsilon, U+0395 */  {TEXT("Epsilon"), 917, TEXT(' ')}, /* greek capital letter epsilon, U+0395 */
 {TEXT("Eta"), 919},     /* greek capital letter eta, U+0397 */  {TEXT("Eta"), 919, TEXT(' ')},     /* greek capital letter eta, U+0397 */
 {TEXT("Euml"), 203},    /* latin capital letter E with diaeresis, U+00CB ISOlat1 */  {TEXT("Euml"), 203, TEXT(' ')},    /* latin capital letter E with diaeresis, U+00CB ISOlat1 */
 {TEXT("Gamma"), 915},   /* greek capital letter gamma, U+0393 ISOgrk3 */  {TEXT("Gamma"), 915, TEXT(' ')},   /* greek capital letter gamma, U+0393 ISOgrk3 */
 {TEXT("Iacute"), 205},  /* latin capital letter I with acute, U+00CD ISOlat1 */  {TEXT("Iacute"), 205, TEXT(' ')},  /* latin capital letter I with acute, U+00CD ISOlat1 */
 {TEXT("Icirc"), 206},   /* latin capital letter I with circumflex, U+00CE ISOlat1 */  {TEXT("Icirc"), 206, TEXT(' ')},   /* latin capital letter I with circumflex, U+00CE ISOlat1 */
 {TEXT("Igrave"), 204},  /* latin capital letter I with grave, U+00CC ISOlat1 */  {TEXT("Igrave"), 204, TEXT(' ')},  /* latin capital letter I with grave, U+00CC ISOlat1 */
 {TEXT("Iota"), 921},    /* greek capital letter iota, U+0399 */  {TEXT("Iota"), 921, TEXT(' ')},    /* greek capital letter iota, U+0399 */
 {TEXT("Iuml"), 207},    /* latin capital letter I with diaeresis, U+00CF ISOlat1 */  {TEXT("Iuml"), 207, TEXT(' ')},    /* latin capital letter I with diaeresis, U+00CF ISOlat1 */
 {TEXT("Kappa"), 922},   /* greek capital letter kappa, U+039A */  {TEXT("Kappa"), 922, TEXT(' ')},   /* greek capital letter kappa, U+039A */
 {TEXT("Lambda"), 923},  /* greek capital letter lambda, U+039B ISOgrk3 */  {TEXT("Lambda"), 923, TEXT(' ')},  /* greek capital letter lambda, U+039B ISOgrk3 */
 {TEXT("Mu"), 924},      /* greek capital letter mu, U+039C */  {TEXT("Mu"), 924, TEXT(' ')},      /* greek capital letter mu, U+039C */
 {TEXT("Ntilde"), 209},  /* latin capital letter N with tilde, U+00D1 ISOlat1 */  {TEXT("Ntilde"), 209, TEXT(' ')},  /* latin capital letter N with tilde, U+00D1 ISOlat1 */
 {TEXT("Nu"), 925},      /* greek capital letter nu, U+039D */  {TEXT("Nu"), 925, TEXT(' ')},      /* greek capital letter nu, U+039D */
 {TEXT("OElig"), 338},   /* latin capital ligature OE, U+0152 ISOlat2 */  {TEXT("OElig"), 338, TEXT(' ')},   /* latin capital ligature OE, U+0152 ISOlat2 */
 {TEXT("Oacute"), 211},  /* latin capital letter O with acute, U+00D3 ISOlat1 */  {TEXT("Oacute"), 211, TEXT(' ')},  /* latin capital letter O with acute, U+00D3 ISOlat1 */
 {TEXT("Ocirc"), 212},   /* latin capital letter O with circumflex, U+00D4 ISOlat1 */  {TEXT("Ocirc"), 212, TEXT(' ')},   /* latin capital letter O with circumflex, U+00D4 ISOlat1 */
 {TEXT("Ograve"), 210},  /* latin capital letter O with grave, U+00D2 ISOlat1 */  {TEXT("Ograve"), 210, TEXT(' ')},  /* latin capital letter O with grave, U+00D2 ISOlat1 */
 {TEXT("Omega"), 937},   /* greek capital letter omega, U+03A9 ISOgrk3 */  {TEXT("Omega"), 937, TEXT(' ')},   /* greek capital letter omega, U+03A9 ISOgrk3 */
 {TEXT("Omicron"), 927}, /* greek capital letter omicron, U+039F */  {TEXT("Omicron"), 927, TEXT(' ')}, /* greek capital letter omicron, U+039F */
 {TEXT("Oslash"), 216},  /* latin capital letter O with stroke = */   {TEXT("Oslash"), 216, TEXT(' ')},  /* latin capital letter O with stroke = */ 
                         /* latin capital letter O slash, U+00D8 ISOlat1 */                                     /* latin capital letter O slash, U+00D8 ISOlat1 */
 {TEXT("Otilde"), 213},  /* latin capital letter O with tilde, U+00D5 ISOlat1 */  {TEXT("Otilde"), 213, TEXT(' ')},  /* latin capital letter O with tilde, U+00D5 ISOlat1 */
 {TEXT("Ouml"), 214},    /* latin capital letter O with diaeresis, U+00D6 ISOlat1 */  {TEXT("Ouml"), 214, TEXT(' ')},    /* latin capital letter O with diaeresis, U+00D6 ISOlat1 */
 {TEXT("Phi"), 934},     /* greek capital letter phi, U+03A6 ISOgrk3 */  {TEXT("Phi"), 934, TEXT(' ')},     /* greek capital letter phi, U+03A6 ISOgrk3 */
 {TEXT("Pi"), 928},      /* greek capital letter pi, U+03A0 ISOgrk3 */  {TEXT("Pi"), 928, TEXT(' ')},      /* greek capital letter pi, U+03A0 ISOgrk3 */
 {TEXT("Prime"), 8243},  /* double prime = seconds = inches, U+2033 ISOtech */  {TEXT("Prime"), 8243, TEXT(' ')},  /* double prime = seconds = inches, U+2033 ISOtech */
 {TEXT("Psi"), 936},     /* greek capital letter psi, U+03A8 ISOgrk3 */  {TEXT("Psi"), 936, TEXT(' ')},     /* greek capital letter psi, U+03A8 ISOgrk3 */
 {TEXT("Rho"), 929},     /* greek capital letter rho, U+03A1 */  {TEXT("Rho"), 929, TEXT(' ')},     /* greek capital letter rho, U+03A1 */
 {TEXT("Scaron"), 352},  /* latin capital letter S with caron, U+0160 ISOlat2 */  {TEXT("Scaron"), 352, TEXT(' ')},  /* latin capital letter S with caron, U+0160 ISOlat2 */
 {TEXT("Sigma"), 931},   /* greek capital letter sigma, U+03A3 ISOgrk3 */  {TEXT("Sigma"), 931, TEXT(' ')},   /* greek capital letter sigma, U+03A3 ISOgrk3 */
 {TEXT("THORN"), 222},   /* latin capital letter THORN, U+00DE ISOlat1 */  {TEXT("THORN"), 222, TEXT(' ')},   /* latin capital letter THORN, U+00DE ISOlat1 */
 {TEXT("Tau"), 932},     /* greek capital letter tau, U+03A4 */  {TEXT("Tau"), 932, TEXT(' ')},     /* greek capital letter tau, U+03A4 */
 {TEXT("Theta"), 920},   /* greek capital letter theta, U+0398 ISOgrk3 */  {TEXT("Theta"), 920, TEXT(' ')},   /* greek capital letter theta, U+0398 ISOgrk3 */
 {TEXT("Uacute"), 218},  /* latin capital letter U with acute, U+00DA ISOlat1 */  {TEXT("Uacute"), 218, TEXT(' ')},  /* latin capital letter U with acute, U+00DA ISOlat1 */
 {TEXT("Ucirc"), 219},   /* latin capital letter U with circumflex, U+00DB ISOlat1 */  {TEXT("Ucirc"), 219, TEXT(' ')},   /* latin capital letter U with circumflex, U+00DB ISOlat1 */
 {TEXT("Ugrave"), 217},  /* latin capital letter U with grave, U+00D9 ISOlat1 */  {TEXT("Ugrave"), 217, TEXT(' ')},  /* latin capital letter U with grave, U+00D9 ISOlat1 */
 {TEXT("Upsilon"), 933}, /* greek capital letter upsilon, U+03A5 ISOgrk3 */  {TEXT("Upsilon"), 933, TEXT(' ')}, /* greek capital letter upsilon, U+03A5 ISOgrk3 */
 {TEXT("Uuml"), 220},    /* latin capital letter U with diaeresis, U+00DC ISOlat1 */  {TEXT("Uuml"), 220, TEXT(' ')},    /* latin capital letter U with diaeresis, U+00DC ISOlat1 */
 {TEXT("Xi"), 926},      /* greek capital letter xi, U+039E ISOgrk3 */  {TEXT("Xi"), 926, TEXT(' ')},      /* greek capital letter xi, U+039E ISOgrk3 */
 {TEXT("Yacute"), 221},  /* latin capital letter Y with acute, U+00DD ISOlat1 */  {TEXT("Yacute"), 221, TEXT(' ')},  /* latin capital letter Y with acute, U+00DD ISOlat1 */
 {TEXT("Yuml"), 376},    /* latin capital letter Y with diaeresis, U+0178 ISOlat2 */  {TEXT("Yuml"), 376, TEXT(' ')},    /* latin capital letter Y with diaeresis, U+0178 ISOlat2 */
 {TEXT("Zeta"), 918},    /* greek capital letter zeta, U+0396 */  {TEXT("Zeta"), 918, TEXT(' ')},    /* greek capital letter zeta, U+0396 */
 {TEXT("aacute"), 225},  /* latin small letter a with acute, U+00E1 ISOlat1 */  {TEXT("aacute"), 225, TEXT(' ')},  /* latin small letter a with acute, U+00E1 ISOlat1 */
 {TEXT("acirc"), 226},   /* latin small letter a with circumflex, U+00E2 ISOlat1 */  {TEXT("acirc"), 226, TEXT(' ')},   /* latin small letter a with circumflex, U+00E2 ISOlat1 */
 {TEXT("acute"), 180},   /* acute accent = spacing acute, U+00B4 ISOdia */  {TEXT("acute"), 180, TEXT(' ')},   /* acute accent = spacing acute, U+00B4 ISOdia */
 {TEXT("aelig"), 230},   /* latin small letter ae = */  {TEXT("aelig"), 230, TEXT(' ')},   /* latin small letter ae = */
                         /* latin small ligature ae, U+00E6 ISOlat1 */                                     /* latin small ligature ae, U+00E6 ISOlat1 */
 {TEXT("agrave"), 224},  /* latin small letter a with grave = */  {TEXT("agrave"), 224, TEXT(' ')},  /* latin small letter a with grave = */
                         /* latin small letter a grave, U+00E0 ISOlat1 */                                     /* latin small letter a grave, U+00E0 ISOlat1 */
 {TEXT("alefsym"), 8501},/* alef symbol = first transfinite cardinal, U+2135 NEW */  {TEXT("alefsym"), 8501, TEXT(' ')}, /* alef symbol = first transfinite cardinal, U+2135 NEW */
 {TEXT("alpha"), 945},   /* greek small letter alpha, U+03B1 ISOgrk3 */  {TEXT("alpha"), 945, TEXT(' ')},   /* greek small letter alpha, U+03B1 ISOgrk3 */
 {TEXT("amp"), 38},      /* ampersand, U+0026 ISOnum */  {TEXT("amp"), 38, TEXT(' ')},      /* ampersand, U+0026 ISOnum */
 {TEXT("and"), 8743},    /* logical and = wedge, U+2227 ISOtech */  {TEXT("and"), 8743, TEXT(' ')},    /* logical and = wedge, U+2227 ISOtech */
 {TEXT("ang"), 8736},    /* angle, U+2220 ISOamso */  {TEXT("ang"), 8736, TEXT(' ')},    /* angle, U+2220 ISOamso */
 {TEXT("aring"), 229},   /* latin small letter a with ring above = */  {TEXT("aring"), 229, TEXT(' ')},   /* latin small letter a with ring above = */
                         /* latin small letter a ring, U+00E5 ISOlat1 */                                     /* latin small letter a ring, U+00E5 ISOlat1 */
 {TEXT("asymp"), 8776},  /* almost equal to = asymptotic to, U+2248 ISOamsr */  {TEXT("asymp"), 8776, TEXT(' ')},  /* almost equal to = asymptotic to, U+2248 ISOamsr */
 {TEXT("atilde"), 227},  /* latin small letter a with tilde, U+00E3 ISOlat1 */  {TEXT("atilde"), 227, TEXT(' ')},  /* latin small letter a with tilde, U+00E3 ISOlat1 */
 {TEXT("auml"), 228},    /* latin small letter a with diaeresis, U+00E4 ISOlat1 */  {TEXT("auml"), 228, TEXT(' ')},    /* latin small letter a with diaeresis, U+00E4 ISOlat1 */
 {TEXT("bdquo"), 8222},  /* double low-9 quotation mark, U+201E NEW */  {TEXT("bdquo"), 8222},             /* double low-9 quotation mark, U+201E NEW */
 {TEXT("beta"), 946},    /* greek small letter beta, U+03B2 ISOgrk3 */  {TEXT("beta"), 946, TEXT(' ')},    /* greek small letter beta, U+03B2 ISOgrk3 */
 {TEXT("brvbar"), 166},  /* broken bar = broken vertical bar, U+00A6 ISOnum */  {TEXT("brvbar"), 166, TEXT(' ')},  /* broken bar = broken vertical bar, U+00A6 ISOnum */
 {TEXT("bull"), 8226},   /* bullet = black small circle, U+2022 ISOpub */  {TEXT("bull"), 8226, TEXT(' ')},   /* bullet = black small circle, U+2022 ISOpub */
 {TEXT("cap"), 8745},    /* intersection = cap, U+2229 ISOtech */  {TEXT("cap"), 8745, TEXT(' ')},    /* intersection = cap, U+2229 ISOtech */
 {TEXT("ccedil"), 231},  /* latin small letter c with cedilla, U+00E7 ISOlat1 */  {TEXT("ccedil"), 231, TEXT(' ')},  /* latin small letter c with cedilla, U+00E7 ISOlat1 */
 {TEXT("cedil"), 184},   /* cedilla = spacing cedilla, U+00B8 ISOdia */  {TEXT("cedil"), 184, TEXT(' ')},   /* cedilla = spacing cedilla, U+00B8 ISOdia */
 {TEXT("cent"), 162},    /* cent sign, U+00A2 ISOnum */  {TEXT("cent"), 162, TEXT(' ')},    /* cent sign, U+00A2 ISOnum */
 {TEXT("chi"), 967},     /* greek small letter chi, U+03C7 ISOgrk3 */  {TEXT("chi"), 967, TEXT(' ')},     /* greek small letter chi, U+03C7 ISOgrk3 */
 {TEXT("circ"), 710},    /* modifier letter circumflex accent, U+02C6 ISOpub */  {TEXT("circ"), 710, TEXT(' ')},    /* modifier letter circumflex accent, U+02C6 ISOpub */
 {TEXT("clubs"), 9827},  /* black club suit = shamrock, U+2663 ISOpub */  {TEXT("clubs"), 9827, TEXT(' ')},  /* black club suit = shamrock, U+2663 ISOpub */
 {TEXT("cong"), 8773},   /* approximately equal to, U+2245 ISOtech */  {TEXT("cong"), 8773, TEXT(' ')},   /* approximately equal to, U+2245 ISOtech */
 {TEXT("copy"), 169},    /* copyright sign, U+00A9 ISOnum */  {TEXT("copy"), 169, TEXT(' ')},    /* copyright sign, U+00A9 ISOnum */
 {TEXT("crarr"), 8629},  /* downwards arrow with corner leftwards = */  {TEXT("crarr"), 8629, TEXT(' ')},  /* downwards arrow with corner leftwards = */
                         /* carriage return, U+21B5 NEW */                                     /* carriage return, U+21B5 NEW */
 {TEXT("cup"), 8746},    /* union = cup, U+222A ISOtech */  {TEXT("cup"), 8746, TEXT(' ')},    /* union = cup, U+222A ISOtech */
 {TEXT("curren"), 164},  /* currency sign, U+00A4 ISOnum */  {TEXT("curren"), 164, TEXT(' ')},  /* currency sign, U+00A4 ISOnum */
 {TEXT("dArr"), 8659},   /* downwards double arrow, U+21D3 ISOamsa */  {TEXT("dArr"), 8659, TEXT(' ')},   /* downwards double arrow, U+21D3 ISOamsa */
 {TEXT("dagger"), 8224}, /* dagger, U+2020 ISOpub */  {TEXT("dagger"), 8224, TEXT(' ')}, /* dagger, U+2020 ISOpub */
 {TEXT("darr"), 8595},   /* downwards arrow, U+2193 ISOnum */  {TEXT("darr"), 8595, TEXT(' ')},   /* downwards arrow, U+2193 ISOnum */
 {TEXT("deg"), 176},     /* degree sign, U+00B0 ISOnum */  {TEXT("deg"), 176, TEXT(' ')},     /* degree sign, U+00B0 ISOnum */
 {TEXT("delta"), 948},   /* greek small letter delta, U+03B4 ISOgrk3 */  {TEXT("delta"), 948, TEXT(' ')},   /* greek small letter delta, U+03B4 ISOgrk3 */
 {TEXT("diams"), 9830},  /* black diamond suit, U+2666 ISOpub */  {TEXT("diams"), 9830, TEXT(' ')},  /* black diamond suit, U+2666 ISOpub */
 {TEXT("divide"), 247},  /* division sign, U+00F7 ISOnum */  {TEXT("divide"), 247, TEXT(' ')},  /* division sign, U+00F7 ISOnum */
 {TEXT("eacute"), 233},  /* latin small letter e with acute, U+00E9 ISOlat1 */  {TEXT("eacute"), 233, TEXT(' ')},  /* latin small letter e with acute, U+00E9 ISOlat1 */
 {TEXT("ecirc"), 234},   /* latin small letter e with circumflex, U+00EA ISOlat1 */  {TEXT("ecirc"), 234, TEXT(' ')},   /* latin small letter e with circumflex, U+00EA ISOlat1 */
 {TEXT("egrave"), 232},  /* latin small letter e with grave, U+00E8 ISOlat1 */  {TEXT("egrave"), 232, TEXT(' ')},  /* latin small letter e with grave, U+00E8 ISOlat1 */
 {TEXT("empty"), 8709},  /* empty set = null set = diameter, U+2205 ISOamso */  {TEXT("empty"), 8709, TEXT(' ')},  /* empty set = null set = diameter, U+2205 ISOamso */
 {TEXT("emsp"), 8195},   /* em space, U+2003 ISOpub */  {TEXT("emsp"), 8195, TEXT(' ')},   /* em space, U+2003 ISOpub */
 {TEXT("ensp"), 8194},   /* en space, U+2002 ISOpub */  {TEXT("ensp"), 8194, TEXT(' ')},   /* en space, U+2002 ISOpub */
 {TEXT("epsilon"), 949}, /* greek small letter epsilon, U+03B5 ISOgrk3 */  {TEXT("epsilon"), 949, TEXT(' ')}, /* greek small letter epsilon, U+03B5 ISOgrk3 */
 {TEXT("equiv"), 8801},  /* identical to, U+2261 ISOtech */  {TEXT("equiv"), 8801, TEXT(' ')},  /* identical to, U+2261 ISOtech */
 {TEXT("eta"), 951},     /* greek small letter eta, U+03B7 ISOgrk3 */  {TEXT("eta"), 951, TEXT(' ')},     /* greek small letter eta, U+03B7 ISOgrk3 */
 {TEXT("eth"), 240},     /* latin small letter eth, U+00F0 ISOlat1 */  {TEXT("eth"), 240, TEXT(' ')},     /* latin small letter eth, U+00F0 ISOlat1 */
 {TEXT("euml"), 235},    /* latin small letter e with diaeresis, U+00EB ISOlat1 */  {TEXT("euml"), 235, TEXT(' ')},    /* latin small letter e with diaeresis, U+00EB ISOlat1 */
 {TEXT("euro"), 8364},   /* euro sign, U+20AC NEW */  {TEXT("euro"), 8364, TEXT(' ')},   /* euro sign, U+20AC NEW */
 {TEXT("exist"), 8707},  /* there exists, U+2203 ISOtech */  {TEXT("exist"), 8707, TEXT(' ')},  /* there exists, U+2203 ISOtech */
 {TEXT("fnof"), 402},    /* latin small f with hook = function = */  {TEXT("fnof"), 402, TEXT(' ')},    /* latin small f with hook = function = */
                         /* florin, U+0192 ISOtech */                                     /* florin, U+0192 ISOtech */
 {TEXT("forall"), 8704}, /* for all, U+2200 ISOtech */  {TEXT("forall"), 8704, TEXT(' ')}, /* for all, U+2200 ISOtech */
 {TEXT("frac12"), 189},  /* vulgar fraction one half = */  {TEXT("frac12"), 189, TEXT(' ')},  /* vulgar fraction one half = */
                         /*fraction one half, U+00BD ISOnum */                                     /*fraction one half, U+00BD ISOnum */
 {TEXT("frac14"), 188},  /* vulgar fraction one quarter = */  {TEXT("frac14"), 188, TEXT(' ')},  /* vulgar fraction one quarter = */
                         /* fraction one quarter, U+00BC ISOnum */                                     /* fraction one quarter, U+00BC ISOnum */
 {TEXT("frac34"), 190},  /* vulgar fraction three quarters = */  {TEXT("frac34"), 190, TEXT(' ')},  /* vulgar fraction three quarters = */
                         /* fraction three quarters, U+00BE ISOnum */                                     /* fraction three quarters, U+00BE ISOnum */
 {TEXT("frasl"), 8260},  /* fraction slash, U+2044 NEW */  {TEXT("frasl"), 8260, TEXT(' ')},  /* fraction slash, U+2044 NEW */
 {TEXT("gamma"), 947},   /* greek small letter gamma, U+03B3 ISOgrk3 */  {TEXT("gamma"), 947, TEXT(' ')},   /* greek small letter gamma, U+03B3 ISOgrk3 */
 {TEXT("ge"), 8805},     /* greater-than or equal to, U+2265 ISOtech */  {TEXT("ge"), 8805, TEXT(' ')},     /* greater-than or equal to, U+2265 ISOtech */
 {TEXT("gt"), 62},       /* greater-than sign, U+003E ISOnum */  {TEXT("gt"), 62, TEXT(' ')},       /* greater-than sign, U+003E ISOnum */
 {TEXT("hArr"), 8660},   /* left right double arrow, U+21D4 ISOamsa */  {TEXT("hArr"), 8660, TEXT(' ')},   /* left right double arrow, U+21D4 ISOamsa */
 {TEXT("harr"), 8596},   /* left right arrow, U+2194 ISOamsa */  {TEXT("harr"), 8596, TEXT(' ')},   /* left right arrow, U+2194 ISOamsa */
 {TEXT("hearts"), 9829}, /* black heart suit = valentine, U+2665 ISOpub */  {TEXT("hearts"), 9829, TEXT(' ')}, /* black heart suit = valentine, U+2665 ISOpub */
 {TEXT("hellip"), 8230}, /* horizontal ellipsis = three dot leader, U+2026 ISOpub */  {TEXT("hellip"), 8230, TEXT(' ')}, /* horizontal ellipsis = three dot leader, U+2026 ISOpub */
 {TEXT("hyphen"), 173},  /* hyphen = discretionary hyphen, U+00AD ISOnum */  {TEXT("hyphen"), 173, TEXT(' ')},  /* hyphen = discretionary hyphen, U+00AD ISOnum */
 {TEXT("iacute"), 237},  /* latin small letter i with acute, U+00ED ISOlat1 */  {TEXT("iacute"), 237, TEXT(' ')},  /* latin small letter i with acute, U+00ED ISOlat1 */
 {TEXT("icirc"), 238},   /* latin small letter i with circumflex, U+00EE ISOlat1 */  {TEXT("icirc"), 238, TEXT(' ')},   /* latin small letter i with circumflex, U+00EE ISOlat1 */
 {TEXT("iexcl"), 161},   /* inverted exclamation mark, U+00A1 ISOnum */  {TEXT("iexcl"), 161, TEXT(' ')},   /* inverted exclamation mark, U+00A1 ISOnum */
 {TEXT("igrave"), 236},  /* latin small letter i with grave, U+00EC ISOlat1 */  {TEXT("igrave"), 236, TEXT(' ')},  /* latin small letter i with grave, U+00EC ISOlat1 */
 {TEXT("image"), 8465},  /* blackletter capital I = imaginary part, U+2111 ISOamso */  {TEXT("image"), 8465, TEXT(' ')},  /* blackletter capital I = imaginary part, U+2111 ISOamso */
 {TEXT("infin"), 8734},  /* infinity, U+221E ISOtech */  {TEXT("infin"), 8734, TEXT(' ')},  /* infinity, U+221E ISOtech */
 {TEXT("int"), 8747},    /* integral, U+222B ISOtech */  {TEXT("int"), 8747, TEXT(' ')},    /* integral, U+222B ISOtech */
 {TEXT("iota"), 953},    /* greek small letter iota, U+03B9 ISOgrk3 */  {TEXT("iota"), 953, TEXT(' ')},    /* greek small letter iota, U+03B9 ISOgrk3 */
 {TEXT("iquest"), 191},  /* inverted question mark = */  {TEXT("iquest"), 191, TEXT(' ')},  /* inverted question mark = */
                         /* turned question mark, U+00BF ISOnum */                                     /* turned question mark, U+00BF ISOnum */
 {TEXT("isin"), 8712},   /* element of, U+2208 ISOtech */  {TEXT("isin"), 8712, TEXT(' ')},   /* element of, U+2208 ISOtech */
 {TEXT("iuml"), 239},    /* latin small letter i with diaeresis, U+00EF ISOlat1 */  {TEXT("iuml"), 239, TEXT(' ')},    /* latin small letter i with diaeresis, U+00EF ISOlat1 */
 {TEXT("kappa"), 954},   /* greek small letter kappa, U+03BA ISOgrk3 */  {TEXT("kappa"), 954, TEXT(' ')},   /* greek small letter kappa, U+03BA ISOgrk3 */
 {TEXT("lArr"), 8656},   /* leftwards double arrow, U+21D0 ISOtech */  {TEXT("lArr"), 8656, TEXT(' ')},   /* leftwards double arrow, U+21D0 ISOtech */
 {TEXT("lambda"), 955},  /* greek small letter lambda, U+03BB ISOgrk3 */  {TEXT("lambda"), 955, TEXT(' ')},  /* greek small letter lambda, U+03BB ISOgrk3 */
 {TEXT("lang"), 9001},   /* left-pointing angle bracket = bra, U+2329 ISOtech */  {TEXT("lang"), 9001, TEXT(' ')},   /* left-pointing angle bracket = bra, U+2329 ISOtech */
 {TEXT("laquo"), 171},   /* left-pointing double angle quotation mark = */  {TEXT("laquo"), 171, TEXT(' ')},   /* left-pointing double angle quotation mark = */
                         /* left pointing guillemet, U+00AB ISOnum */                                     /* left pointing guillemet, U+00AB ISOnum */
 {TEXT("larr"), 8592},   /* leftwards arrow, U+2190 ISOnum */  {TEXT("larr"), 8592, TEXT(' ')},   /* leftwards arrow, U+2190 ISOnum */
 {TEXT("lceil"), 8968},  /* left ceiling = apl upstile, U+2308 ISOamsc */  {TEXT("lceil"), 8968, TEXT(' ')},  /* left ceiling = apl upstile, U+2308 ISOamsc */
 {TEXT("ldquo"), 8220},  /* left double quotation mark, U+201C ISOnum */  {TEXT("ldquo"), 8220, TEXT(' ')},  /* left double quotation mark, U+201C ISOnum */
 {TEXT("le"), 8804},     /* less-than or equal to, U+2264 ISOtech */  {TEXT("le"), 8804, TEXT(' ')},     /* less-than or equal to, U+2264 ISOtech */
 {TEXT("lfloor"), 8970}, /* left floor = apl downstile, U+230A ISOamsc */  {TEXT("lfloor"), 8970, TEXT(' ')}, /* left floor = apl downstile, U+230A ISOamsc */
 {TEXT("lowast"), 8727}, /* asterisk operator, U+2217 ISOtech */  {TEXT("lowast"), 8727, TEXT(' ')}, /* asterisk operator, U+2217 ISOtech */
 {TEXT("loz"), 9674},    /* lozenge, U+25CA ISOpub */  {TEXT("loz"), 9674, TEXT(' ')},    /* lozenge, U+25CA ISOpub */
 {TEXT("lrm"), 8206},    /* left-to-right mark, U+200E NEW RFC 2070 */  {TEXT("lrm"), 8206, TEXT(' ')},    /* left-to-right mark, U+200E NEW RFC 2070 */
 {TEXT("lsaquo"), 8249}, /* single left-pointing angle quotation mark, */  {TEXT("lsaquo"), 8249, TEXT(' ')}, /* single left-pointing angle quotation mark, */
                         /* U+2039 ISO proposed */                                     /* U+2039 ISO proposed */
 {TEXT("lsquo"), 8216},  /* left single quotation mark, U+2018 ISOnum */  {TEXT("lsquo"), 8216, TEXT(' ')},  /* left single quotation mark, U+2018 ISOnum */
 {TEXT("lt"), 60},       /* less-than sign, U+003C ISOnum */  {TEXT("lt"), 60, TEXT(' ')},       /* less-than sign, U+003C ISOnum */
 {TEXT("macr"), 175},    /* macron = spacing macron = overline = APL overbar, */  {TEXT("macr"), 175, TEXT(' ')},    /* macron = spacing macron = overline = APL overbar, */
                         /* U+00AF ISOdia */                                     /* U+00AF ISOdia */
 {TEXT("mdash"), 8212},  /* em dash, U+2014 ISOpub */  {TEXT("mdash"), 8212, TEXT(' ')},  /* em dash, U+2014 ISOpub */
 {TEXT("micro"), 181},   /* micro sign, U+00B5 ISOnum */  {TEXT("micro"), 181, TEXT(' ')},   /* micro sign, U+00B5 ISOnum */
 {TEXT("middot"), 183},  /* middle dot = Georgian comma = */  {TEXT("middot"), 183, TEXT(' ')},  /* middle dot = Georgian comma = */
                         /* Greek middle dot, U+00B7 ISOnum */                                     /* Greek middle dot, U+00B7 ISOnum */
 {TEXT("minus"), 8722},  /* minus sign, U+2212 ISOtech */  {TEXT("minus"), 8722, TEXT(' ')},  /* minus sign, U+2212 ISOtech */
 {TEXT("mu"), 956},      /* greek small letter mu, U+03BC ISOgrk3 */  {TEXT("mu"), 956, TEXT(' ')},      /* greek small letter mu, U+03BC ISOgrk3 */
 {TEXT("nabla"), 8711},  /* nabla = backward difference, U+2207 ISOtech */  {TEXT("nabla"), 8711, TEXT(' ')},  /* nabla = backward difference, U+2207 ISOtech */
 {TEXT("nbsp"), 160},    /* no-break space = non-breaking space, U+00A0 ISOnum */  {TEXT("nbsp"), 160, TEXT(' ')},    /* no-break space = non-breaking space, U+00A0 ISOnum */
 {TEXT("ndash"), 8211},  /* en dash, U+2013 ISOpub */  {TEXT("ndash"), 8211, TEXT(' ')},  /* en dash, U+2013 ISOpub */
 {TEXT("ne"), 8800},     /* not equal to, U+2260 ISOtech */  {TEXT("ne"), 8800, TEXT(' ')},     /* not equal to, U+2260 ISOtech */
 {TEXT("ni"), 8715},     /* contains as member, U+220B ISOtech */  {TEXT("ni"), 8715, TEXT(' ')},     /* contains as member, U+220B ISOtech */
 {TEXT("not"), 172},     /* not sign, U+00AC ISOnum */  {TEXT("not"), 172, TEXT(' ')},     /* not sign, U+00AC ISOnum */
 {TEXT("notin"), 8713},  /* not an element of, U+2209 ISOtech */  {TEXT("notin"), 8713, TEXT(' ')},  /* not an element of, U+2209 ISOtech */
 {TEXT("nsub"), 8836},   /* not a subset of, U+2284 ISOamsn */  {TEXT("nsub"), 8836, TEXT(' ')},   /* not a subset of, U+2284 ISOamsn */
 {TEXT("ntilde"), 241},  /* latin small letter n with tilde, U+00F1 ISOlat1 */  {TEXT("ntilde"), 241, TEXT(' ')},  /* latin small letter n with tilde, U+00F1 ISOlat1 */
 {TEXT("nu"), 957},      /* greek small letter nu, U+03BD ISOgrk3 */  {TEXT("nu"), 957, TEXT(' ')},      /* greek small letter nu, U+03BD ISOgrk3 */
 {TEXT("oacute"), 243},  /* latin small letter o with acute, U+00F3 ISOlat1 */  {TEXT("oacute"), 243, TEXT(' ')},  /* latin small letter o with acute, U+00F3 ISOlat1 */
 {TEXT("ocirc"), 244},   /* latin small letter o with circumflex, U+00F4 ISOlat1 */  {TEXT("ocirc"), 244, TEXT(' ')},   /* latin small letter o with circumflex, U+00F4 ISOlat1 */
 {TEXT("oelig"), 339},   /* latin small ligature oe, U+0153 ISOlat2 */  {TEXT("oelig"), 339, TEXT(' ')},   /* latin small ligature oe, U+0153 ISOlat2 */
 {TEXT("ograve"), 242},  /* latin small letter o with grave, U+00F2 ISOlat1 */  {TEXT("ograve"), 242, TEXT(' ')},  /* latin small letter o with grave, U+00F2 ISOlat1 */
 {TEXT("oline"), 8254},  /* overline = spacing overscore, U+203E NEW */  {TEXT("oline"), 8254, TEXT(' ')},  /* overline = spacing overscore, U+203E NEW */
 {TEXT("omega"), 969},   /* greek small letter omega, U+03C9 ISOgrk3 */  {TEXT("omega"), 969, TEXT(' ')},   /* greek small letter omega, U+03C9 ISOgrk3 */
 {TEXT("omicron"), 959}, /* greek small letter omicron, U+03BF NEW */  {TEXT("omicron"), 959, TEXT(' ')}, /* greek small letter omicron, U+03BF NEW */
 {TEXT("oplus"), 8853},  /* circled plus = direct sum, U+2295 ISOamsb */  {TEXT("oplus"), 8853, TEXT(' ')},  /* circled plus = direct sum, U+2295 ISOamsb */
 {TEXT("or"), 8744},     /* logical or = vee, U+2228 ISOtech */  {TEXT("or"), 8744, TEXT(' ')},     /* logical or = vee, U+2228 ISOtech */
 {TEXT("ordf"), 170},    /* feminine ordinal indicator, U+00AA ISOnum */  {TEXT("ordf"), 170, TEXT(' ')},    /* feminine ordinal indicator, U+00AA ISOnum */
 {TEXT("ordm"), 186},    /* masculine ordinal indicator, U+00BA ISOnum */  {TEXT("ordm"), 186, TEXT(' ')},    /* masculine ordinal indicator, U+00BA ISOnum */
 {TEXT("oslash"), 248},  /* latin small letter o with stroke, = */  {TEXT("oslash"), 248, TEXT(' ')},  /* latin small letter o with stroke, = */
                         /* latin small letter o slash, U+00F8 ISOlat1 */                                     /* latin small letter o slash, U+00F8 ISOlat1 */
 {TEXT("otilde"), 245},  /* latin small letter o with tilde, U+00F5 ISOlat1 */  {TEXT("otilde"), 245, TEXT(' ')},  /* latin small letter o with tilde, U+00F5 ISOlat1 */
 {TEXT("otimes"), 8855}, /* circled times = vector product, U+2297 ISOamsb */  {TEXT("otimes"), 8855, TEXT(' ')}, /* circled times = vector product, U+2297 ISOamsb */
 {TEXT("ouml"), 246},    /* latin small letter o with diaeresis, U+00F6 ISOlat1 */  {TEXT("ouml"), 246, TEXT(' ')},    /* latin small letter o with diaeresis, U+00F6 ISOlat1 */
 {TEXT("para"), 182},    /* pilcrow sign = paragraph sign, U+00B6 ISOnum */  {TEXT("para"), 182, TEXT(' ')},    /* pilcrow sign = paragraph sign, U+00B6 ISOnum */
 {TEXT("part"), 8706},   /* partial differential, U+2202 ISOtech */  {TEXT("part"), 8706, TEXT(' ')},   /* partial differential, U+2202 ISOtech */
 {TEXT("permil"), 8240}, /* per mille sign, U+2030 ISOtech */  {TEXT("permil"), 8240, TEXT(' ')}, /* per mille sign, U+2030 ISOtech */
 {TEXT("perp"), 8869},   /* up tack = orthogonal to = perpendicular, U+22A5 ISOtech */  {TEXT("perp"), 8869, TEXT(' ')},   /* up tack = orthogonal to = perpendicular, U+22A5 ISOtech */
 {TEXT("phi"), 966},     /* greek small letter phi, U+03C6 ISOgrk3 */  {TEXT("phi"), 966, TEXT(' ')},     /* greek small letter phi, U+03C6 ISOgrk3 */
 {TEXT("pi"), 960},      /* greek small letter pi, U+03C0 ISOgrk3 */  {TEXT("pi"), 960, TEXT(' ')},      /* greek small letter pi, U+03C0 ISOgrk3 */
 {TEXT("piv"), 982},     /* greek pi symbol, U+03D6 ISOgrk3 */  {TEXT("piv"), 982, TEXT(' ')},     /* greek pi symbol, U+03D6 ISOgrk3 */
 {TEXT("plusmn"), 177},  /* plus-minus sign = plus-or-minus sign, U+00B1 ISOnum */  {TEXT("plusmn"), 177, TEXT(' ')},  /* plus-minus sign = plus-or-minus sign, U+00B1 ISOnum */
 {TEXT("pound"), 163},   /* pound sign, U+00A3 ISOnum */  {TEXT("pound"), 163, TEXT(' ')},   /* pound sign, U+00A3 ISOnum */
 {TEXT("prime"), 8242},  /* prime = minutes = feet, U+2032 ISOtech */  {TEXT("prime"), 8242, TEXT(' ')},  /* prime = minutes = feet, U+2032 ISOtech */
 {TEXT("prod"), 8719},   /* n-ary product = product sign, U+220F ISOamsb */  {TEXT("prod"), 8719, TEXT(' ')},   /* n-ary product = product sign, U+220F ISOamsb */
 {TEXT("prop"), 8733},   /* proportional to, U+221D ISOtech */  {TEXT("prop"), 8733, TEXT(' ')},   /* proportional to, U+221D ISOtech */
 {TEXT("psi"), 968},     /* greek small letter psi, U+03C8 ISOgrk3 */  {TEXT("psi"), 968, TEXT(' ')},     /* greek small letter psi, U+03C8 ISOgrk3 */
 {TEXT("quot"), 34},     /* quotation mark = APL quote, U+0022 ISOnum */  {TEXT("quot"), 34, TEXT(' ')},     /* quotation mark = APL quote, U+0022 ISOnum */
 {TEXT("rArr"), 8658},   /* rightwards double arrow, U+21D2 ISOtech */  {TEXT("rArr"), 8658, TEXT(' ')},   /* rightwards double arrow, U+21D2 ISOtech */
 {TEXT("radic"), 8730},  /* square root = radical sign, U+221A ISOtech */  {TEXT("radic"), 8730, TEXT(' ')},  /* square root = radical sign, U+221A ISOtech */
 {TEXT("rang"), 9002},   /* right-pointing angle bracket = ket, U+232A ISOtech */  {TEXT("rang"), 9002, TEXT(' ')},   /* right-pointing angle bracket = ket, U+232A ISOtech */
 {TEXT("raquo"), 187},   /* right-pointing double angle quotation mark = */  {TEXT("raquo"), 187, TEXT(' ')},   /* right-pointing double angle quotation mark = */
                         /* right pointing guillemet, U+00BB ISOnum */                                     /* right pointing guillemet, U+00BB ISOnum */
 {TEXT("rarr"), 8594},   /* rightwards arrow, U+2192 ISOnum */  {TEXT("rarr"), 8594, TEXT(' ')},   /* rightwards arrow, U+2192 ISOnum */
 {TEXT("rceil"), 8969},  /* right ceiling, U+2309 ISOamsc */  {TEXT("rceil"), 8969, TEXT(' ')},  /* right ceiling, U+2309 ISOamsc */
 {TEXT("rdquo"), 8221},  /* right double quotation mark, U+201D ISOnum */  {TEXT("rdquo"), 8221, TEXT(' ')},  /* right double quotation mark, U+201D ISOnum */
 {TEXT("real"), 8476},   /* blackletter capital R = real part symbol, U+211C ISOamso */  {TEXT("real"), 8476, TEXT(' ')},   /* blackletter capital R = real part symbol, U+211C ISOamso */
 {TEXT("reg"), 174},     /* registered sign = registered trade mark sign, */  {TEXT("reg"), 174, TEXT(' ')},     /* registered sign = registered trade mark sign, */
                         /* U+00AE ISOnum */                                     /* U+00AE ISOnum */
 {TEXT("rfloor"), 8971}, /* right floor, U+230B ISOamsc */  {TEXT("rfloor"), 8971, TEXT(' ')}, /* right floor, U+230B ISOamsc */
 {TEXT("rho"), 961},     /* greek small letter rho, U+03C1 ISOgrk3 */  {TEXT("rho"), 961, TEXT(' ')},     /* greek small letter rho, U+03C1 ISOgrk3 */
 {TEXT("rlm"), 8207},    /* right-to-left mark, U+200F NEW RFC 2070 */  {TEXT("rlm"), 8207, TEXT(' ')},    /* right-to-left mark, U+200F NEW RFC 2070 */
 {TEXT("rsaquo"), 8250}, /* single right-pointing angle quotation mark, */  {TEXT("rsaquo"), 8250, TEXT(' ')}, /* single right-pointing angle quotation mark, */
                         /* U+203A ISO proposed */                                     /* U+203A ISO proposed */
 {TEXT("rsquo"), 8217},  /* right single quotation mark, U+2019 ISOnum */  {TEXT("rsquo"), 8217, TEXT(' ')},  /* right single quotation mark, U+2019 ISOnum */
 {TEXT("sbquo"), 8218},  /* single low-9 quotation mark, U+201A NEW */  {TEXT("sbquo"), 8218, TEXT(' ')},  /* single low-9 quotation mark, U+201A NEW */
 {TEXT("scaron"), 353},  /* latin small letter s with caron, U+0161 ISOlat2 */  {TEXT("scaron"), 353, TEXT(' ')},  /* latin small letter s with caron, U+0161 ISOlat2 */
 {TEXT("sdot"), 8901},   /* dot operator, U+22C5 ISOamsb */  {TEXT("sdot"), 8901, TEXT(' ')},   /* dot operator, U+22C5 ISOamsb */
 {TEXT("sect"), 167},    /* section sign, U+00A7 ISOnum */  {TEXT("sect"), 167, TEXT(' ')},    /* section sign, U+00A7 ISOnum */
 {TEXT("shy"), 173},     /* soft hyphen = discretionary hyphen, U+00AD ISOnum */  {TEXT("shy"), 173, TEXT(' ')},     /* soft hyphen = discretionary hyphen, U+00AD ISOnum */
 {TEXT("sigma"), 963},   /* greek small letter sigma, U+03C3 ISOgrk3 */  {TEXT("sigma"), 963, TEXT(' ')},   /* greek small letter sigma, U+03C3 ISOgrk3 */
 {TEXT("sigmaf"), 962},  /* greek small letter final sigma, U+03C2 ISOgrk3 */  {TEXT("sigmaf"), 962, TEXT(' ')},  /* greek small letter final sigma, U+03C2 ISOgrk3 */
 {TEXT("sim"), 8764},    /* tilde operator = varies with = similar to, U+223C ISOtech */  {TEXT("sim"), 8764, TEXT(' ')},    /* tilde operator = varies with = similar to, U+223C ISOtech */
 {TEXT("spades"), 9824}, /* black spade suit, U+2660 ISOpub */  {TEXT("spades"), 9824, TEXT(' ')}, /* black spade suit, U+2660 ISOpub */
 {TEXT("sub"), 8834},    /* subset of, U+2282 ISOtech */  {TEXT("sub"), 8834, TEXT(' ')},    /* subset of, U+2282 ISOtech */
 {TEXT("sube"), 8838},   /* subset of or equal to, U+2286 ISOtech */  {TEXT("sube"), 8838, TEXT(' ')},   /* subset of or equal to, U+2286 ISOtech */
 {TEXT("sum"), 8721},    /* n-ary sumation, U+2211 ISOamsb */  {TEXT("sum"), 8721, TEXT(' ')},    /* n-ary sumation, U+2211 ISOamsb */
 {TEXT("sup"), 8835},    /* superset of, U+2283 ISOtech */  {TEXT("sup"), 8835, TEXT(' ')},    /* superset of, U+2283 ISOtech */
 {TEXT("sup1"), 185},    /* superscript one = superscript digit one, U+00B9 ISOnum */  {TEXT("sup1"), 185, TEXT(' ')},    /* superscript one = superscript digit one, U+00B9 ISOnum */
 {TEXT("sup2"), 178},    /* superscript two = superscript digit two = squared, */  {TEXT("sup2"), 178, TEXT(' ')},    /* superscript two = superscript digit two = squared, */
                         /* U+00B2 ISOnum */                                     /* U+00B2 ISOnum */
 {TEXT("sup3"), 179},    /* superscript three = superscript digit three = cubed, */  {TEXT("sup3"), 179, TEXT(' ')},    /* superscript three = superscript digit three = cubed, */
                         /* U+00B3 ISOnum */                                     /* U+00B3 ISOnum */
 {TEXT("supe"), 8839},   /* superset of or equal to, U+2287 ISOtech */  {TEXT("supe"), 8839, TEXT(' ')},   /* superset of or equal to, U+2287 ISOtech */
 {TEXT("szlig"), 223},   /* latin small letter sharp s = ess-zed, U+00DF ISOlat1 */  {TEXT("szlig"), 223, TEXT(' ')},   /* latin small letter sharp s = ess-zed, U+00DF ISOlat1 */
 {TEXT("tau"), 964},     /* greek small letter tau, U+03C4 ISOgrk3 */  {TEXT("tau"), 964, TEXT(' ')},     /* greek small letter tau, U+03C4 ISOgrk3 */
 {TEXT("there4"), 8756}, /* therefore, U+2234 ISOtech */  {TEXT("there4"), 8756, TEXT(' ')}, /* therefore, U+2234 ISOtech */
 {TEXT("theta"), 952},   /* greek small letter theta, U+03B8 ISOgrk3 */  {TEXT("theta"), 952, TEXT(' ')},   /* greek small letter theta, U+03B8 ISOgrk3 */
 {TEXT("thetasym"), 977},/* greek small letter theta symbol, U+03D1 NEW */  {TEXT("thetasym"), 977, TEXT(' ')}, /* greek small letter theta symbol, U+03D1 NEW */
 {TEXT("thinsp"), 8201}, /* thin space, U+2009 ISOpub */  {TEXT("thinsp"), 8201, TEXT(' ')}, /* thin space, U+2009 ISOpub */
 {TEXT("thorn"), 254},   /* latin small letter thorn with, U+00FE ISOlat1 */  {TEXT("thorn"), 254, TEXT(' ')},   /* latin small letter thorn with, U+00FE ISOlat1 */
 {TEXT("tilde"), 732},   /* small tilde, U+02DC ISOdia */  {TEXT("tilde"), 732, TEXT(' ')},   /* small tilde, U+02DC ISOdia */
 {TEXT("times"), 215},   /* multiplication sign, U+00D7 ISOnum */  {TEXT("times"), 215, TEXT(' ')},   /* multiplication sign, U+00D7 ISOnum */
 {TEXT("trade"), 8482},  /* trade mark sign, U+2122 ISOnum */  {TEXT("trade"), 8482, TEXT(' ')},  /* trade mark sign, U+2122 ISOnum */
 {TEXT("uArr"), 8657},   /* upwards double arrow, U+21D1 ISOamsa */  {TEXT("uArr"), 8657, TEXT(' ')},   /* upwards double arrow, U+21D1 ISOamsa */
 {TEXT("uacute"), 250},  /* latin small letter u with acute, U+00FA ISOlat1 */  {TEXT("uacute"), 250, TEXT(' ')},  /* latin small letter u with acute, U+00FA ISOlat1 */
 {TEXT("uarr"), 8593},   /* upwards arrow, U+2191 ISOnum*/  {TEXT("uarr"), 8593, TEXT(' ')},   /* upwards arrow, U+2191 ISOnum*/
 {TEXT("ucirc"), 251},   /* latin small letter u with circumflex, U+00FB ISOlat1 */  {TEXT("ucirc"), 251, TEXT(' ')},   /* latin small letter u with circumflex, U+00FB ISOlat1 */
 {TEXT("ugrave"), 249},  /* latin small letter u with grave, U+00F9 ISOlat1 */  {TEXT("ugrave"), 249, TEXT(' ')},  /* latin small letter u with grave, U+00F9 ISOlat1 */
 {TEXT("uml"), 168},     /* diaeresis = spacing diaeresis, U+00A8 ISOdia */  {TEXT("uml"), 168, TEXT(' ')},     /* diaeresis = spacing diaeresis, U+00A8 ISOdia */
 {TEXT("upsih"), 978},   /* greek upsilon with hook symbol, U+03D2 NEW */  {TEXT("upsih"), 978, TEXT(' ')},   /* greek upsilon with hook symbol, U+03D2 NEW */
 {TEXT("upsilon"), 965}, /* greek small letter upsilon, U+03C5 ISOgrk3 */  {TEXT("upsilon"), 965, TEXT(' ')}, /* greek small letter upsilon, U+03C5 ISOgrk3 */
 {TEXT("uuml"), 252},    /* latin small letter u with diaeresis, U+00FC ISOlat1 */  {TEXT("uuml"), 252, TEXT(' ')},    /* latin small letter u with diaeresis, U+00FC ISOlat1 */
 {TEXT("weierp"), 8472}, /* script capital P = power set = Weierstrass p, */  {TEXT("weierp"), 8472, TEXT(' ')}, /* script capital P = power set = Weierstrass p, */
                         /* U+2118 ISOamso */                                     /* U+2118 ISOamso */
 {TEXT("xi"), 958},      /* greek small letter xi, U+03BE ISOgrk3 */  {TEXT("xi"), 958, TEXT(' ')},      /* greek small letter xi, U+03BE ISOgrk3 */
 {TEXT("yacute"), 253},  /* latin small letter y with acute, U+00FD ISOlat1 */  {TEXT("yacute"), 253, TEXT(' ')},  /* latin small letter y with acute, U+00FD ISOlat1 */
 {TEXT("yen"), 165},     /* yen sign = yuan sign, U+00A5 ISOnum */  {TEXT("yen"), 165, TEXT(' ')},     /* yen sign = yuan sign, U+00A5 ISOnum */
 {TEXT("yuml"), 255},    /* latin small letter y with diaeresis, U+00FF ISOlat1 */  {TEXT("yuml"), 255, TEXT(' ')},    /* latin small letter y with diaeresis, U+00FF ISOlat1 */
 {TEXT("zeta"), 950},    /* greek small letter zeta, U+03B6 ISOgrk3 */  {TEXT("zeta"), 950, TEXT(' ')},    /* greek small letter zeta, U+03B6 ISOgrk3 */
 {TEXT("zwj"), 8205},    /* zero width joiner, U+200D NEW RFC 2070 */  {TEXT("zwj"), 8205, TEXT(' ')},    /* zero width joiner, U+200D NEW RFC 2070 */
 {TEXT("zwnj"), 8204},   /* zero width non-joiner, U+200C NEW RFC 2070 */  {TEXT("zwnj"), 8204, TEXT(' ')},   /* zero width non-joiner, U+200C NEW RFC 2070 */
 {TEXT("zzzz"), 0}                       /* this last entry is required */  {TEXT("zzzz"), 0, TEXT(' ')}       /* this last entry is required */
 };  };
   
 /* tables defined in fetchHTMLname.c */  /* tables defined in fetchHTMLname.c */
Line 545  Document doc; Line 544  Document doc;
      }       }
 }  }
   
   /*---------------------------------------------------------------------------
      XhtmlMapEntity
      Search that entity in the entity table and return the corresponding value.
     ---------------------------------------------------------------------------*/
   #ifdef __STDC__
   void    XhtmlMapEntity (STRING  entityName,
                           int    *entityValue,
                           STRING  alphabet)
   #else
   void    XhtmlMapEntity (entityName, entityValue, alphabet)
   STRING  entityName;
   int    *entityValue;
   STRING  alphabet;
   #endif
   {
     int        i;
     ThotBool   found;
   
     found = FALSE;
     for (i = 0; XhtmlEntityTable[i].charCode >= 0 && ! found; i++)
        found = !ustrcmp (XhtmlEntityTable[i].charName, entityName);
   
     if (found)
       {
         /* entity found */
         i--;
         *entityValue = XhtmlEntityTable[i].charCode;
         *alphabet = XhtmlEntityTable[i].charAlphabet;
       }
     else
       *alphabet = WC_EOS;
   }
   
   /*----------------------------------------------------------------------
     PutNonISOlatin1Char     
     Put a Unicode character in the input buffer.
     ----------------------------------------------------------------------*/
   #ifdef __STDC__
   static void    PutNonISOlatin1Char (int code,
                                       STRING prefix,
                                       STRING entityName,
                                       ParserData *context)
   #else
   static void    PutNonISOlatin1Char (code, prefix, entityName, context)
   int            code;
   STRING         prefix;
   STRING         entityName;
   ParserData    *context;
   #endif
   {
      Language      lang, l;
      ElementType   elType;
      Element       elText;
      AttributeType attrType;
      Attribute     attr;
      CHAR_T        buffer[MaxEntityLength+10];
   
      /* create a new text leaf */
      elType.ElSSchema = TtaGetDocumentSSchema (context->doc);
      elType.ElTypeNum = HTML_EL_TEXT_UNIT;
      elText = TtaNewElement (context->doc, elType);
      XmlSetElemLineNumber (elText);
      XhtmlInsertElement (&elText);
      context->lastElement = elText;
      context->lastElementClosed = TRUE;
      
      /* try to find a fallback character */
      l = context->language;
      GetFallbackCharacter (code, buffer, &lang);
      
      /* put that fallback character in the new text leaf */
      TtaSetTextContent (elText, buffer, lang, context->doc);
      context->language = l;
      
      /* make that text leaf read-only */
      TtaSetAccessRight (elText, ReadOnly, context->doc);
      
      /* associate an attribute EntityName with the new text leaf */
      attrType.AttrSSchema = TtaGetDocumentSSchema (context->doc);
      attrType.AttrTypeNum = HTML_ATTR_EntityName;
      attr = TtaNewAttribute (attrType);
      TtaAttachAttribute (elText, attr, context->doc);
      ustrcpy (buffer, prefix);
      ustrcat (buffer, entityName);
      TtaSetAttributeText (attr, buffer, elText, context->doc);
      context->mergeText = FALSE;
   }
   
   /*----------------------------------------------------------------------
      XhtmlEntityCreated
      A XTHML entity has been created by the XML parser.
     ----------------------------------------------------------------------*/
   #ifdef __STDC__
   void        XhtmlEntityCreated (int entityValue, Language lang,
                                   STRING entityName, ParserData *context)
   #else
   void        XhtmlEntityCreated (entityValue, lang, entityName, context)
   int         entityValue;
   Language    lang;
   STRING      entityName;
   ParserData *context;
   #endif
   { 
     CHAR_T    buffer[2];
   
     if (lang < 0)
       PutInXmlElement (entityName);
     else
       {
         if (entityValue < 255)
           {
             buffer[0] = ((UCHAR_T) entityValue);
             buffer[1] = WC_EOS;
             PutInXmlElement (buffer);
           }
         else
           PutNonISOlatin1Char (entityValue, TEXT(""), entityName, context);
       }
   }
   
 /*----------------------------------------------------------------------  /*----------------------------------------------------------------------
   XhtmlElementComplete    XhtmlElementComplete
   Complete Xhtml elements.    Complete Xhtml elements.
Line 559  Document   doc; Line 678  Document   doc;
 int       *error;  int       *error;
 #endif  #endif
 {  {
    ElementType         elType, newElType, childType;     ElementType       elType, newElType, childType;
    Element             constElem, child, desc, leaf, prev, next, last,     Element           constElem, child, desc, leaf, prev, next, last,
                        elFrames, lastFrame, lastChild;                       elFrames, lastFrame, lastChild;
    Attribute           attr;     Attribute         attr;
    AttributeType       attrType;     AttributeType     attrType;
    Language            lang;     Language          lang;
    STRING              text;     STRING            text;
    CHAR_T              lastChar[2];     CHAR_T            lastChar[2];
    STRING              name1;     STRING            name1;
    int                 length;     int               length;
    SSchema             docSSchema;     SSchema           docSSchema;
   
    *error = 0;     *error = 0;
    docSSchema = TtaGetDocumentSSchema (doc);     docSSchema = TtaGetDocumentSSchema (doc);
Line 927  void            MapHTMLAttributeValue (C Line 1046  void            MapHTMLAttributeValue (C
                                        AttributeType attrType,                                         AttributeType attrType,
                                        int* value)                                         int* value)
 #else  #else
 void            MapHTMLAttributeValue (AttrVal,  void            MapHTMLAttributeValue (AttrVal, attrType, value)
                                        attrType,  
                                        value)  
 CHAR_T*         AttrVal;  CHAR_T*         AttrVal;
 AttributeType   attrType;  AttributeType   attrType;
 int*            value;  int*            value;
Line 955  int*            value; Line 1072  int*            value;
               XhtmlAttrValueMappingTable[i].ThotAttr != 0);                XhtmlAttrValueMappingTable[i].ThotAttr != 0);
      }       }
 }  }
   
 /*---------------------------------------------------------------------------  
    XhtmlMapEntity  
    Search that entity in the entity table and return the corresponding value.  
   ---------------------------------------------------------------------------*/  
 #ifdef __STDC__  
 void    XhtmlMapEntity (STRING entityName, int *entityValue, STRING alphabet)  
 #else  
 void    XhtmlMapEntity (entityName, entityValue, alphabet)  
 STRING  entityName;  
 int    *entityValue;  
 STRING  alphabet;  
 #endif  
 {  
   int            i;  
   ThotBool       found;  
   
   found = FALSE;  
   for (i = 0; XhtmlEntityTable[i].charCode >= 0 && ! found; i++)  
      found = !ustrcmp (XhtmlEntityTable[i].charName, entityName);  
   
   if (found)  
     {  
       /* entity found */  
       i--;  
       *entityValue = XhtmlEntityTable[i].charCode;  
       *alphabet = 'L';  
     }  
   else  
     *alphabet = EOS;  
 }  
   
 /*----------------------------------------------------------------------  
   PutNonISOlatin1Char       
   Put a Unicode character in the input buffer.  
   ----------------------------------------------------------------------*/  
 #ifdef __STDC__  
 static void    PutNonISOlatin1Char (int code, STRING prefix, STRING entityName, ParserData *context)  
 #else  
 static void    PutNonISOlatin1Char (code, prefix, entityName, context)  
 int            code;  
 STRING         prefix;  
 STRING         entityName;  
 ParserData    *context;  
 #endif  
 {  
    Language      lang, l;  
    ElementType   elType;  
    Element       elText;  
    AttributeType attrType;  
    Attribute     attr;  
    CHAR_T        buffer[MaxEntityLength+10];  
   
    if (context->readingAnAttrValue)  
      /* this entity belongs to an attribute value */  
      {  
        /* Thot can't mix different languages in the same attribute value */  
        /* just discard that character */  
        ;  
      }  
    else  
      /* this entity belongs to the element contents */  
      {  
        /* create a new text leaf */  
        elType.ElSSchema = TtaGetDocumentSSchema (context->doc);  
        elType.ElTypeNum = HTML_EL_TEXT_UNIT;  
        elText = TtaNewElement (context->doc, elType);  
        XmlSetElemLineNumber (elText);  
        XhtmlInsertElement (&elText);  
        context->lastElement = elText;  
        context->lastElementClosed = FALSE;  
        context->lastElementClosed = TRUE;  
   
        /* try to find a fallback character */  
        l = context->language;  
        GetFallbackCharacter (code, buffer, &lang);  
   
        /* put that fallback character in the new text leaf */  
        TtaSetTextContent (elText, buffer, lang, context->doc);  
        context->language = l;  
   
        /* make that text leaf read-only */  
        TtaSetAccessRight (elText, ReadOnly, context->doc);  
   
        /* associate an attribute EntityName with the new text leaf */  
        attrType.AttrSSchema = TtaGetDocumentSSchema (context->doc);  
        attrType.AttrTypeNum = HTML_ATTR_EntityName;  
        attr = TtaNewAttribute (attrType);  
        TtaAttachAttribute (elText, attr, context->doc);  
        ustrcpy (buffer, prefix);  
        ustrcat (buffer, entityName);  
        TtaSetAttributeText (attr, buffer, elText, context->doc);  
        context->mergeText = FALSE;  
      }  
 }  
   
 /*----------------------------------------------------------------------  
    XhtmlEntityCreated  
    A XTHML entity has been created by the XML parser.  
   ----------------------------------------------------------------------*/  
 #ifdef __STDC__  
 void        XhtmlEntityCreated (int entityVal, Language lang, STRING entityName, ParserData *context)  
 #else  
 void        XhtmlEntityCreated (entityVal, lang, entityName, context)  
 int         entityVal;  
 Language    lang;  
 STRING      entityName;  
 ParserData *context;  
 #endif  
 {   
   CHAR_T         buffer[2];  
   
   if (lang < 0)  
     PutInXmlElement (entityName);  
   else  
     {  
 #ifdef LC  
       printf (" \n code=%d", entityVal);  
 #endif /* LC */  
       if (entityVal < 255)  
         {  
           buffer[0] = TEXT(entityVal);  
           buffer[1] = WC_EOS;  
           PutInXmlElement (buffer);  
         }  
       else  
         PutNonISOlatin1Char (entityVal, TEXT(""), entityName, context);  
     }  
 }  

Removed from v.1.22  
changed lines
  Added in v.1.23


Webmaster