- getch();
- break;
- }
- case 'a': {
- result->kind = JSONNodeKind_Arr;
- while ((c = peekch()), (c != '\r') && (c != '\n')) {
- JSONNodePush(result, GetNode(result));
+ else {
+ JSONNode * old = node;
+
+ /**/ if (c == 'i') { node = JSONNodeNew(JSONNodeKind_Int); editingNode = true; }
+ else if (c == 's') { node = JSONNodeNew(JSONNodeKind_Str); editingNode = true; }
+ else if (c == 'o') { node = JSONNodeNew(JSONNodeKind_Obj); }
+ else if (c == 'a') { node = JSONNodeNew(JSONNodeKind_Arr); }
+ else if (c == 'h') { if (node->prev != NULL) g_CurrNode = node = node->prev; continue; }
+ else if (c == 'l') { if (node->next != NULL) g_CurrNode = node = node->next; continue; }
+ else if (c == 'k') { if (node->parent != NULL) g_CurrNode = node = node->parent; continue; }
+ else if (c == 'j') { if (node->firstChild != NULL) g_CurrNode = node = node->firstChild; continue; }
+ else if (c == ' ') { if (JSONNodeEditable(node)) editingNode = true; continue; }
+ else if (isBackspace(c) && node != NULL) { g_CurrNode = node = JSONNodeRemove(node); continue; }
+ else { continue; }
+
+ if (old != NULL) {
+ // new node was added to an object
+ if (old->kind == JSONNodeKind_Obj) {
+ JSONNode * keyNode = JSONNodeNew(JSONNodeKind_Str);
+ JSONNodePush(keyNode, node);
+ node = keyNode;
+ editingNode = true;
+ }
+ JSONNodePush(old, node);
+ }
+ else {
+ g_DrawNode = result = node;
+ }
+
+ g_CurrNode = node;