代码拉取完成,页面将自动刷新
同步操作将从 Josin/Exjson 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
%{
#include <stdio.h>
#include <stdlib.h>
#include "stack.h"
#include "exjson.h"
extern int yylex();
extern int yylineno;
extern char *yytext;
int _status = 1;
typedef struct yy_buffer_state * YY_BUFFER_STATE;
extern int yyparse();
extern YY_BUFFER_STATE yy_scan_string(char * str);
extern void yy_delete_buffer(YY_BUFFER_STATE buffer);
extern void yyerror(char *);
/* (INT: 2) (DOUBLE: 3) (STR: 4)
* (ARRAY: 5) (OBJECT: 6) (true 7)
* (false: 8) (null: 9) */
E_STACK *value_stack,
*exjson_stack;
EXJSON *exjson;
E_STACK_V *temp_exjson_stack;
%}
%union {
struct {
long ival;
double dval;
void *ptr;
unsigned char val_type;
} val;
}
%token<val> T_INT T_STR T_DOUBLE
%type<val> object array object_key_pair array_data value
%%
json
: object
| array
;
object
: '{' object_key_pair '}'
{
}
;
array
: '[' array_data ']'
{
}
;
object_key_pair
: T_STR ':' value
{
switch ($3.val_type)
{
case SV_INT:
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_object_int(exjson, $1.ptr, $3.ival);
break;
case SV_DOUBLE:
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_object_double(exjson, $1.ptr, $3.dval);
break;
case SV_STRING:
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_object_string(exjson, $1.ptr, $3.ptr);
break;
case SV_ARRAY:
temp_exjson_stack = pop(exjson_stack);
if ( SV_NEXT_P(temp_exjson_stack) )
{
exjson = SV_DATA_P(SV_NEXT_P(temp_exjson_stack));
}
else
{
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
}
add_object_array(exjson, $1.ptr, SV_DATA_P(temp_exjson_stack));
break;
case SV_OBJECT:
temp_exjson_stack = pop(exjson_stack);
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_object_object(exjson, $1.ptr, SV_DATA_P(temp_exjson_stack));
break;
}
}
| object_key_pair ',' T_STR ':' value
{
switch ($5.val_type)
{
case SV_INT:
add_object_int(exjson, $3.ptr, $5.ival);
break;
case SV_DOUBLE:
add_object_double(exjson, $3.ptr, $5.dval);
break;
case SV_STRING:
add_object_string(exjson, $3.ptr, $5.ptr);
break;
case SV_ARRAY:
temp_exjson_stack = pop(exjson_stack);
add_object_array(SV_DATA_P(SV_NEXT_P(temp_exjson_stack)), $3.ptr, SV_DATA_P(temp_exjson_stack));
exjson = SV_DATA_P(SV_NEXT_P(temp_exjson_stack));
break;
case SV_OBJECT:
temp_exjson_stack = pop(exjson_stack);
add_object_object(SV_DATA_P(SV_NEXT_P(temp_exjson_stack)), $3.ptr, SV_DATA_P(temp_exjson_stack));
exjson = SV_DATA_P(SV_NEXT_P(temp_exjson_stack));
break;
}
}
;
array_data
: value
{
switch ($1.val_type)
{
case SV_INT:
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_array_int(exjson, $1.ival);
break;
case SV_DOUBLE:
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_array_double(exjson, $1.dval);
break;
case SV_STRING:
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_array_string(exjson, $1.ptr);
break;
case SV_ARRAY:
/* array */
temp_exjson_stack = pop(exjson_stack);
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_array_array(exjson, SV_DATA_P(temp_exjson_stack));
break;
case SV_OBJECT:
/* object */
temp_exjson_stack = pop(exjson_stack);
exjson = INIT_EXJSON();
push(exjson_stack, exjson, 0);
add_array_object(exjson, SV_DATA_P(temp_exjson_stack));
break;
}
}
| array_data ',' value
{
switch ($3.val_type)
{
case SV_INT:
add_array_int(exjson, $3.ival);
break;
case SV_DOUBLE:
add_array_double(exjson, $3.dval);
break;
case SV_STRING:
add_array_string(exjson, $3.ptr);
break;
case SV_ARRAY:
temp_exjson_stack = pop(exjson_stack);
add_array_array(SV_DATA_P(SV_NEXT_P(temp_exjson_stack)), SV_DATA_P(temp_exjson_stack));
exjson = SV_DATA_P(SV_NEXT_P(temp_exjson_stack));
break;
case SV_OBJECT:
temp_exjson_stack = pop(exjson_stack);
add_array_object(SV_DATA_P(SV_NEXT_P(temp_exjson_stack)), SV_DATA_P(temp_exjson_stack));
exjson = SV_DATA_P(SV_NEXT_P(temp_exjson_stack));
break;
}
}
;
value
: T_STR
{
$$ = $1;
}
| T_INT
{
$$ = $1;
}
| T_DOUBLE
{
$$ = $1;
}
| array
{
$$.val_type = SV_ARRAY;
}
| object
{
$$.val_type = SV_OBJECT;
}
;
%%
/* Remember that the return value need be freed by destroy_exjson() function
* Other than memory leak may be occcured.
*/
EXJSON *decode_json(char *json_string)
{
exjson_stack = INIT_STACK();
value_stack = INIT_STACK();
exjson = INIT_EXJSON();
YY_BUFFER_STATE buffer = yy_scan_string(json_string);
yyparse();
yy_delete_buffer(buffer);
destroy_stack(value_stack);
if ( !_status ) { destroy_exjson(exjson); return NULL; }
return exjson;
}
void yyerror(char *msg)
{
_status = 0;
fprintf(stderr, "\n%d: %s at '%s'\n", yylineno, msg, yytext);
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。