1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
|
*/
#define ARG_INTEGER 1
#define ARG_NUMBER 2
#define ARG_STRING 3
static Operator aOperator[] = {
{"(", OP_OPEN_BRACKET, -1, 0},
{")", OP_CLOSE_BRACKET, -1, 0},
/* Note: all unary operators have (iPrecedence==1) */
{"-", OP_UNARY_MINUS, 1, ARG_NUMBER},
{"+", OP_UNARY_PLUS, 1, ARG_NUMBER},
{"~", OP_BITWISE_NOT, 1, ARG_INTEGER},
{"!", OP_LOGICAL_NOT, 1, ARG_INTEGER},
/* Binary operators. It is important to the parsing in Th_Expr() that
* the two-character symbols ("==") appear before the one-character
* ones ("="). And that the priorities of all binary operators are
* integers between 2 and 12.
*/
{"<<", OP_LEFTSHIFT, 4, ARG_INTEGER},
{">>", OP_RIGHTSHIFT, 4, ARG_INTEGER},
{"<=", OP_LE, 5, ARG_NUMBER},
{">=", OP_GE, 5, ARG_NUMBER},
{"==", OP_EQ, 6, ARG_NUMBER},
{"!=", OP_NE, 6, ARG_NUMBER},
{"eq", OP_SEQ, 7, ARG_STRING},
{"ne", OP_SNE, 7, ARG_STRING},
{"&&", OP_LOGICAL_AND, 11, ARG_INTEGER},
{"||", OP_LOGICAL_OR, 12, ARG_INTEGER},
{"*", OP_MULTIPLY, 2, ARG_NUMBER},
{"/", OP_DIVIDE, 2, ARG_NUMBER},
{"%", OP_MODULUS, 2, ARG_INTEGER},
{"+", OP_ADD, 3, ARG_NUMBER},
{"-", OP_SUBTRACT, 3, ARG_NUMBER},
{"<", OP_LT, 5, ARG_NUMBER},
{">", OP_GT, 5, ARG_NUMBER},
{"&", OP_BITWISE_AND, 8, ARG_INTEGER},
{"^", OP_BITWISE_XOR, 9, ARG_INTEGER},
{"|", OP_BITWISE_OR, 10, ARG_INTEGER},
{0,0,0,0}
};
/*
** The first part of the string (zInput,nInput) contains an integer.
** Set *pnVarname to the number of bytes in the numeric string.
*/
static int thNextInteger(
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
|
*/
#define ARG_INTEGER 1
#define ARG_NUMBER 2
#define ARG_STRING 3
static Operator aOperator[] = {
{"(", 1, OP_OPEN_BRACKET, -1, 0},
{")", 1, OP_CLOSE_BRACKET, -1, 0},
/* Note: all unary operators have (iPrecedence==1) */
{"-", 1, OP_UNARY_MINUS, 1, ARG_NUMBER},
{"+", 1, OP_UNARY_PLUS, 1, ARG_NUMBER},
{"~", 1, OP_BITWISE_NOT, 1, ARG_INTEGER},
{"!", 1, OP_LOGICAL_NOT, 1, ARG_INTEGER},
/* Binary operators. It is important to the parsing in Th_Expr() that
* the two-character symbols ("==") appear before the one-character
* ones ("="). And that the priorities of all binary operators are
* integers between 2 and 12.
*/
{"<<", 2, OP_LEFTSHIFT, 4, ARG_INTEGER},
{">>", 2, OP_RIGHTSHIFT, 4, ARG_INTEGER},
{"<=", 2, OP_LE, 5, ARG_NUMBER},
{">=", 2, OP_GE, 5, ARG_NUMBER},
{"==", 2, OP_EQ, 6, ARG_NUMBER},
{"!=", 2, OP_NE, 6, ARG_NUMBER},
{"eq", 2, OP_SEQ, 7, ARG_STRING},
{"ne", 2, OP_SNE, 7, ARG_STRING},
{"&&", 2, OP_LOGICAL_AND, 11, ARG_INTEGER},
{"||", 2, OP_LOGICAL_OR, 12, ARG_INTEGER},
{"*", 1, OP_MULTIPLY, 2, ARG_NUMBER},
{"/", 1, OP_DIVIDE, 2, ARG_NUMBER},
{"%", 1, OP_MODULUS, 2, ARG_INTEGER},
{"+", 1, OP_ADD, 3, ARG_NUMBER},
{"-", 1, OP_SUBTRACT, 3, ARG_NUMBER},
{"<", 1, OP_LT, 5, ARG_NUMBER},
{">", 1, OP_GT, 5, ARG_NUMBER},
{"&", 1, OP_BITWISE_AND, 8, ARG_INTEGER},
{"^", 1, OP_BITWISE_XOR, 9, ARG_INTEGER},
{"|", 1, OP_BITWISE_OR, 10, ARG_INTEGER},
{0,0,0,0,0}
};
/*
** The first part of the string (zInput,nInput) contains an integer.
** Set *pnVarname to the number of bytes in the numeric string.
*/
static int thNextInteger(
|