Not logged in.  Login/Logout/Register | List snippets | | Create snippet | Upload image | Upload data

72
LINES

< > BotCompany Repo | #1002839 // nlParse

JavaX fragment (include)

1  
static new AtomicInteger nlParse_count; // how often did we parse something?
2  
3  
static Lisp nlParse(S s) {
4  
  ret nlParse(s, true);
5  
}
6  
7  
static Lisp nlParse(S s, boolean unbracket) {
8  
  ret nlParse(codeTokens(snlTok(s)), unbracket, false, null);
9  
}
10  
11  
static Lisp nlParse(S s, boolean unbracket, boolean explicitBrackets) {
12  
  ret nlParse(codeTokens(snlTok(s)), unbracket, explicitBrackets, null);
13  
}
14  
15  
static Lisp nlParse(L<S> tok) {
16  
  ret nlParse(tok, true, false, null);
17  
}
18  
19  
// unbracket refers to outermost brackets
20  
// explicitBrackets refers to inner brackets
21  
static Lisp nlParse(L<S> tok, boolean unbracket, final boolean explicitBrackets, L<S> warnings) {
22  
  nlParse_count.incrementAndGet();
23  
  
24  
  class Entry {
25  
    int i;
26  
    Lisp tree;
27  
    S wrapper;
28  
    
29  
    *(int *i) {
30  
      tree = lisp("[]");
31  
    }
32  
    
33  
    *(int *i, S bracket) {
34  
      tree = lisp("[]");
35  
      wrapper = bracket;
36  
    }
37  
    
38  
    Lisp wrapped() {
39  
      Lisp t = explicitBrackets ? tree : nlUnbracket(tree);
40  
      ret wrapper == null ? t : lisp(wrapper, t);
41  
    }
42  
  }
43  
44  
  new L<Entry> stack;
45  
  stack.add(new Entry(0));
46  
  
47  
  for (int i = 0; i < l(tok); i++) {
48  
    S t = tok.get(i);
49  
    if (eq(t, "[") || eq(t, "(")) {
50  
      stack.add(new Entry(i, eq(t, "(") ? "()" : null));
51  
    } else if (eq(t, "]") || eq(t, ")")) {
52  
      if (l(stack) == 1)
53  
        warn("too many closing brackets", warnings);
54  
      else {
55  
        Entry e = popLast(stack);
56  
        /*if (!bracketsMatch(tok.get(e.i), t))
57  
          warn("non-matching brackets");*/
58  
        last(stack).tree.add(e.wrapped());
59  
      }
60  
    } else
61  
      last(stack).tree.add(t);
62  
  }
63  
  
64  
  while (l(stack) > 1) {
65  
    warn("too many opening brackets", warnings);
66  
    Entry e = popLast(stack);
67  
    last(stack).tree.add(e.wrapped());
68  
  }
69  
  
70  
  Lisp result = last(stack).wrapped();
71  
  ret unbracket ? nlUnbracket(result) : result;
72  
}

download  show line numbers  debug dex  old transpilations   

Travelled to 13 computer(s): aoiabmzegqzx, bhatertpkbcr, cbybwowwnfue, cfunsshuasjs, gwrvuhgaqvyk, ishqpsrjomds, lpdgvwnxivlt, mqqgnosmbjvj, pyentgdyhuwx, pzhvpgtvlbxg, tslmcundralx, tvejysmllsmz, vouqrxazstgt

No comments. add comment

Snippet ID: #1002839
Snippet name: nlParse
Eternal ID of this version: #1002839/1
Text MD5: 5f482de23f9ca0569efe9f8bd4866911
Author: stefan
Category: javax
Type: JavaX fragment (include)
Public (visible to everyone): Yes
Archived (hidden from active list): No
Created/modified: 2016-04-10 23:06:33
Source code size: 1905 bytes / 72 lines
Pitched / IR pitched: No / No
Views / Downloads: 644 / 826
Referenced in: [show references]