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

22
LINES

< > BotCompany Repo | #1018097 // matchStartUsingWordTree_all - return all options

JavaX fragment (include)

// tok = CNC
// returns [(index, tree leaf)]
static LPair<Int, O> matchStartUsingWordTree_all(L<S> tok, Map<S, O> tree) {
  O best = null; // best leaf
  int bestIndex = 0; // best index
  
  int j = 1;
  LPair<Int, O> out = new L;
  while (j < l(tok)) {
    O def = tree.get("<default>");
    if (def != null) { best = def; bestIndex = j; }
   
    O t = tree.get(tok.get(j));
    j += 2;
    if (t == null) break;
    if (!t instanceof Map) break with addPair(out, j, t); // leaf!
    tree = (Map) t;
  }
  
  if (best != null) addPair(out, bestIndex, best);
  ret out;
}

Author comment

Began life as a copy of #1017908

download  show line numbers  debug dex  old transpilations   

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

No comments. add comment

Snippet ID: #1018097
Snippet name: matchStartUsingWordTree_all - return all options
Eternal ID of this version: #1018097/3
Text MD5: 72c46ae4c6a91bf28afd579c9745903f
Author: stefan
Category: javax / a.i.
Type: JavaX fragment (include)
Public (visible to everyone): Yes
Archived (hidden from active list): No
Created/modified: 2018-09-02 12:49:38
Source code size: 594 bytes / 22 lines
Pitched / IR pitched: No / No
Views / Downloads: 291 / 356
Version history: 2 change(s)
Referenced in: #1006654 - Standard functions list 2 (LIVE, continuation of #761)
#1018103 - matchEndUsingWordTree_all - return all options