- if (parent != NULL && node != NULL)
- JSONNodePush(parent, node);
-
- switch (c) {
- case 'i': {
- node->kind = JSONNodeKind_Int;
- GetStr(node, predInt);
- break;
- }
- case 's': {
- node->kind = JSONNodeKind_Str;
- GetStr(node, predStr);
- break;
- }
- case 'o': {
- node->kind = JSONNodeKind_Obj;
- while ((c = PeekChar()), (c != '\r') && (c != '\n')) {
- JSONNode * newNode;
-
- newNode = JSONNodeNewStr("");
- g_CurrNode = newNode;
- JSONNodePush(node, newNode);
- GetStr(newNode, predStr);
-
- newNode = JSONNodeNewNul();
- JSONNodePush(node, newNode);
- GetNode(node, newNode);
+ if (editingNode) {
+ if (JSONNodeEditable(node)) {
+ if (node->data == (size_t)NULL) {
+ node->data = (size_t)NEWARR(char, 16);
+ strLen = 0;
+ }
+
+ char * str = (char *)node->data;
+
+ if (isBackspace(c)) {
+ str[strLen-1] = '\0';
+ strLen--;
+ }
+ else if (strLen < 16 - 1) {
+ str[strLen] = c;
+ str[strLen+1] = '\0';
+ strLen++;
+ }
+ }
+ else {
+ if (node->kind == JSONNodeKind_Obj) {
+ /**/ if (c == 'i') { node = JSONNodePush(node, JSONNodePush(JSONNodeNew(JSONNodeKind_Str), JSONNodeNew(JSONNodeKind_Int))->parent); }
+ else if (c == 's') { node = JSONNodePush(node, JSONNodePush(JSONNodeNew(JSONNodeKind_Str), JSONNodeNew(JSONNodeKind_Str))->parent); }
+ else if (c == 'o') { node = JSONNodePush(node, JSONNodePush(JSONNodeNew(JSONNodeKind_Str), JSONNodeNew(JSONNodeKind_Obj))->parent); }
+ else if (c == 'a') { node = JSONNodePush(node, JSONNodePush(JSONNodeNew(JSONNodeKind_Str), JSONNodeNew(JSONNodeKind_Arr))->parent); }
+ }
+ else if (node->kind == JSONNodeKind_Arr) {
+ /**/ if (c == 'i') { node = JSONNodePush(node, JSONNodeNew(JSONNodeKind_Int)); }
+ else if (c == 's') { node = JSONNodePush(node, JSONNodeNew(JSONNodeKind_Str)); }
+ else if (c == 'o') { node = JSONNodePush(node, JSONNodeNew(JSONNodeKind_Obj)); }
+ else if (c == 'a') { node = JSONNodePush(node, JSONNodeNew(JSONNodeKind_Arr)); }
+ }
+ g_CurrNode = node;
+ }