static new ThreadLocal applyNLLogicFacts_v2_verbose; svoid applyNLLogicFacts_v2(S input, VF1 postMessage) { applyNLLogicFacts_v2(input, postMessage, mL_facts()); } svoid applyNLLogicFacts_v2(S input, VF1 postMessage, LS facts) { applyNLLogicFacts_v2(input, postMessage, facts, ai_mL_parsedLogicExamples()); } svoid applyNLLogicFacts_v2(S input, VF1 postMessage, LS facts, L> rules) { new NLLogicChecker_v2 c; c.matcher = new NLStringMatcher_dollarVars; addAll(c.facts, facts); c.input = input; applyNLLogicFacts_v2(c, postMessage, rules); } svoid applyNLLogicFacts_v2(NLLogicChecker_v2 c, VF1 postMessage, L> rules) { for (Pair idAndRule : rules) pcall { IfThen rule = idAndRule.b; new NLLogicChecker_v2.Matching m; m.verbose = isTrue(applyNLLogicFacts_v2_verbose!); if (m.verbose) print("Checking rule: " + rule); if (c.checkRule(rule, m)) { print("Matched " + quote(c.input) + " with rule " + quote(rule)); printStruct(m.matches); new SS matches; // matches made in evaluating RHS of rule for (Exp out : m.output) for (Exp e : nlLogic_unrollAnd(out)) if (e cast Func) { if (eq(e.name, "output") && e.arg instanceof Sentence) callF(postMessage, addAndReturn(c.posted, replaceVars(nlLogic_text(e.arg), matches))); } /*else if (e cast Eq) { // any sf as operator - disabled for security reasons, use eval() Exp r = e.right; S var = nlLogic_text(e.left); if (r cast Func) if (isStandardFunction(r.name) && r.arg instanceof Sentence && noJavaTokens(nlLogic_text(r.arg))) matches.put(var, str(callAndMake(r.name))); }*/ } } }