occam-verify-cli 1.0.913 → 1.0.920

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -12,9 +12,6 @@ _export(exports, {
12
12
  get equivalencesFromEquality () {
13
13
  return equivalencesFromEquality;
14
14
  },
15
- get findEquivalenceByTerm () {
16
- return findEquivalenceByTerm;
17
- },
18
15
  get findEquivalenceByTermNodes () {
19
16
  return findEquivalenceByTermNodes;
20
17
  },
@@ -43,15 +40,6 @@ function mergeEquivalences(equivalencesA, equivalencesB, context) {
43
40
  });
44
41
  return equivalencesA;
45
42
  }
46
- function findEquivalenceByTerm(equivalences, term) {
47
- const equivalence = equivalences.find((equivalence)=>{
48
- const equivalenceEqualToTerm = equivalence.isEqualTo(term);
49
- if (equivalenceEqualToTerm) {
50
- return true;
51
- }
52
- }) || null;
53
- return equivalence;
54
- }
55
43
  function equivalencesFromEquality(equality, context) {
56
44
  const { Equivalence } = _elements.default, eaulivalence = Equivalence.fromEquality(equality, context), equivalences = [
57
45
  eaulivalence
@@ -143,4 +131,4 @@ function groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquiva
143
131
  });
144
132
  }
145
133
 
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/equivalences.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nimport elements from \"../elements\";\n\nimport { variablesFromTerm } from \"../utilities/equivalence\";\n\nconst { push, separate } = arrayUtilities;\n\nexport function mergeEquivalences(equivalencesA, equivalencesB, context) {\n  equivalencesA = [  ///\n    ...equivalencesA\n  ];\n\n  equivalencesB.forEach((equivalenceB) => {\n    equivalencesA = mergeEquivalence(equivalencesA, equivalenceB, context);\n  });\n\n  return equivalencesA;\n}\n\nexport function findEquivalenceByTerm(equivalences, term) {\n  const equivalence = equivalences.find((equivalence) => {\n    const equivalenceEqualToTerm = equivalence.isEqualTo(term);\n\n    if (equivalenceEqualToTerm) {\n      return true;\n    }\n  }) || null;\n\n  return equivalence;\n}\n\nexport function equivalencesFromEquality(equality, context) {\n  const { Equivalence } = elements,\n        eaulivalence = Equivalence.fromEquality(equality, context),\n        equivalences = [\n          eaulivalence\n        ];\n\n  return equivalences;\n}\n\nexport function findEquivalenceByTermNodes(equivalences, termNodes) {\n  const equivalence = equivalences.find((equivalence) => {\n    const termNodeMatches = equivalence.matchTermNodes(termNodes);\n\n    if (termNodeMatches) {\n      return true;\n    }\n  }) || null;\n\n  return equivalence;\n}\n\nexport function separateGroundedTermsAndDefinedVariables(equivalences, groundedTerms, definedVariables, context) {\n  let groundedEquivalences,\n      remainingEquivalences,\n      initiallyGroundedEquivalences,\n      implicitlyGroundedEquivalences;\n\n  remainingEquivalences = [];\n\n  initiallyGroundedEquivalences = [];\n\n  separateInitiallyGroundedEquivalences(equivalences, remainingEquivalences, initiallyGroundedEquivalences, context);\n\n  const initiallyGroundedEquivalencesLength = initiallyGroundedEquivalences.length;\n\n  if (initiallyGroundedEquivalencesLength > 0) {\n    groundedEquivalences = initiallyGroundedEquivalences; ///\n\n    let implicitlyGroundedEquivalencesLength = 1;\n\n    while (implicitlyGroundedEquivalencesLength > 0) {\n      let definedVariablesLength = 0,\n            previousDefinedVariablesLength = -1;\n\n      while (definedVariablesLength > previousDefinedVariablesLength) {\n        previousDefinedVariablesLength = definedVariablesLength;  ///\n\n        groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context);\n\n        definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context);\n\n        definedVariablesLength = definedVariables.length;\n      }\n\n      equivalences = remainingEquivalences; ///\n\n      remainingEquivalences = [];\n\n      implicitlyGroundedEquivalences = [];\n\n      separateImplicitlyGroundedEquivalences(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context);\n\n      push(groundedEquivalences, implicitlyGroundedEquivalences);\n\n      implicitlyGroundedEquivalencesLength = implicitlyGroundedEquivalences.length;  ///\n    }\n  }\n}\n\nfunction mergeEquivalence(equivalencesA, equivalenceB, context) {\n  const mergedEquivalences = [];\n\n  equivalencesA.forEach((equivalenceA) => {\n    const equivalenceBDisjointFromEquivalenceA = equivalenceB.isDisjointFrom(equivalenceA);\n\n    if (equivalenceBDisjointFromEquivalenceA) {\n      const mergedEquivalence = equivalenceB;  ///\n\n      mergedEquivalences.push(mergedEquivalence);\n    } else {\n      equivalenceB = equivalenceB.mergedWith(equivalenceA, context);\n    }\n  });\n\n  const mergedEquivalence = equivalenceB;  ///\n\n  mergedEquivalences.push(mergedEquivalence);\n\n  equivalencesA = mergedEquivalences;  ///\n\n  return equivalencesA;\n}\n\nfunction definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context) {\n  groundedTerms.forEach((groundedTerm) => {\n    const term = groundedTerm,  ///\n          variables = variablesFromTerm(term, context);\n\n    variables.forEach((variable) => {\n      const definedVariablesIncludesTermVariable = definedVariables.includes(variable);\n\n      if (!definedVariablesIncludesTermVariable) {\n        const definedVariable = variable;  ///\n\n        definedVariables.push(definedVariable);\n      }\n    });\n  });\n}\n\nfunction separateInitiallyGroundedEquivalences(equivalences, remainingEquivalences, initiallyGroundedEquivalences, context) {\n  separate(equivalences, remainingEquivalences, initiallyGroundedEquivalences, (equivalence) => {\n    const equivalenceInitiallyGrounded = equivalence.isInitiallyGrounded(context);\n\n    if (!equivalenceInitiallyGrounded) {\n      return true;\n    }\n  });\n}\n\nfunction separateImplicitlyGroundedEquivalences(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context) {\n  separate(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, (equivalence) => {\n    const equivalenceImplicitlyGrounded = equivalence.isImplicitlyGrounded(definedVariables, context);\n\n    if (!equivalenceImplicitlyGrounded) {\n      return true;\n    }\n  });\n}\n\nfunction groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context) {\n  groundedEquivalences.forEach((groundedEquivalence) => {\n    groundedEquivalence.getGroundedTerms(definedVariables, groundedTerms, context);\n  });\n}\n"],"names":["equivalencesFromEquality","findEquivalenceByTerm","findEquivalenceByTermNodes","mergeEquivalences","separateGroundedTermsAndDefinedVariables","push","separate","arrayUtilities","equivalencesA","equivalencesB","context","forEach","equivalenceB","mergeEquivalence","equivalences","term","equivalence","find","equivalenceEqualToTerm","isEqualTo","equality","Equivalence","elements","eaulivalence","fromEquality","termNodes","termNodeMatches","matchTermNodes","groundedTerms","definedVariables","groundedEquivalences","remainingEquivalences","initiallyGroundedEquivalences","implicitlyGroundedEquivalences","separateInitiallyGroundedEquivalences","initiallyGroundedEquivalencesLength","length","implicitlyGroundedEquivalencesLength","definedVariablesLength","previousDefinedVariablesLength","groundedTermsFromGroundedEquivalencesAndDefinedVariables","definedVariablesFromGroundedTerms","separateImplicitlyGroundedEquivalences","mergedEquivalences","equivalenceA","equivalenceBDisjointFromEquivalenceA","isDisjointFrom","mergedEquivalence","mergedWith","groundedTerm","variables","variablesFromTerm","variable","definedVariablesIncludesTermVariable","includes","definedVariable","equivalenceInitiallyGrounded","isInitiallyGrounded","equivalenceImplicitlyGrounded","isImplicitlyGrounded","groundedEquivalence","getGroundedTerms"],"mappings":"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"}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/equivalences.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nimport elements from \"../elements\";\n\nimport { variablesFromTerm } from \"../utilities/equivalence\";\n\nconst { push, separate } = arrayUtilities;\n\nexport function mergeEquivalences(equivalencesA, equivalencesB, context) {\n  equivalencesA = [  ///\n    ...equivalencesA\n  ];\n\n  equivalencesB.forEach((equivalenceB) => {\n    equivalencesA = mergeEquivalence(equivalencesA, equivalenceB, context);\n  });\n\n  return equivalencesA;\n}\n\nexport function equivalencesFromEquality(equality, context) {\n  const { Equivalence } = elements,\n        eaulivalence = Equivalence.fromEquality(equality, context),\n        equivalences = [\n          eaulivalence\n        ];\n\n  return equivalences;\n}\n\nexport function findEquivalenceByTermNodes(equivalences, termNodes) {\n  const equivalence = equivalences.find((equivalence) => {\n    const termNodeMatches = equivalence.matchTermNodes(termNodes);\n\n    if (termNodeMatches) {\n      return true;\n    }\n  }) || null;\n\n  return equivalence;\n}\n\nexport function separateGroundedTermsAndDefinedVariables(equivalences, groundedTerms, definedVariables, context) {\n  let groundedEquivalences,\n      remainingEquivalences,\n      initiallyGroundedEquivalences,\n      implicitlyGroundedEquivalences;\n\n  remainingEquivalences = [];\n\n  initiallyGroundedEquivalences = [];\n\n  separateInitiallyGroundedEquivalences(equivalences, remainingEquivalences, initiallyGroundedEquivalences, context);\n\n  const initiallyGroundedEquivalencesLength = initiallyGroundedEquivalences.length;\n\n  if (initiallyGroundedEquivalencesLength > 0) {\n    groundedEquivalences = initiallyGroundedEquivalences; ///\n\n    let implicitlyGroundedEquivalencesLength = 1;\n\n    while (implicitlyGroundedEquivalencesLength > 0) {\n      let definedVariablesLength = 0,\n            previousDefinedVariablesLength = -1;\n\n      while (definedVariablesLength > previousDefinedVariablesLength) {\n        previousDefinedVariablesLength = definedVariablesLength;  ///\n\n        groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context);\n\n        definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context);\n\n        definedVariablesLength = definedVariables.length;\n      }\n\n      equivalences = remainingEquivalences; ///\n\n      remainingEquivalences = [];\n\n      implicitlyGroundedEquivalences = [];\n\n      separateImplicitlyGroundedEquivalences(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context);\n\n      push(groundedEquivalences, implicitlyGroundedEquivalences);\n\n      implicitlyGroundedEquivalencesLength = implicitlyGroundedEquivalences.length;  ///\n    }\n  }\n}\n\nfunction mergeEquivalence(equivalencesA, equivalenceB, context) {\n  const mergedEquivalences = [];\n\n  equivalencesA.forEach((equivalenceA) => {\n    const equivalenceBDisjointFromEquivalenceA = equivalenceB.isDisjointFrom(equivalenceA);\n\n    if (equivalenceBDisjointFromEquivalenceA) {\n      const mergedEquivalence = equivalenceB;  ///\n\n      mergedEquivalences.push(mergedEquivalence);\n    } else {\n      equivalenceB = equivalenceB.mergedWith(equivalenceA, context);\n    }\n  });\n\n  const mergedEquivalence = equivalenceB;  ///\n\n  mergedEquivalences.push(mergedEquivalence);\n\n  equivalencesA = mergedEquivalences;  ///\n\n  return equivalencesA;\n}\n\nfunction definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context) {\n  groundedTerms.forEach((groundedTerm) => {\n    const term = groundedTerm,  ///\n          variables = variablesFromTerm(term, context);\n\n    variables.forEach((variable) => {\n      const definedVariablesIncludesTermVariable = definedVariables.includes(variable);\n\n      if (!definedVariablesIncludesTermVariable) {\n        const definedVariable = variable;  ///\n\n        definedVariables.push(definedVariable);\n      }\n    });\n  });\n}\n\nfunction separateInitiallyGroundedEquivalences(equivalences, remainingEquivalences, initiallyGroundedEquivalences, context) {\n  separate(equivalences, remainingEquivalences, initiallyGroundedEquivalences, (equivalence) => {\n    const equivalenceInitiallyGrounded = equivalence.isInitiallyGrounded(context);\n\n    if (!equivalenceInitiallyGrounded) {\n      return true;\n    }\n  });\n}\n\nfunction separateImplicitlyGroundedEquivalences(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context) {\n  separate(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, (equivalence) => {\n    const equivalenceImplicitlyGrounded = equivalence.isImplicitlyGrounded(definedVariables, context);\n\n    if (!equivalenceImplicitlyGrounded) {\n      return true;\n    }\n  });\n}\n\nfunction groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context) {\n  groundedEquivalences.forEach((groundedEquivalence) => {\n    groundedEquivalence.getGroundedTerms(definedVariables, groundedTerms, context);\n  });\n}\n"],"names":["equivalencesFromEquality","findEquivalenceByTermNodes","mergeEquivalences","separateGroundedTermsAndDefinedVariables","push","separate","arrayUtilities","equivalencesA","equivalencesB","context","forEach","equivalenceB","mergeEquivalence","equality","Equivalence","elements","eaulivalence","fromEquality","equivalences","termNodes","equivalence","find","termNodeMatches","matchTermNodes","groundedTerms","definedVariables","groundedEquivalences","remainingEquivalences","initiallyGroundedEquivalences","implicitlyGroundedEquivalences","separateInitiallyGroundedEquivalences","initiallyGroundedEquivalencesLength","length","implicitlyGroundedEquivalencesLength","definedVariablesLength","previousDefinedVariablesLength","groundedTermsFromGroundedEquivalencesAndDefinedVariables","definedVariablesFromGroundedTerms","separateImplicitlyGroundedEquivalences","mergedEquivalences","equivalenceA","equivalenceBDisjointFromEquivalenceA","isDisjointFrom","mergedEquivalence","mergedWith","groundedTerm","term","variables","variablesFromTerm","variable","definedVariablesIncludesTermVariable","includes","definedVariable","equivalenceInitiallyGrounded","isInitiallyGrounded","equivalenceImplicitlyGrounded","isImplicitlyGrounded","groundedEquivalence","getGroundedTerms"],"mappings":"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"}
@@ -8,7 +8,6 @@ Object.defineProperty(exports, "unifySteps", {
8
8
  return unifySteps;
9
9
  }
10
10
  });
11
- const _necessary = require("necessary");
12
11
  const _elements = /*#__PURE__*/ _interop_require_default(require("../elements"));
13
12
  const _context = require("./context");
14
13
  function _interop_require_default(obj) {
@@ -16,12 +15,11 @@ function _interop_require_default(obj) {
16
15
  default: obj
17
16
  };
18
17
  }
19
- const { backwardsSome } = _necessary.arrayUtilities;
20
18
  async function unifyStepWithRule(step, context) {
21
19
  let stepUnifiesWithRule = false;
22
- const qualified = step.isQualified();
23
- if (qualified) {
24
- const reference = step.getReference(), rule = context.findRuleByReference(reference);
20
+ const reference = step.getReference();
21
+ if (reference !== null) {
22
+ const rule = context.findRuleByReference(reference);
25
23
  if (rule !== null) {
26
24
  const stepString = step.getString(), ruleString = rule.getString();
27
25
  context.trace(`Unifying the '${stepString}' step with the '${ruleString}' rule...`);
@@ -38,9 +36,9 @@ async function unifyStepWithRule(step, context) {
38
36
  }
39
37
  async function unifyStepWithReference(step, context) {
40
38
  let stepUnifiesWithReference = false;
41
- const qualified = step.isQualified();
42
- if (qualified) {
43
- const reference = step.getReference(), stepString = step.getString(), referenceString = reference.getString();
39
+ const reference = step.getReference();
40
+ if (reference !== null) {
41
+ const stepString = step.getString(), referenceString = reference.getString();
44
42
  context.trace(`Unifying the '${stepString}' step with the '${referenceString}' reference...`);
45
43
  const topLevelAssertion = context.findTopLevelAssertionByReference(reference);
46
44
  if (topLevelAssertion !== null) {
@@ -64,57 +62,11 @@ async function unifyStepWithReference(step, context) {
64
62
  }
65
63
  return stepUnifiesWithReference;
66
64
  }
67
- async function unifyStepAsSignatureAssertion(step, context) {
68
- let stepUnifiesAsSignatureAssertion = false;
69
- const { SignatureAssertion } = _elements.default;
70
- const signatureAssertion = SignatureAssertion.fromStep(step, context);
71
- if (signatureAssertion !== null) {
72
- const stepString = step.getString();
73
- context.trace(`Unifying the '${stepString}' step as a signature assertion...`);
74
- (0, _context.descend)((context)=>{
75
- signatureAssertion.verifySignature(context);
76
- }, context);
77
- const unqualified = step.isUnqualified();
78
- if (unqualified) {
79
- const subproofOrProofAssertions = context.getSubproofOrProofAssertions();
80
- stepUnifiesAsSignatureAssertion = backwardsSome(subproofOrProofAssertions, (stepsOrSubproof)=>{
81
- const stepOrSubProofUnifiesWIthSignatureAssertion = stepsOrSubproof.unifyWithSignatureAssertion(signatureAssertion, context);
82
- if (stepOrSubProofUnifiesWIthSignatureAssertion) {
83
- return true;
84
- }
85
- });
86
- } else {
87
- const reference = signatureAssertion.getReference(), topLevelAssertion = context.findTopLevelAssertionByReference(reference);
88
- if (topLevelAssertion !== null) {
89
- const axiom = context.findAxiomByReference(reference);
90
- if (axiom !== null) {
91
- const satisfiable = axiom.isSatisfiable();
92
- if (satisfiable) {
93
- const topLevelAssertionUnifies = axiom.unifyTopLevelAssertion(topLevelAssertion, context);
94
- if (topLevelAssertionUnifies) {
95
- const substitutionsCorrelates = signatureAssertion.correlateSubstitutions(substitutions, context);
96
- if (substitutionsCorrelates) {
97
- stepUnifiesAsSignatureAssertion = true;
98
- }
99
- }
100
- } else {
101
- const axiomString = axiom.getString();
102
- context.debug(`Unable to unify with the '${axiomString}' because it is not satisfiable.`);
103
- }
104
- }
105
- }
106
- }
107
- if (stepUnifiesAsSignatureAssertion) {
108
- context.debug(`...unified the '${stepString}' step as a signature assertion.`);
109
- }
110
- }
111
- return stepUnifiesAsSignatureAssertion;
112
- }
113
65
  async function unifyStepWithTopLevelAssertion(step, context) {
114
66
  let stepUnifiesWithTopLevelAssertion = false;
115
- const qualified = step.isQualified();
116
- if (qualified) {
117
- const reference = step.getReference(), topLevelAssertion = context.findTopLevelAssertionByReference(reference);
67
+ const reference = step.getReference();
68
+ if (reference !== null) {
69
+ const topLevelAssertion = context.findTopLevelAssertionByReference(reference);
118
70
  if (topLevelAssertion !== null) {
119
71
  const stepString = step.getString(), topLevelAssertionString = reference.getString();
120
72
  context.trace(`Unifying the '${stepString}' step with the '${topLevelAssertionString}' top level assertion...`);
@@ -129,97 +81,123 @@ async function unifyStepWithTopLevelAssertion(step, context) {
129
81
  }
130
82
  return stepUnifiesWithTopLevelAssertion;
131
83
  }
132
- async function unifyStepAsEquality(step, context) {
133
- let stepUnifiesAEquality = false;
84
+ async function unifyStepWithSignatureAssertion(step, context) {
85
+ let stepUnifiesWithSignatureAssertion = false;
86
+ const signatureAssertion = step.getSignatureAssertion();
87
+ if (signatureAssertion !== null) {
88
+ const stepString = step.getString(), signatureAssertionString = signatureAssertion.getString();
89
+ context.trace(`Unifying the '${stepString}' step with the '${signatureAssertionString}' signature assertion...`);
90
+ const subproofOrProofAssertions = context.getSubproofOrProofAssertions(), stepAndSubproofOrProofAssertionsUnify = await signatureAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);
91
+ if (stepAndSubproofOrProofAssertionsUnify) {
92
+ stepUnifiesWithSignatureAssertion = true;
93
+ }
94
+ if (stepUnifiesWithSignatureAssertion) {
95
+ context.debug(`...unified the '${stepString}' step with the '${signatureAssertionString}' signature assertion.`);
96
+ }
97
+ }
98
+ return stepUnifiesWithSignatureAssertion;
99
+ }
100
+ async function unifyStepAsUnqualifiedEquality(step, context) {
101
+ let stepUnifiesAUnqualifiedEquality = false;
134
102
  const unqualified = step.isUnqualified();
135
103
  if (unqualified) {
136
104
  const { Equality } = _elements.default, statement = step.getStatement(), equality = Equality.fromStatement(statement, context);
137
105
  if (equality !== null) {
138
106
  const stepString = step.getString();
139
- context.trace(`Unifying the '${stepString}' step as an equality...`);
140
- const equalityEqual = equality.isEqual(context);
141
- if (equalityEqual) {
142
- stepUnifiesAEquality = true;
143
- }
144
- if (stepUnifiesAEquality) {
145
- context.debug(`...unified the '${stepString}' step as an equality.`);
107
+ context.trace(`Unifying the '${stepString}' step as an unqualified equality...`);
108
+ stepUnifiesAUnqualifiedEquality = true;
109
+ if (stepUnifiesAUnqualifiedEquality) {
110
+ context.debug(`...unified the '${stepString}' step as an unqualified equality.`);
146
111
  }
147
112
  }
148
113
  }
149
- return stepUnifiesAEquality;
114
+ return stepUnifiesAUnqualifiedEquality;
150
115
  }
151
- async function unifyStepAsJudgement(step, context) {
152
- let stepUnifiesAsJudgement = false;
116
+ async function unifyStepAsUNqualifiedJudgement(step, context) {
117
+ let stepUnifiesAsUnqualifiedJudgement = false;
153
118
  const unqualified = step.isUnqualified();
154
119
  if (unqualified) {
155
120
  const { Judgement } = _elements.default, statement = step.getStatement(), judgement = Judgement.fromStatement(statement, context);
156
121
  if (judgement !== null) {
157
122
  const stepString = step.getString();
158
- context.trace(`Unifying the '${stepString}' step as a judgement...`);
159
- stepUnifiesAsJudgement = true;
160
- if (stepUnifiesAsJudgement) {
161
- context.debug(`...unified the '${stepString}' step as a judgement.`);
123
+ context.trace(`Unifying the '${stepString}' step as an unqualified judgement...`);
124
+ stepUnifiesAsUnqualifiedJudgement = true;
125
+ if (stepUnifiesAsUnqualifiedJudgement) {
126
+ context.debug(`...unified the '${stepString}' step as an unqualified judgement.`);
162
127
  }
163
128
  }
164
129
  }
165
- return stepUnifiesAsJudgement;
130
+ return stepUnifiesAsUnqualifiedJudgement;
166
131
  }
167
- async function unifyStepAsTypeAssertion(step, context) {
168
- let stepUnifiesAsTypeAssertion = false;
132
+ async function unifyStepAsUnqualifiedTypeAssertion(step, context) {
133
+ let stepUnifiesAsUnqualifiedTypeAssertion = false;
169
134
  const unqualified = step.isUnqualified();
170
135
  if (unqualified) {
171
136
  const { TypeAssertion } = _elements.default, statement = step.getStatement(), typeAssertion = TypeAssertion.fromStatement(statement, context);
172
137
  if (typeAssertion !== null) {
173
138
  const stepString = step.getString();
174
- context.trace(`Unifying the '${stepString}' step as a type assertion...`);
175
- stepUnifiesAsTypeAssertion = true;
176
- context.debug(`...unified the '${stepString}' step as a type assertion.`);
139
+ context.trace(`Unifying the '${stepString}' step as an unqualified type assertion...`);
140
+ stepUnifiesAsUnqualifiedTypeAssertion = true;
141
+ if (stepUnifiesAsUnqualifiedTypeAssertion) {
142
+ context.debug(`...unified the '${stepString}' step as an unqualified type assertion.`);
143
+ }
177
144
  }
178
145
  }
179
- return stepUnifiesAsTypeAssertion;
146
+ return stepUnifiesAsUnqualifiedTypeAssertion;
180
147
  }
181
- async function unifyStepAsPropertyAssertion(step, context) {
182
- let stepUnifiesAsPropertyAssertion = false;
148
+ async function unifyStepAsUnqualifiedPropertyAssertion(step, context) {
149
+ let stepUnifiesAsUnqualifiedPropertyAssertion = false;
183
150
  const unqualified = step.isUnqualified();
184
151
  if (unqualified) {
185
152
  const { PropertyAssertion } = _elements.default, statement = step.getStatement(), propertyAssertion = PropertyAssertion.fromStatement(statement, context);
186
153
  if (propertyAssertion !== null) {
187
154
  const stepString = step.getString();
188
- context.trace(`Unifying the '${stepString}' step as a property assertion...`);
189
- const term = propertyAssertion.getTerm(), equivalence = context.findEquivalenceByTerm(term);
190
- if (equivalence !== null) {
191
- const propertyAssertionMatches = equivalence.someOtherTerm(term, (term)=>{
192
- const propertyRelation = propertyAssertion.getPropertyRelation(), comparesToTermAndPropertyRelation = context.compareTermAndPropertyRelation(term, propertyRelation);
193
- if (comparesToTermAndPropertyRelation) {
194
- return true;
195
- }
196
- });
197
- if (propertyAssertionMatches) {
198
- stepUnifiesAsPropertyAssertion = true;
199
- }
200
- }
201
- if (stepUnifiesAsPropertyAssertion) {
202
- context.debug(`...unified the '${stepString}' step as a property assertion.`);
155
+ context.trace(`Unifying the '${stepString}' step as an unqualified property assertion...`);
156
+ stepUnifiesAsUnqualifiedPropertyAssertion = true;
157
+ if (stepUnifiesAsUnqualifiedPropertyAssertion) {
158
+ context.debug(`...unified the '${stepString}' step as an unqualified property assertion.`);
203
159
  }
204
160
  }
205
161
  }
206
- return stepUnifiesAsPropertyAssertion;
162
+ return stepUnifiesAsUnqualifiedPropertyAssertion;
207
163
  }
208
- async function unifyStepWithSignatureAssertion(step, context) {
209
- let stepUnifiesWithSignatureAssertion = false;
210
- const signatureAssertion = step.getSignatureAssertion();
211
- if (signatureAssertion !== null) {
212
- const stepString = step.getString(), signatureAssertionString = signatureAssertion.getString();
213
- context.trace(`Unifying the '${stepString}' step with the '${signatureAssertionString}' signature assertion...`);
214
- const subproofOrProofAssertions = context.getSubproofOrProofAssertions(), stepUnifies = signatureAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);
215
- if (stepUnifies) {
216
- stepUnifiesWithSignatureAssertion = true;
164
+ async function unifyStepAsUnqualifiedSignatureAssertion(step, context) {
165
+ let stepUnifiesAsUnqualifiedSignatureAssertion = false;
166
+ const unqualified = step.isUnqualified();
167
+ if (unqualified) {
168
+ const { SignatureAssertion } = _elements.default, statement = step.getStatement(), signatureAssertion = SignatureAssertion.fromStatement(statement, context);
169
+ if (signatureAssertion !== null) {
170
+ const stepString = step.getString();
171
+ context.trace(`Unifying the '${stepString}' step as a signature assertion...`);
172
+ stepUnifiesAsUnqualifiedSignatureAssertion = true;
173
+ if (stepUnifiesAsUnqualifiedSignatureAssertion) {
174
+ context.debug(`...unified the '${stepString}' step as a signature assertion.`);
175
+ }
217
176
  }
218
- if (stepUnifiesWithSignatureAssertion) {
219
- context.debug(`...unified the '${stepString}' step with the '${signatureAssertionString}' signature assertion.`);
177
+ }
178
+ return stepUnifiesAsUnqualifiedSignatureAssertion;
179
+ }
180
+ async function unifyStepAsSignatureAssertionWithReference(step, context) {
181
+ let stepUnifiesAsSignatureAssertionWithReference = false;
182
+ const reference = step.getReference();
183
+ if (reference !== null) {
184
+ const topLevelAssertion = context.findTopLevelAssertionByReference(reference);
185
+ if (topLevelAssertion !== null) {
186
+ const statementNode = step.getStatementNode(), signatureAssertionNode = statementNode.getSignatureAssertionNode();
187
+ if (signatureAssertionNode !== null) {
188
+ const stepString = step.getString(), referenceString = reference.getString(), signatureAssertion = context.findAssertionByAssertionNode(signatureAssertionNode);
189
+ context.trace(`Unifying the '${stepString}' step as a signature assertion with the '${referenceString}' reference...`);
190
+ const unifyTopLevelAssertion = await signatureAssertion.unifyTopLevelAssertion(topLevelAssertion, context);
191
+ if (unifyTopLevelAssertion) {
192
+ stepUnifiesAsSignatureAssertionWithReference = true;
193
+ }
194
+ if (stepUnifiesAsSignatureAssertionWithReference) {
195
+ context.debug(`...unified the '${stepString}' step as a signature assertion with the '${referenceString}' reference.`);
196
+ }
197
+ }
220
198
  }
221
199
  }
222
- return stepUnifiesWithSignatureAssertion;
200
+ return stepUnifiesAsSignatureAssertionWithReference;
223
201
  }
224
202
  async function compareStepWithSubproofOrProofAssertions(step, context) {
225
203
  let stepComparesToSubproofOrProofAssertions = false;
@@ -240,14 +218,15 @@ async function compareStepWithSubproofOrProofAssertions(step, context) {
240
218
  const unifySteps = [
241
219
  unifyStepWithRule,
242
220
  unifyStepWithReference,
243
- unifyStepAsSignatureAssertion,
244
221
  unifyStepWithTopLevelAssertion,
245
- unifyStepAsEquality,
246
- unifyStepAsJudgement,
247
- unifyStepAsTypeAssertion,
248
- unifyStepAsPropertyAssertion,
249
222
  unifyStepWithSignatureAssertion,
223
+ unifyStepAsUnqualifiedEquality,
224
+ unifyStepAsUNqualifiedJudgement,
225
+ unifyStepAsUnqualifiedTypeAssertion,
226
+ unifyStepAsUnqualifiedPropertyAssertion,
227
+ unifyStepAsUnqualifiedSignatureAssertion,
228
+ unifyStepAsSignatureAssertionWithReference,
250
229
  compareStepWithSubproofOrProofAssertions
251
230
  ];
252
231
 
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/unification.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nimport elements from \"../elements\";\n\nimport { descend } from \"./context\";\n\nconst { backwardsSome } = arrayUtilities;\n\nasync function unifyStepWithRule(step, context) {\n  let stepUnifiesWithRule = false;\n\n  const qualified = step.isQualified();\n\n  if (qualified) {\n    const reference = step.getReference(),\n          rule = context.findRuleByReference(reference);\n\n    if (rule !== null) {\n      const stepString = step.getString(),\n            ruleString = rule.getString();\n\n      context.trace(`Unifying the '${stepString}' step with the '${ruleString}' rule...`);\n\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await rule.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithRule = true;\n      }\n\n      if (stepUnifiesWithRule) {\n        context.debug(`...unified the '${stepString}' step with the '${ruleString}' rule.`);\n      }\n    }\n  }\n\n  return stepUnifiesWithRule;\n}\n\nasync function unifyStepWithReference(step, context) {\n  let stepUnifiesWithReference = false;\n\n  const qualified = step.isQualified();\n\n  if (qualified) {\n    const reference = step.getReference(),\n          stepString = step.getString(),\n          referenceString = reference.getString();\n\n    context.trace(`Unifying the '${stepString}' step with the '${referenceString}' reference...`);\n\n    const topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await topLevelAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithReference = true;\n      }\n    } else {\n      const metaLevel = context.isMetaLevel();\n\n      if (metaLevel) {\n        descend((context) => {\n          const { MetaLevelAssumption } = elements,\n                metaLevelAssumption = MetaLevelAssumption.fromStep(step, context);\n\n          metaLevelAssumption.validate(context);\n\n          stepUnifiesWithReference = true;\n        }, context);\n      }\n    }\n\n    if (stepUnifiesWithReference) {\n      context.debug(`...unified the '${stepString}' step with the '${referenceString}' reference.`);\n    }\n  }\n\n  return stepUnifiesWithReference;\n}\n\nasync function unifyStepAsSignatureAssertion(step, context) {\n  let stepUnifiesAsSignatureAssertion = false;\n\n  const { SignatureAssertion } = elements;\n\n  const signatureAssertion = SignatureAssertion.fromStep(step, context);\n\n  if (signatureAssertion !== null) {\n    const stepString = step.getString();\n\n    context.trace(`Unifying the '${stepString}' step as a signature assertion...`);\n\n    descend((context) => {\n      signatureAssertion.verifySignature(context);\n    }, context);\n\n    const unqualified = step.isUnqualified();\n\n    if (unqualified) {\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions();\n\n      stepUnifiesAsSignatureAssertion = backwardsSome(subproofOrProofAssertions, (stepsOrSubproof) => {\n        const stepOrSubProofUnifiesWIthSignatureAssertion = stepsOrSubproof.unifyWithSignatureAssertion(signatureAssertion, context);\n\n        if (stepOrSubProofUnifiesWIthSignatureAssertion) {\n          return true;\n        }\n      });\n    } else {\n      const reference = signatureAssertion.getReference(),\n            topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n      if (topLevelAssertion !== null) {\n        const axiom = context.findAxiomByReference(reference);\n\n        if (axiom !== null) {\n          const satisfiable = axiom.isSatisfiable();\n\n          if (satisfiable) {\n            const topLevelAssertionUnifies = axiom.unifyTopLevelAssertion(topLevelAssertion, context);\n\n            if (topLevelAssertionUnifies) {\n              const substitutionsCorrelates = signatureAssertion.correlateSubstitutions(substitutions, context);\n\n              if (substitutionsCorrelates) {\n                stepUnifiesAsSignatureAssertion = true;\n              }\n            }\n          } else {\n            const axiomString = axiom.getString();\n\n            context.debug(`Unable to unify with the '${axiomString}' because it is not satisfiable.`)\n          }\n        }\n      }\n    }\n\n    if (stepUnifiesAsSignatureAssertion) {\n      context.debug(`...unified the '${stepString}' step as a signature assertion.`);\n    }\n  }\n\n  return stepUnifiesAsSignatureAssertion;\n}\n\nasync function unifyStepWithTopLevelAssertion(step, context) {\n  let stepUnifiesWithTopLevelAssertion = false;\n\n  const qualified = step.isQualified();\n\n  if (qualified) {\n    const reference = step.getReference(),\n          topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const stepString = step.getString(),\n            topLevelAssertionString = reference.getString();\n\n      context.trace(`Unifying the '${stepString}' step with the '${topLevelAssertionString}' top level assertion...`);\n\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await topLevelAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithTopLevelAssertion = true;\n      }\n\n      if (stepUnifiesWithTopLevelAssertion) {\n        context.debug(`...unified the '${stepString}' step with the '${topLevelAssertionString}' top level assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesWithTopLevelAssertion;\n}\n\nasync function unifyStepAsEquality(step, context) {\n  let stepUnifiesAEquality = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { Equality } = elements,\n          statement = step.getStatement(),\n          equality = Equality.fromStatement(statement, context);\n\n    if (equality !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an equality...`);\n\n      const equalityEqual = equality.isEqual(context);\n\n      if (equalityEqual) {\n        stepUnifiesAEquality = true;\n      }\n\n      if (stepUnifiesAEquality) {\n        context.debug(`...unified the '${stepString}' step as an equality.`);\n      }\n    }\n  }\n\n  return stepUnifiesAEquality;\n}\n\nasync function unifyStepAsJudgement(step, context) {\n  let stepUnifiesAsJudgement = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { Judgement } = elements,\n          statement = step.getStatement(),\n          judgement = Judgement.fromStatement(statement, context);\n\n    if (judgement !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as a judgement...`);\n\n      stepUnifiesAsJudgement = true;\n\n      if (stepUnifiesAsJudgement) {\n        context.debug(`...unified the '${stepString}' step as a judgement.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsJudgement;\n}\n\nasync function unifyStepAsTypeAssertion(step, context) {\n  let stepUnifiesAsTypeAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { TypeAssertion } = elements,\n          statement = step.getStatement(),\n          typeAssertion = TypeAssertion.fromStatement(statement, context);\n\n    if (typeAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as a type assertion...`);\n\n      stepUnifiesAsTypeAssertion = true;\n\n      context.debug(`...unified the '${stepString}' step as a type assertion.`);\n    }\n  }\n\n  return stepUnifiesAsTypeAssertion;\n}\n\nasync function unifyStepAsPropertyAssertion(step, context) {\n  let stepUnifiesAsPropertyAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { PropertyAssertion } = elements,\n          statement = step.getStatement(),\n          propertyAssertion = PropertyAssertion.fromStatement(statement, context);\n\n    if (propertyAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as a property assertion...`);\n\n      const term = propertyAssertion.getTerm(),\n            equivalence = context.findEquivalenceByTerm(term);\n\n      if (equivalence !== null) {\n        const propertyAssertionMatches = equivalence.someOtherTerm(term, (term) => {  ///\n          const propertyRelation = propertyAssertion.getPropertyRelation(),\n                comparesToTermAndPropertyRelation = context.compareTermAndPropertyRelation(term, propertyRelation);\n\n          if (comparesToTermAndPropertyRelation) {\n            return true;\n          }\n        });\n\n        if (propertyAssertionMatches) {\n          stepUnifiesAsPropertyAssertion = true;\n        }\n      }\n\n      if (stepUnifiesAsPropertyAssertion) {\n        context.debug(`...unified the '${stepString}' step as a property assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsPropertyAssertion;\n}\n\nasync function unifyStepWithSignatureAssertion(step, context) {\n  let stepUnifiesWithSignatureAssertion = false;\n\n  const signatureAssertion = step.getSignatureAssertion();\n\n  if (signatureAssertion !== null) {\n    const stepString = step.getString(),\n          signatureAssertionString = signatureAssertion.getString();\n\n    context.trace(`Unifying the '${stepString}' step with the '${signatureAssertionString}' signature assertion...`);\n\n    const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n          stepUnifies = signatureAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n    if (stepUnifies) {\n      stepUnifiesWithSignatureAssertion = true;\n    }\n\n    if (stepUnifiesWithSignatureAssertion) {\n      context.debug(`...unified the '${stepString}' step with the '${signatureAssertionString}' signature assertion.`);\n    }\n  }\n\n  return stepUnifiesWithSignatureAssertion;\n}\n\nasync function compareStepWithSubproofOrProofAssertions(step, context) {\n  let stepComparesToSubproofOrProofAssertions = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const stepString = step.getString();\n\n    context.trace(`Comparing the '${stepString}' step with the subproofs or proof asssertions...`);\n\n    const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n          comparesToSubproofOrProofAssertions = step.compareSubproofOrProofAssertions(subproofOrProofAssertions, context);\n\n    if (comparesToSubproofOrProofAssertions) {\n      stepComparesToSubproofOrProofAssertions = true;\n    }\n\n    if (stepComparesToSubproofOrProofAssertions) {\n      context.debug(`...compared the '${stepString}' step with the subproofs or proof asssertions.`);\n    }\n  }\n\n  return stepComparesToSubproofOrProofAssertions;\n}\n\nexport const unifySteps = [\n  unifyStepWithRule,\n  unifyStepWithReference,\n  unifyStepAsSignatureAssertion,\n  unifyStepWithTopLevelAssertion,\n  unifyStepAsEquality,\n  unifyStepAsJudgement,\n  unifyStepAsTypeAssertion,\n  unifyStepAsPropertyAssertion,\n  unifyStepWithSignatureAssertion,\n  compareStepWithSubproofOrProofAssertions\n];\n"],"names":["unifySteps","backwardsSome","arrayUtilities","unifyStepWithRule","step","context","stepUnifiesWithRule","qualified","isQualified","reference","getReference","rule","findRuleByReference","stepString","getString","ruleString","trace","subproofOrProofAssertions","getSubproofOrProofAssertions","stepAndSubproofOrProofAssertionsUnify","unifyStepAndSubproofOrProofAssertions","debug","unifyStepWithReference","stepUnifiesWithReference","referenceString","topLevelAssertion","findTopLevelAssertionByReference","metaLevel","isMetaLevel","descend","MetaLevelAssumption","elements","metaLevelAssumption","fromStep","validate","unifyStepAsSignatureAssertion","stepUnifiesAsSignatureAssertion","SignatureAssertion","signatureAssertion","verifySignature","unqualified","isUnqualified","stepsOrSubproof","stepOrSubProofUnifiesWIthSignatureAssertion","unifyWithSignatureAssertion","axiom","findAxiomByReference","satisfiable","isSatisfiable","topLevelAssertionUnifies","unifyTopLevelAssertion","substitutionsCorrelates","correlateSubstitutions","substitutions","axiomString","unifyStepWithTopLevelAssertion","stepUnifiesWithTopLevelAssertion","topLevelAssertionString","unifyStepAsEquality","stepUnifiesAEquality","Equality","statement","getStatement","equality","fromStatement","equalityEqual","isEqual","unifyStepAsJudgement","stepUnifiesAsJudgement","Judgement","judgement","unifyStepAsTypeAssertion","stepUnifiesAsTypeAssertion","TypeAssertion","typeAssertion","unifyStepAsPropertyAssertion","stepUnifiesAsPropertyAssertion","PropertyAssertion","propertyAssertion","term","getTerm","equivalence","findEquivalenceByTerm","propertyAssertionMatches","someOtherTerm","propertyRelation","getPropertyRelation","comparesToTermAndPropertyRelation","compareTermAndPropertyRelation","unifyStepWithSignatureAssertion","stepUnifiesWithSignatureAssertion","getSignatureAssertion","signatureAssertionString","stepUnifies","compareStepWithSubproofOrProofAssertions","stepComparesToSubproofOrProofAssertions","comparesToSubproofOrProofAssertions","compareSubproofOrProofAssertions"],"mappings":"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"}
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/unification.js"],"sourcesContent":["\"use strict\";\n\nimport elements from \"../elements\";\n\nimport { descend } from \"./context\";\n\nasync function unifyStepWithRule(step, context) {\n  let stepUnifiesWithRule = false;\n\n  const reference = step.getReference();\n\n  if (reference !== null) {\n    const rule = context.findRuleByReference(reference);\n\n    if (rule !== null) {\n      const stepString = step.getString(),\n            ruleString = rule.getString();\n\n      context.trace(`Unifying the '${stepString}' step with the '${ruleString}' rule...`);\n\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await rule.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithRule = true;\n      }\n\n      if (stepUnifiesWithRule) {\n        context.debug(`...unified the '${stepString}' step with the '${ruleString}' rule.`);\n      }\n    }\n  }\n\n  return stepUnifiesWithRule;\n}\n\nasync function unifyStepWithReference(step, context) {\n  let stepUnifiesWithReference = false;\n\n  const reference = step.getReference();\n\n  if (reference !== null) {\n    const stepString = step.getString(),\n          referenceString = reference.getString();\n\n    context.trace(`Unifying the '${stepString}' step with the '${referenceString}' reference...`);\n\n    const topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await topLevelAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithReference = true;\n      }\n    } else {\n      const metaLevel = context.isMetaLevel();\n\n      if (metaLevel) {\n        descend((context) => {\n          const { MetaLevelAssumption } = elements,\n                metaLevelAssumption = MetaLevelAssumption.fromStep(step, context);\n\n          metaLevelAssumption.validate(context);\n\n          stepUnifiesWithReference = true;\n        }, context);\n      }\n    }\n\n    if (stepUnifiesWithReference) {\n      context.debug(`...unified the '${stepString}' step with the '${referenceString}' reference.`);\n    }\n  }\n\n  return stepUnifiesWithReference;\n}\n\nasync function unifyStepWithTopLevelAssertion(step, context) {\n  let stepUnifiesWithTopLevelAssertion = false;\n\n  const reference = step.getReference();\n\n  if (reference !== null) {\n    const topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const stepString = step.getString(),\n            topLevelAssertionString = reference.getString();\n\n      context.trace(`Unifying the '${stepString}' step with the '${topLevelAssertionString}' top level assertion...`);\n\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await topLevelAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithTopLevelAssertion = true;\n      }\n\n      if (stepUnifiesWithTopLevelAssertion) {\n        context.debug(`...unified the '${stepString}' step with the '${topLevelAssertionString}' top level assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesWithTopLevelAssertion;\n}\n\nasync function unifyStepWithSignatureAssertion(step, context) {\n  let stepUnifiesWithSignatureAssertion = false;\n\n  const signatureAssertion = step.getSignatureAssertion();\n\n  if (signatureAssertion !== null) {\n    const stepString = step.getString(),\n          signatureAssertionString = signatureAssertion.getString();\n\n    context.trace(`Unifying the '${stepString}' step with the '${signatureAssertionString}' signature assertion...`);\n\n    const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n          stepAndSubproofOrProofAssertionsUnify = await signatureAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n    if (stepAndSubproofOrProofAssertionsUnify) {\n      stepUnifiesWithSignatureAssertion = true;\n    }\n\n    if (stepUnifiesWithSignatureAssertion) {\n      context.debug(`...unified the '${stepString}' step with the '${signatureAssertionString}' signature assertion.`);\n    }\n  }\n\n  return stepUnifiesWithSignatureAssertion;\n}\n\nasync function unifyStepAsUnqualifiedEquality(step, context) {\n  let stepUnifiesAUnqualifiedEquality = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { Equality } = elements,\n          statement = step.getStatement(),\n          equality = Equality.fromStatement(statement, context);\n\n    if (equality !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an unqualified equality...`);\n\n      stepUnifiesAUnqualifiedEquality = true;\n\n      if (stepUnifiesAUnqualifiedEquality) {\n        context.debug(`...unified the '${stepString}' step as an unqualified equality.`);\n      }\n    }\n  }\n\n  return stepUnifiesAUnqualifiedEquality;\n}\n\nasync function unifyStepAsUNqualifiedJudgement(step, context) {\n  let stepUnifiesAsUnqualifiedJudgement = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { Judgement } = elements,\n          statement = step.getStatement(),\n          judgement = Judgement.fromStatement(statement, context);\n\n    if (judgement !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an unqualified judgement...`);\n\n      stepUnifiesAsUnqualifiedJudgement = true;\n\n      if (stepUnifiesAsUnqualifiedJudgement) {\n        context.debug(`...unified the '${stepString}' step as an unqualified judgement.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsUnqualifiedJudgement;\n}\n\nasync function unifyStepAsUnqualifiedTypeAssertion(step, context) {\n  let stepUnifiesAsUnqualifiedTypeAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { TypeAssertion } = elements,\n          statement = step.getStatement(),\n          typeAssertion = TypeAssertion.fromStatement(statement, context);\n\n    if (typeAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an unqualified type assertion...`);\n\n      stepUnifiesAsUnqualifiedTypeAssertion = true;\n\n      if (stepUnifiesAsUnqualifiedTypeAssertion) {\n        context.debug(`...unified the '${stepString}' step as an unqualified type assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsUnqualifiedTypeAssertion;\n}\n\nasync function unifyStepAsUnqualifiedPropertyAssertion(step, context) {\n  let stepUnifiesAsUnqualifiedPropertyAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { PropertyAssertion } = elements,\n          statement = step.getStatement(),\n          propertyAssertion = PropertyAssertion.fromStatement(statement, context);\n\n    if (propertyAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an unqualified property assertion...`);\n\n      stepUnifiesAsUnqualifiedPropertyAssertion = true;\n\n      if (stepUnifiesAsUnqualifiedPropertyAssertion) {\n        context.debug(`...unified the '${stepString}' step as an unqualified property assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsUnqualifiedPropertyAssertion;\n}\n\nasync function unifyStepAsUnqualifiedSignatureAssertion(step, context) {\n  let stepUnifiesAsUnqualifiedSignatureAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { SignatureAssertion } = elements,\n          statement = step.getStatement(),\n          signatureAssertion = SignatureAssertion.fromStatement(statement, context);\n\n    if (signatureAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as a signature assertion...`);\n\n      stepUnifiesAsUnqualifiedSignatureAssertion = true;\n\n      if (stepUnifiesAsUnqualifiedSignatureAssertion) {\n        context.debug(`...unified the '${stepString}' step as a signature assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsUnqualifiedSignatureAssertion;\n}\n\nasync function unifyStepAsSignatureAssertionWithReference(step, context) {\n  let stepUnifiesAsSignatureAssertionWithReference = false;\n\n  const reference = step.getReference();\n\n  if (reference !== null) {\n    const topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const statementNode = step.getStatementNode(),\n            signatureAssertionNode = statementNode.getSignatureAssertionNode();\n\n      if (signatureAssertionNode !== null) {\n        const stepString = step.getString(),\n              referenceString = reference.getString(),\n              signatureAssertion = context.findAssertionByAssertionNode(signatureAssertionNode);\n\n        context.trace(`Unifying the '${stepString}' step as a signature assertion with the '${referenceString}' reference...`);\n\n        const unifyTopLevelAssertion = await signatureAssertion.unifyTopLevelAssertion(topLevelAssertion, context);\n\n        if (unifyTopLevelAssertion) {\n          stepUnifiesAsSignatureAssertionWithReference = true;\n        }\n\n        if (stepUnifiesAsSignatureAssertionWithReference) {\n          context.debug(`...unified the '${stepString}' step as a signature assertion with the '${referenceString}' reference.`);\n        }\n      }\n    }\n  }\n\n  return stepUnifiesAsSignatureAssertionWithReference;\n}\n\nasync function compareStepWithSubproofOrProofAssertions(step, context) {\n  let stepComparesToSubproofOrProofAssertions = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const stepString = step.getString();\n\n    context.trace(`Comparing the '${stepString}' step with the subproofs or proof asssertions...`);\n\n    const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n          comparesToSubproofOrProofAssertions = step.compareSubproofOrProofAssertions(subproofOrProofAssertions, context);\n\n    if (comparesToSubproofOrProofAssertions) {\n      stepComparesToSubproofOrProofAssertions = true;\n    }\n\n    if (stepComparesToSubproofOrProofAssertions) {\n      context.debug(`...compared the '${stepString}' step with the subproofs or proof asssertions.`);\n    }\n  }\n\n  return stepComparesToSubproofOrProofAssertions;\n}\n\nexport const unifySteps = [\n  unifyStepWithRule,\n  unifyStepWithReference,\n  unifyStepWithTopLevelAssertion,\n  unifyStepWithSignatureAssertion,\n  unifyStepAsUnqualifiedEquality,\n  unifyStepAsUNqualifiedJudgement,\n  unifyStepAsUnqualifiedTypeAssertion,\n  unifyStepAsUnqualifiedPropertyAssertion,\n  unifyStepAsUnqualifiedSignatureAssertion,\n  unifyStepAsSignatureAssertionWithReference,\n  compareStepWithSubproofOrProofAssertions\n];\n"],"names":["unifySteps","unifyStepWithRule","step","context","stepUnifiesWithRule","reference","getReference","rule","findRuleByReference","stepString","getString","ruleString","trace","subproofOrProofAssertions","getSubproofOrProofAssertions","stepAndSubproofOrProofAssertionsUnify","unifyStepAndSubproofOrProofAssertions","debug","unifyStepWithReference","stepUnifiesWithReference","referenceString","topLevelAssertion","findTopLevelAssertionByReference","metaLevel","isMetaLevel","descend","MetaLevelAssumption","elements","metaLevelAssumption","fromStep","validate","unifyStepWithTopLevelAssertion","stepUnifiesWithTopLevelAssertion","topLevelAssertionString","unifyStepWithSignatureAssertion","stepUnifiesWithSignatureAssertion","signatureAssertion","getSignatureAssertion","signatureAssertionString","unifyStepAsUnqualifiedEquality","stepUnifiesAUnqualifiedEquality","unqualified","isUnqualified","Equality","statement","getStatement","equality","fromStatement","unifyStepAsUNqualifiedJudgement","stepUnifiesAsUnqualifiedJudgement","Judgement","judgement","unifyStepAsUnqualifiedTypeAssertion","stepUnifiesAsUnqualifiedTypeAssertion","TypeAssertion","typeAssertion","unifyStepAsUnqualifiedPropertyAssertion","stepUnifiesAsUnqualifiedPropertyAssertion","PropertyAssertion","propertyAssertion","unifyStepAsUnqualifiedSignatureAssertion","stepUnifiesAsUnqualifiedSignatureAssertion","SignatureAssertion","unifyStepAsSignatureAssertionWithReference","stepUnifiesAsSignatureAssertionWithReference","statementNode","getStatementNode","signatureAssertionNode","getSignatureAssertionNode","findAssertionByAssertionNode","unifyTopLevelAssertion","compareStepWithSubproofOrProofAssertions","stepComparesToSubproofOrProofAssertions","comparesToSubproofOrProofAssertions","compareSubproofOrProofAssertions"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-verify-cli",
3
3
  "author": "James Smith",
4
- "version": "1.0.913",
4
+ "version": "1.0.920",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-verify-cli",
7
7
  "description": "Occam's Verifier",
@@ -12,12 +12,12 @@
12
12
  "dependencies": {
13
13
  "argumentative": "^2.0.47",
14
14
  "necessary": "^17.1.7",
15
- "occam-furtle": "^3.0.195",
15
+ "occam-furtle": "^3.0.197",
16
16
  "occam-grammars": "^1.3.524",
17
- "occam-languages": "^0.0.199",
17
+ "occam-languages": "^0.0.202",
18
18
  "occam-lexers": "^23.1.44",
19
19
  "occam-model": "^1.0.506",
20
- "occam-nominal": "^1.0.103",
20
+ "occam-nominal": "^1.0.105",
21
21
  "occam-parsers": "^23.1.50",
22
22
  "occam-server": "^7.0.7"
23
23
  },
@@ -4,7 +4,7 @@ import { arrayUtilities } from "necessary";
4
4
 
5
5
  import Context from "../context";
6
6
 
7
- import { mergeEquivalences, findEquivalenceByTerm, equivalencesFromEquality, separateGroundedTermsAndDefinedVariables } from "../utilities/equivalences";
7
+ import { mergeEquivalences, equivalencesFromEquality, separateGroundedTermsAndDefinedVariables } from "../utilities/equivalences";
8
8
 
9
9
  const { last, filter } = arrayUtilities;
10
10
 
@@ -240,8 +240,6 @@ class BoundedContext extends Context {
240
240
  return comparesToTermAndPropertyRelation;
241
241
  }
242
242
 
243
- findEquivalenceByTerm(term) { return findEquivalenceByTerm(this.equivalences, term); }
244
-
245
243
  findDeclaredJudgementByMetavariableNode(metavariableNode) {
246
244
  const declaredJudgements = this.getDeclaredJudgements(),
247
245
  declaredJudgement = declaredJudgements.find((declaredJudgement) => {