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

59
LINES

< > BotCompany Repo | #1014205 // translateUsingWordTree - uses javaTok (doesn't ignore punctuation)

JavaX fragment (include)

sbool translateUsingWordTree_debug;
sbool translateUsingWordTree_printReplacements;

sS translateUsingWordTree(S input, Map<S, O> tree) {  
  ret empty(input) ? input : join(translateUsingWordTree(javaTok(input), tree));
}
  
static L<S> translateUsingWordTree(L<S> tok, Map<S, O> tree) {  
  for (int i = 1; i < l(tok); )
    i = translateUsingWordTree_scanFrom(tok, i, tree);
  ret tok;
}
      
// returns index of first unreplaced token
// every replacement ends up as a single token plus some ""
static int translateUsingWordTree_scanFrom(L<S> tok, int i, Map<S, O> tree) {
  int j = i;
  S best = null; // best replacement found
  int bestIndex = 0; // till where to replace
  
  while true {
    if (j > i) { // no default in root!
      S def = cast tree.get("<default>");
      if (def != null) {
        best = def; bestIndex = j;
        //print("best solution: " + sfu(bestSolution));
      }
    }
   
    if (j >= l(tok)) break;
    
    O t = tree.get(tok.get(j));
    if (translateUsingWordTree_debug)
      print(i + "-" + j + " / " + joinSubList(tok, i, j+1) + " => " + sfu(t));
    if (t == null) break;
    if (t instanceof S) {
      int k = j+2;
      if (translateUsingWordTree_printReplacements)
        print("translateUsingWordTree: replacing " + sfu(subList(tok, i, k-1) + " with " + quote(t));
      replaceTokens(tok, i, k-1, (S) t);
      ret k;
    }
    tree = (Map) t;
    j += 2;
  }
  
  if (best != null) {
    int k = bestIndex;
    replaceTokens(tok, i, k-1, best);
    ret k;
  }
  ret i+2;
}



sS translateUsingWordTree(Map<S, O> tree, S input) {
  ret translateUsingWordTree(input, tree);
}

download  show line numbers  debug dex  old transpilations   

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

No comments. add comment

Snippet ID: #1014205
Snippet name: translateUsingWordTree - uses javaTok (doesn't ignore punctuation)
Eternal ID of this version: #1014205/17
Text MD5: 0b7dd3f2c8664bf124212a5615a90c2b
Author: stefan
Category: javax / a.i.
Type: JavaX fragment (include)
Public (visible to everyone): Yes
Archived (hidden from active list): No
Created/modified: 2020-03-24 01:36:55
Source code size: 1690 bytes / 59 lines
Pitched / IR pitched: No / No
Views / Downloads: 329 / 368
Version history: 16 change(s)
Referenced in: #1006654 - Standard functions list 2 (LIVE, continuation of #761)
#1014764 - translateUsingWordTreeC - works on code token parses
#1017474 - groupUsingWordTree - uses curly brackets; values of word tree don't matter [dev.]