Referindo-se a js0n.c
A sintaxe do código é a seguinte:
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;
........
........
Alguém pode explicar o que está sendo feito aqui? O que a sintaxe [0 ... 255]
e
&&l_bad
faz aqui?
c
gcc-extensions
Gaurav K
fonte
fonte
&
código dobrado entrando em produção!).&&
é um token totalmente separado de&
, portanto, não há como a gramática C padrão interpretar&&x
como "endereço de endereço de x", independentemente da categoria de valor de&x
.--
é sempre analisado como--
e&&
sempre é analisado como&&
. C99 §6.4¶4: o próximo token de pré-processamento é a mais longa sequência de caracteres que poderia constituir um token de pré-processamento