Haciendo referencia a js0n.c
La sintaxis del código es la siguiente:
static void *gostruct[] =
{
[0 ... 255] = &&l_bad,
['\t'] = &&l_loop, [' '] = &&l_loop, ['\r'] = &&l_loop, ['\n'] = &&l_loop,
['"'] = &&l_qup,
[':'] = &&l_loop, [','] = &&l_loop,
['['] = &&l_up, [']'] = &&l_down, // tracking [] and {} individually would allow fuller validation but is really messy
['{'] = &&l_up, ['}'] = &&l_down,
['-'] = &&l_bare, [48 ... 57] = &&l_bare, // 0-9
[65 ... 90] = &&l_bare, // A-Z
[97 ... 122] = &&l_bare // a-z
};
........
.......
l_bad:
*vlen = cur - json; // where error'd
return 0;
........
........
¿Alguien puede explicar qué se está haciendo aquí? ¿Qué hace la sintaxis [0 ... 255]
y
&&l_bad
aquí?
fuente
&
ingresar al código de producción).&&
es un token completamente separado de&
, por lo que no hay forma de que la gramática C estándar pueda interpretarse&&x
como "dirección de la dirección de x" independientemente de la categoría de valor de&x
.--
siempre se analiza como--
y&&
siempre se analiza como&&
. C99 §6.4¶4: el siguiente token de preprocesamiento es la secuencia más larga de caracteres que podría constituir un token de preprocesamiento