From 9e3ddd1e2cd95d993aa9343a36a472964a80d1a8 Mon Sep 17 00:00:00 2001 From: hyung-hwan Date: Sun, 29 Jul 2018 08:01:43 +0000 Subject: [PATCH] added more code to read_object_in_cli_mode() --- lib/read.c | 36 +++++++++++++++++++++++++++++++++--- 1 file changed, 33 insertions(+), 3 deletions(-) diff --git a/lib/read.c b/lib/read.c index 4f816c7..11b9619 100644 --- a/lib/read.c +++ b/lib/read.c @@ -2226,25 +2226,55 @@ static int read_object_in_cli_mode (hcl_t* hcl) if (begin_include(hcl) <= -1) return -1; goto redo; + case HCL_IOTOK_LPAREN: /* () */ + flagv = 0; + LIST_FLAG_SET_CONCODE (flagv, HCL_CONCODE_XLIST); + start_list: + if (level >= HCL_TYPE_MAX(int)) + { + /* the nesting level has become too deep */ + hcl_setsynerr (hcl, HCL_SYNERR_NESTING, TOKEN_LOC(hcl), TOKEN_NAME(hcl)); + return -1; + } + + /* push some data to simulate recursion into + * a list literal or an array literal */ + if (enter_list(hcl, flagv) == HCL_NULL) return -1; + level++; + if (LIST_FLAG_GET_CONCODE(flagv) == HCL_CONCODE_ARRAY) array_level++; + + /* read the next token */ + GET_TOKEN (hcl); + goto redo; + case HCL_IOTOK_EOL: + case HCL_IOTOK_RPAREN: { int oldflagv; //int concode; if (level <= 0) { + unbalpbb: hcl_setsynerr (hcl, HCL_SYNERR_UNBALPBB, TOKEN_LOC(hcl), HCL_NULL); return -1; } + if (level == 1 && TOKEN_TYPE(hcl) != HCL_IOTOK_EOL) goto unbalpbb; + //concode = LIST_FLAG_GET_CONCODE(flagv); obj = leave_list (hcl, &flagv, &oldflagv); level--; //if (LIST_FLAG_GET_CONCODE(oldflagv) == HCL_CONCODE_ARRAY) array_level--; - goto done; + goto done ; } + case HCL_IOTOK_NUMLIT: + case HCL_IOTOK_RADNUMLIT: + obj = string_to_num(hcl, TOKEN_NAME(hcl), TOKEN_TYPE(hcl) == HCL_IOTOK_RADNUMLIT); + break; + case HCL_IOTOK_STRLIT: case HCL_IOTOK_IDENT: obj = hcl_makestring(hcl, TOKEN_NAME_PTR(hcl), TOKEN_NAME_LEN(hcl), 0); @@ -2254,11 +2284,11 @@ static int read_object_in_cli_mode (hcl_t* hcl) if (!obj) return -1; /* check if we are at the top level */ - //if (level <= 0) break; /* yes */ + if (level <= 0) break; /* yes */ /* if not, append the element read into the current list. * if we are not at the top level, we must be in a list */ - //if (chain_to_list(hcl, obj) == HCL_NULL) return -1; + if (chain_to_list(hcl, obj) == HCL_NULL) return -1; clear_comma_colon_flag (hcl); /* read the next token */