// keyword can comprise multiple tokens now (like "p-awt"}
static L<S> replaceKeywordBlock(L<S> tok, S keyword, S beg, S end) {
  ret replaceKeywordBlock(tok, keyword, beg, end, false, null);
}

static L<S> replaceKeywordBlock(L<S> tok, S keyword, S beg, S end, O cond) {
  ret replaceKeywordBlock(tok, keyword, beg, end, false, cond);
}

static L<S> replaceKeywordBlock(L<S> tok, S keyword, S beg, S end,
  bool debug, O cond) {
  for (int n = 0; n < 1000; n++) {
    int i = jfind(tok, keyword + " {", cond);
    if (i < 0)
      break;
    int idx = findCodeTokens(tok, i, false, "{");
    int j = findEndOfBracketPart(tok, idx);
    
    if (debug) {
      print(toUpper(keyword) + " BEFORE\n" + join(subList(tok, i, j)));
      print("  THEN " + join(subList(tok, j, j+10)));
    }
    //assertEquals("}", tok.get(j-1));
    LS subList = subList(tok, i-1, idx); // N to somewhere
    tok.set(j-1, jreplaceExpandRefs(end, subList));
    replaceTokens(tok, i, idx+1, jreplaceExpandRefs(beg, subList));
    reTok(tok, i, j);
    if (debug) print(toUpper(keyword) + "\n" + join(subList(tok, i, j)) + "\n");
  }
  ret tok;
}