sbool checkNTokenHygiene(L tok) { ret l(tok) == 1 || checkNTokenHygiene_forward(tok) && checkNTokenHygiene_backward(tok); } sbool checkNTokenHygiene_forward(L tok) { int level = 0; for (int i = 0; i < l(tok)-1; i += 2) { S t = tok.get(i); if (i == 0) t = substring(t, lastIndexOf(t, '}')+1); for (char c : characters(t)) if (c == '{') ++level; else if (c == '}') level = max(0, level-1); } if (level == 0) true; for (char c : characters(last(tok))) if (c == '}') if (--level == 0) true; false; } sbool checkNTokenHygiene_backward(L tok) { int level = 0; for (int i = l(tok)-1; i > 0; i -= 2) { S t = tok.get(i); if (i == l(tok)-1) t = substring(t, 0, smartIndexOf(t, '{')); for (char c : reversedCharacters(print("tok", tok.get(i)))) if (c == '}') ++level; else if (c == '{') level = max(0, level-1); } if (level == 0) true; for (char c : reversedCharacters(first(tok))) if (c == '{') if (--level == 0) true; false; }