@trynullsec/s1-zk 1.0.0
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.
- package/LIMITATIONS.md +17 -0
- package/README.md +149 -0
- package/ROADMAP.md +21 -0
- package/RULES.md +229 -0
- package/benchmarks/historical/orchard-inspired/partial-ec-mul-halo2.rs +53 -0
- package/benchmarks/historical/orchard-inspired/safe-ec-mul-halo2.rs +69 -0
- package/dist/ai/prompt-builder.d.ts +2 -0
- package/dist/ai/prompt-builder.js +33 -0
- package/dist/ai/prompt-builder.js.map +1 -0
- package/dist/ai/reasoning-interface.d.ts +15 -0
- package/dist/ai/reasoning-interface.js +2 -0
- package/dist/ai/reasoning-interface.js.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +71 -0
- package/dist/cli.js.map +1 -0
- package/dist/config.d.ts +4 -0
- package/dist/config.js +41 -0
- package/dist/config.js.map +1 -0
- package/dist/core/audit-engine.d.ts +3 -0
- package/dist/core/audit-engine.js +31 -0
- package/dist/core/audit-engine.js.map +1 -0
- package/dist/core/file-loader.d.ts +6 -0
- package/dist/core/file-loader.js +28 -0
- package/dist/core/file-loader.js.map +1 -0
- package/dist/core/issue-builder.d.ts +16 -0
- package/dist/core/issue-builder.js +27 -0
- package/dist/core/issue-builder.js.map +1 -0
- package/dist/core/range-check-classifier.d.ts +16 -0
- package/dist/core/range-check-classifier.js +194 -0
- package/dist/core/range-check-classifier.js.map +1 -0
- package/dist/core/rule-engine.d.ts +10 -0
- package/dist/core/rule-engine.js +41 -0
- package/dist/core/rule-engine.js.map +1 -0
- package/dist/core/severity.d.ts +6 -0
- package/dist/core/severity.js +21 -0
- package/dist/core/severity.js.map +1 -0
- package/dist/core/source-map.d.ts +3 -0
- package/dist/core/source-map.js +16 -0
- package/dist/core/source-map.js.map +1 -0
- package/dist/frontends/circom/circom-comments.d.ts +8 -0
- package/dist/frontends/circom/circom-comments.js +52 -0
- package/dist/frontends/circom/circom-comments.js.map +1 -0
- package/dist/frontends/circom/circom-ir-builder.d.ts +2 -0
- package/dist/frontends/circom/circom-ir-builder.js +12 -0
- package/dist/frontends/circom/circom-ir-builder.js.map +1 -0
- package/dist/frontends/circom/circom-parser.d.ts +2 -0
- package/dist/frontends/circom/circom-parser.js +218 -0
- package/dist/frontends/circom/circom-parser.js.map +1 -0
- package/dist/frontends/circom/circom-tokenizer.d.ts +7 -0
- package/dist/frontends/circom/circom-tokenizer.js +79 -0
- package/dist/frontends/circom/circom-tokenizer.js.map +1 -0
- package/dist/frontends/circom/circom-utils.d.ts +9 -0
- package/dist/frontends/circom/circom-utils.js +88 -0
- package/dist/frontends/circom/circom-utils.js.map +1 -0
- package/dist/frontends/gnark/gnark-adapter.d.ts +5 -0
- package/dist/frontends/gnark/gnark-adapter.js +7 -0
- package/dist/frontends/gnark/gnark-adapter.js.map +1 -0
- package/dist/frontends/halo2/halo2-adapter.d.ts +8 -0
- package/dist/frontends/halo2/halo2-adapter.js +12 -0
- package/dist/frontends/halo2/halo2-adapter.js.map +1 -0
- package/dist/frontends/halo2/halo2-constraint-extractor.d.ts +29 -0
- package/dist/frontends/halo2/halo2-constraint-extractor.js +38 -0
- package/dist/frontends/halo2/halo2-constraint-extractor.js.map +1 -0
- package/dist/frontends/halo2/halo2-constraint-graph.d.ts +16 -0
- package/dist/frontends/halo2/halo2-constraint-graph.js +96 -0
- package/dist/frontends/halo2/halo2-constraint-graph.js.map +1 -0
- package/dist/frontends/halo2/halo2-dataflow.d.ts +11 -0
- package/dist/frontends/halo2/halo2-dataflow.js +19 -0
- package/dist/frontends/halo2/halo2-dataflow.js.map +1 -0
- package/dist/frontends/halo2/halo2-expression-parser.d.ts +14 -0
- package/dist/frontends/halo2/halo2-expression-parser.js +62 -0
- package/dist/frontends/halo2/halo2-expression-parser.js.map +1 -0
- package/dist/frontends/halo2/halo2-ir-builder.d.ts +2 -0
- package/dist/frontends/halo2/halo2-ir-builder.js +17 -0
- package/dist/frontends/halo2/halo2-ir-builder.js.map +1 -0
- package/dist/frontends/halo2/halo2-parser.d.ts +2 -0
- package/dist/frontends/halo2/halo2-parser.js +316 -0
- package/dist/frontends/halo2/halo2-parser.js.map +1 -0
- package/dist/frontends/halo2/halo2-patterns.d.ts +6 -0
- package/dist/frontends/halo2/halo2-patterns.js +54 -0
- package/dist/frontends/halo2/halo2-patterns.js.map +1 -0
- package/dist/frontends/halo2/halo2-types.d.ts +100 -0
- package/dist/frontends/halo2/halo2-types.js +2 -0
- package/dist/frontends/halo2/halo2-types.js.map +1 -0
- package/dist/frontends/noir/noir-adapter.d.ts +5 -0
- package/dist/frontends/noir/noir-adapter.js +7 -0
- package/dist/frontends/noir/noir-adapter.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/ir/circuit-ir.d.ts +1 -0
- package/dist/ir/circuit-ir.js +2 -0
- package/dist/ir/circuit-ir.js.map +1 -0
- package/dist/ir/component-table.d.ts +6 -0
- package/dist/ir/component-table.js +11 -0
- package/dist/ir/component-table.js.map +1 -0
- package/dist/ir/constraint-graph.d.ts +26 -0
- package/dist/ir/constraint-graph.js +130 -0
- package/dist/ir/constraint-graph.js.map +1 -0
- package/dist/ir/dataflow.d.ts +3 -0
- package/dist/ir/dataflow.js +10 -0
- package/dist/ir/dataflow.js.map +1 -0
- package/dist/ir/reference-index.d.ts +6 -0
- package/dist/ir/reference-index.js +18 -0
- package/dist/ir/reference-index.js.map +1 -0
- package/dist/ir/signal-table.d.ts +6 -0
- package/dist/ir/signal-table.js +16 -0
- package/dist/ir/signal-table.js.map +1 -0
- package/dist/report/json.d.ts +2 -0
- package/dist/report/json.js +4 -0
- package/dist/report/json.js.map +1 -0
- package/dist/report/markdown.d.ts +2 -0
- package/dist/report/markdown.js +45 -0
- package/dist/report/markdown.js.map +1 -0
- package/dist/report/sarif.d.ts +2 -0
- package/dist/report/sarif.js +52 -0
- package/dist/report/sarif.js.map +1 -0
- package/dist/report/summary.d.ts +2 -0
- package/dist/report/summary.js +7 -0
- package/dist/report/summary.js.map +1 -0
- package/dist/report/terminal.d.ts +2 -0
- package/dist/report/terminal.js +50 -0
- package/dist/report/terminal.js.map +1 -0
- package/dist/rules/NS-ZK-001-dangerous-hint-assignment.d.ts +2 -0
- package/dist/rules/NS-ZK-001-dangerous-hint-assignment.js +27 -0
- package/dist/rules/NS-ZK-001-dangerous-hint-assignment.js.map +1 -0
- package/dist/rules/NS-ZK-002-assigned-but-unconstrained.d.ts +2 -0
- package/dist/rules/NS-ZK-002-assigned-but-unconstrained.js +22 -0
- package/dist/rules/NS-ZK-002-assigned-but-unconstrained.js.map +1 -0
- package/dist/rules/NS-ZK-003-unbound-public-input.d.ts +2 -0
- package/dist/rules/NS-ZK-003-unbound-public-input.js +22 -0
- package/dist/rules/NS-ZK-003-unbound-public-input.js.map +1 -0
- package/dist/rules/NS-ZK-004-unconstrained-output.d.ts +2 -0
- package/dist/rules/NS-ZK-004-unconstrained-output.js +27 -0
- package/dist/rules/NS-ZK-004-unconstrained-output.js.map +1 -0
- package/dist/rules/NS-ZK-005-missing-booleanity.d.ts +2 -0
- package/dist/rules/NS-ZK-005-missing-booleanity.js +26 -0
- package/dist/rules/NS-ZK-005-missing-booleanity.js.map +1 -0
- package/dist/rules/NS-ZK-006-missing-range-check.d.ts +2 -0
- package/dist/rules/NS-ZK-006-missing-range-check.js +32 -0
- package/dist/rules/NS-ZK-006-missing-range-check.js.map +1 -0
- package/dist/rules/NS-ZK-007-unsafe-assertion.d.ts +2 -0
- package/dist/rules/NS-ZK-007-unsafe-assertion.js +24 -0
- package/dist/rules/NS-ZK-007-unsafe-assertion.js.map +1 -0
- package/dist/rules/NS-ZK-008-unsafe-division-or-inverse.d.ts +2 -0
- package/dist/rules/NS-ZK-008-unsafe-division-or-inverse.js +39 -0
- package/dist/rules/NS-ZK-008-unsafe-division-or-inverse.js.map +1 -0
- package/dist/rules/NS-ZK-009-unconstrained-component-output.d.ts +2 -0
- package/dist/rules/NS-ZK-009-unconstrained-component-output.js +25 -0
- package/dist/rules/NS-ZK-009-unconstrained-component-output.js.map +1 -0
- package/dist/rules/NS-ZK-010-alias-overflow-risk.d.ts +2 -0
- package/dist/rules/NS-ZK-010-alias-overflow-risk.js +48 -0
- package/dist/rules/NS-ZK-010-alias-overflow-risk.js.map +1 -0
- package/dist/rules/NS-ZK-011-unused-signal.d.ts +2 -0
- package/dist/rules/NS-ZK-011-unused-signal.js +26 -0
- package/dist/rules/NS-ZK-011-unused-signal.js.map +1 -0
- package/dist/rules/NS-ZK-012-suspicious-selector.d.ts +2 -0
- package/dist/rules/NS-ZK-012-suspicious-selector.js +33 -0
- package/dist/rules/NS-ZK-012-suspicious-selector.js.map +1 -0
- package/dist/rules/halo2/NS-H2-001-assigned-advice-not-constrained.d.ts +2 -0
- package/dist/rules/halo2/NS-H2-001-assigned-advice-not-constrained.js +40 -0
- package/dist/rules/halo2/NS-H2-001-assigned-advice-not-constrained.js.map +1 -0
- package/dist/rules/halo2/NS-H2-002-instance-not-bound.d.ts +2 -0
- package/dist/rules/halo2/NS-H2-002-instance-not-bound.js +32 -0
- package/dist/rules/halo2/NS-H2-002-instance-not-bound.js.map +1 -0
- package/dist/rules/halo2/NS-H2-003-selector-risk.d.ts +2 -0
- package/dist/rules/halo2/NS-H2-003-selector-risk.js +37 -0
- package/dist/rules/halo2/NS-H2-003-selector-risk.js.map +1 -0
- package/dist/rules/halo2/NS-H2-004-unsafe-inverse.d.ts +2 -0
- package/dist/rules/halo2/NS-H2-004-unsafe-inverse.js +43 -0
- package/dist/rules/halo2/NS-H2-004-unsafe-inverse.js.map +1 -0
- package/dist/rules/halo2/NS-H2-005-partial-ec-operation.d.ts +2 -0
- package/dist/rules/halo2/NS-H2-005-partial-ec-operation.js +43 -0
- package/dist/rules/halo2/NS-H2-005-partial-ec-operation.js.map +1 -0
- package/dist/rules/halo2/NS-H2-006-missing-enable-equality.d.ts +2 -0
- package/dist/rules/halo2/NS-H2-006-missing-enable-equality.js +31 -0
- package/dist/rules/halo2/NS-H2-006-missing-enable-equality.js.map +1 -0
- package/dist/rules/halo2/halo2-rule-utils.d.ts +8 -0
- package/dist/rules/halo2/halo2-rule-utils.js +24 -0
- package/dist/rules/halo2/halo2-rule-utils.js.map +1 -0
- package/dist/rules/index.d.ts +2 -0
- package/dist/rules/index.js +39 -0
- package/dist/rules/index.js.map +1 -0
- package/dist/scanner.d.ts +8 -0
- package/dist/scanner.js +52 -0
- package/dist/scanner.js.map +1 -0
- package/dist/types.d.ts +171 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/examples/halo2/safe/bound-instance.rs +23 -0
- package/examples/halo2/safe/constrained-advice.rs +27 -0
- package/examples/halo2/safe/safe-inverse.rs +30 -0
- package/examples/halo2/safe/safe-selector.rs +27 -0
- package/examples/halo2/vulnerable/missing-selector-booleanity.rs +20 -0
- package/examples/halo2/vulnerable/partial-ec-mul.rs +23 -0
- package/examples/halo2/vulnerable/unbound-instance.rs +20 -0
- package/examples/halo2/vulnerable/unconstrained-advice.rs +24 -0
- package/examples/halo2/vulnerable/unsafe-inverse.rs +20 -0
- package/examples/safe/safe-boolean.circom +15 -0
- package/examples/safe/safe-component-output.circom +18 -0
- package/examples/safe/safe-division.circom +14 -0
- package/examples/safe/safe-public-input.circom +15 -0
- package/examples/safe/safe-range-check.circom +16 -0
- package/examples/safe/safe-transfer.circom +19 -0
- package/examples/vulnerable/alias-overflow-risk.circom +12 -0
- package/examples/vulnerable/merkle-selector-bug.circom +12 -0
- package/examples/vulnerable/missing-boolean.circom +11 -0
- package/examples/vulnerable/missing-range-check.circom +11 -0
- package/examples/vulnerable/public-input-not-bound.circom +12 -0
- package/examples/vulnerable/unconstrained-component-output.circom +15 -0
- package/examples/vulnerable/unconstrained-transfer.circom +17 -0
- package/examples/vulnerable/unsafe-assertion.circom +12 -0
- package/examples/vulnerable/unsafe-division.circom +11 -0
- package/package.json +46 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { expressionUsesAliasAsMultiplier } from "./halo2-expression-parser.js";
|
|
2
|
+
import { extractHalo2ConstraintModel, normalizeHalo2Column } from "./halo2-constraint-extractor.js";
|
|
3
|
+
function includesToken(text, token) {
|
|
4
|
+
if (!text || !token)
|
|
5
|
+
return false;
|
|
6
|
+
const escaped = token.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
7
|
+
return new RegExp(`(^|[^A-Za-z0-9_])${escaped}([^A-Za-z0-9_]|$)`).test(text);
|
|
8
|
+
}
|
|
9
|
+
function assignmentTokens(node) {
|
|
10
|
+
return [
|
|
11
|
+
node.columnName,
|
|
12
|
+
node.label,
|
|
13
|
+
node.cellVariable,
|
|
14
|
+
node.assignment.assignedVariable,
|
|
15
|
+
node.assignment.target,
|
|
16
|
+
...node.assignment.referencedSymbols
|
|
17
|
+
].filter((value) => Boolean(value));
|
|
18
|
+
}
|
|
19
|
+
export class Halo2ConstraintGraph {
|
|
20
|
+
ir;
|
|
21
|
+
model;
|
|
22
|
+
constructor(ir) {
|
|
23
|
+
this.ir = ir;
|
|
24
|
+
this.model = extractHalo2ConstraintModel(ir);
|
|
25
|
+
}
|
|
26
|
+
assignmentNode(assignment) {
|
|
27
|
+
return this.model.assignments.find((node) => node.assignment === assignment);
|
|
28
|
+
}
|
|
29
|
+
gatesForColumn(columnName) {
|
|
30
|
+
const normalized = normalizeHalo2Column(columnName);
|
|
31
|
+
if (!normalized)
|
|
32
|
+
return [];
|
|
33
|
+
return this.model.gates.filter((gate) => gate.adviceColumns.includes(normalized) || gate.instanceColumns.includes(normalized)).map((gate) => gate.gate.name);
|
|
34
|
+
}
|
|
35
|
+
isAssignmentConnected(assignment) {
|
|
36
|
+
return this.assignmentConnections(assignment).length > 0;
|
|
37
|
+
}
|
|
38
|
+
assignmentConnections(assignment) {
|
|
39
|
+
const node = this.assignmentNode(assignment);
|
|
40
|
+
if (!node)
|
|
41
|
+
return [];
|
|
42
|
+
const tokens = assignmentTokens(node);
|
|
43
|
+
const connections = new Set();
|
|
44
|
+
const columnGates = this.gatesForColumn(node.columnName);
|
|
45
|
+
for (const gateName of columnGates)
|
|
46
|
+
connections.add(`gate:${gateName}`);
|
|
47
|
+
for (const gate of this.model.gates.filter((candidate) => candidate.gate.file === assignment.file)) {
|
|
48
|
+
if (tokens.some((token) => gate.expressions.some((expression) => includesToken(expression, token))))
|
|
49
|
+
connections.add(`gate-expression:${gate.gate.name}`);
|
|
50
|
+
}
|
|
51
|
+
for (const eq of this.ir.equalityConstraints.filter((constraint) => constraint.file === assignment.file)) {
|
|
52
|
+
if (tokens.some((token) => includesToken(eq.snippet, token)))
|
|
53
|
+
connections.add("equality");
|
|
54
|
+
}
|
|
55
|
+
for (const copy of this.ir.copyConstraints.filter((constraint) => constraint.file === assignment.file)) {
|
|
56
|
+
if (tokens.some((token) => includesToken(copy.snippet, token)))
|
|
57
|
+
connections.add("copy");
|
|
58
|
+
}
|
|
59
|
+
for (const binding of this.model.instanceBindings.filter((constraint) => constraint.file === assignment.file)) {
|
|
60
|
+
if (tokens.some((token) => includesToken(binding.snippet, token)))
|
|
61
|
+
connections.add("instance");
|
|
62
|
+
}
|
|
63
|
+
for (const lookup of this.model.lookups.filter((candidate) => candidate.file === assignment.file)) {
|
|
64
|
+
if (tokens.some((token) => includesToken(lookup.expression, token)))
|
|
65
|
+
connections.add("lookup");
|
|
66
|
+
}
|
|
67
|
+
return [...connections];
|
|
68
|
+
}
|
|
69
|
+
selectorEnabled(selectorName) {
|
|
70
|
+
const normalized = normalizeHalo2Column(selectorName) ?? selectorName;
|
|
71
|
+
return this.ir.selectors.some((selector) => (selector.name === normalized || normalizeHalo2Column(selector.name) === normalized) && selector.enabledLines.length > 0);
|
|
72
|
+
}
|
|
73
|
+
selectorUsedAsGateMultiplier(selectorName) {
|
|
74
|
+
const normalized = normalizeHalo2Column(selectorName) ?? selectorName;
|
|
75
|
+
return this.model.gates.some((gate) => {
|
|
76
|
+
const aliases = Object.entries(gate.gate.selectorAliases ?? {}).filter(([, column]) => normalizeHalo2Column(column) === normalized).map(([alias]) => alias);
|
|
77
|
+
return aliases.some((alias) => gate.expressions.some((expression) => expressionUsesAliasAsMultiplier(expression, alias)));
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
instanceQueryIsBound(queryColumnName, file) {
|
|
81
|
+
const normalized = normalizeHalo2Column(queryColumnName) ?? queryColumnName;
|
|
82
|
+
const queriedInGate = this.model.gates.some((gate) => gate.gate.file === file && gate.instanceColumns.includes(normalized));
|
|
83
|
+
const exposed = this.model.instanceBindings.some((binding) => binding.file === file && includesToken(binding.snippet, normalized));
|
|
84
|
+
return queriedInGate || exposed;
|
|
85
|
+
}
|
|
86
|
+
columnHasEqualityEnabled(columnName) {
|
|
87
|
+
const normalized = normalizeHalo2Column(columnName);
|
|
88
|
+
if (!normalized)
|
|
89
|
+
return false;
|
|
90
|
+
return this.ir.columns.some((column) => normalizeHalo2Column(column.name) === normalized && column.equalityEnabled);
|
|
91
|
+
}
|
|
92
|
+
equalityConstraintHasEnabledColumn(snippet) {
|
|
93
|
+
return this.ir.columns.some((column) => column.equalityEnabled && includesToken(snippet, column.name));
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=halo2-constraint-graph.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"halo2-constraint-graph.js","sourceRoot":"","sources":["../../../src/frontends/halo2/halo2-constraint-graph.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Halo2Assignment } from "./halo2-types.js";
|
|
2
|
+
import { Halo2ConstraintGraph } from "./halo2-constraint-graph.js";
|
|
3
|
+
export interface Halo2AssignmentFlow {
|
|
4
|
+
assignment: Halo2Assignment;
|
|
5
|
+
connected: boolean;
|
|
6
|
+
connections: string[];
|
|
7
|
+
ecRelated: boolean;
|
|
8
|
+
}
|
|
9
|
+
export declare function assignmentFlows(graph: Halo2ConstraintGraph): Halo2AssignmentFlow[];
|
|
10
|
+
export declare function unconstrainedAssignments(graph: Halo2ConstraintGraph): Halo2AssignmentFlow[];
|
|
11
|
+
export declare function unconstrainedEcAssignments(graph: Halo2ConstraintGraph): Halo2AssignmentFlow[];
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { isEcLikeName } from "./halo2-patterns.js";
|
|
2
|
+
export function assignmentFlows(graph) {
|
|
3
|
+
return graph.ir.assignments.map((assignment) => {
|
|
4
|
+
const connections = graph.assignmentConnections(assignment);
|
|
5
|
+
return {
|
|
6
|
+
assignment,
|
|
7
|
+
connected: connections.length > 0,
|
|
8
|
+
connections,
|
|
9
|
+
ecRelated: isEcLikeName(`${assignment.expression} ${assignment.label ?? ""} ${assignment.columnName ?? ""} ${assignment.assignedVariable ?? ""}`)
|
|
10
|
+
};
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
export function unconstrainedAssignments(graph) {
|
|
14
|
+
return assignmentFlows(graph).filter((flow) => !flow.connected);
|
|
15
|
+
}
|
|
16
|
+
export function unconstrainedEcAssignments(graph) {
|
|
17
|
+
return unconstrainedAssignments(graph).filter((flow) => flow.ecRelated);
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=halo2-dataflow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"halo2-dataflow.js","sourceRoot":"","sources":["../../../src/frontends/halo2/halo2-dataflow.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAWnD,MAAM,UAAU,eAAe,CAAC,KAA2B;IACzD,OAAO,KAAK,CAAC,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;QAC7C,MAAM,WAAW,GAAG,KAAK,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAC5D,OAAO;YACL,UAAU;YACV,SAAS,EAAE,WAAW,CAAC,MAAM,GAAG,CAAC;YACjC,WAAW;YACX,SAAS,EAAE,YAAY,CAAC,GAAG,UAAU,CAAC,UAAU,IAAI,UAAU,CAAC,KAAK,IAAI,EAAE,IAAI,UAAU,CAAC,UAAU,IAAI,EAAE,IAAI,UAAU,CAAC,gBAAgB,IAAI,EAAE,EAAE,CAAC;SAClJ,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,KAA2B;IAClE,OAAO,eAAe,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;AAClE,CAAC;AAED,MAAM,UAAU,0BAA0B,CAAC,KAA2B;IACpE,OAAO,wBAAwB,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;AAC1E,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export interface Halo2ParsedGateExpression {
|
|
2
|
+
returnedExpressions: string[];
|
|
3
|
+
variableReferences: string[];
|
|
4
|
+
selectorAliases: Record<string, string>;
|
|
5
|
+
adviceAliases: Record<string, string>;
|
|
6
|
+
instanceAliases: Record<string, string>;
|
|
7
|
+
fixedAliases: Record<string, string>;
|
|
8
|
+
rotations: Array<{
|
|
9
|
+
alias: string;
|
|
10
|
+
rotation: "cur" | "prev" | "next" | string;
|
|
11
|
+
}>;
|
|
12
|
+
}
|
|
13
|
+
export declare function parseHalo2GateExpression(body: string): Halo2ParsedGateExpression;
|
|
14
|
+
export declare function expressionUsesAliasAsMultiplier(expression: string, alias: string): boolean;
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { extractRustSymbols } from "./halo2-patterns.js";
|
|
2
|
+
function normalizeColumn(value) {
|
|
3
|
+
return value.trim().replace(/^config\./, "").replace(/^self\./, "");
|
|
4
|
+
}
|
|
5
|
+
function extractVecExpressions(body) {
|
|
6
|
+
const vecMatch = body.match(/vec!\s*\[([\s\S]*?)\]\s*;?/);
|
|
7
|
+
if (!vecMatch)
|
|
8
|
+
return [];
|
|
9
|
+
const inner = vecMatch[1] ?? "";
|
|
10
|
+
const expressions = [];
|
|
11
|
+
let depth = 0;
|
|
12
|
+
let current = "";
|
|
13
|
+
for (const ch of inner) {
|
|
14
|
+
if (ch === "(" || ch === "[" || ch === "{")
|
|
15
|
+
depth += 1;
|
|
16
|
+
if (ch === ")" || ch === "]" || ch === "}")
|
|
17
|
+
depth -= 1;
|
|
18
|
+
if (ch === "," && depth === 0) {
|
|
19
|
+
if (current.trim())
|
|
20
|
+
expressions.push(current.trim());
|
|
21
|
+
current = "";
|
|
22
|
+
continue;
|
|
23
|
+
}
|
|
24
|
+
current += ch;
|
|
25
|
+
}
|
|
26
|
+
if (current.trim())
|
|
27
|
+
expressions.push(current.trim());
|
|
28
|
+
return expressions;
|
|
29
|
+
}
|
|
30
|
+
export function parseHalo2GateExpression(body) {
|
|
31
|
+
const selectorAliases = {};
|
|
32
|
+
const adviceAliases = {};
|
|
33
|
+
const instanceAliases = {};
|
|
34
|
+
const fixedAliases = {};
|
|
35
|
+
const rotations = [];
|
|
36
|
+
const queryPattern = /let\s+([A-Za-z_][A-Za-z0-9_]*)\s*=\s*meta\.query_(advice|instance|fixed|selector)\s*\(([^)]*)\)/g;
|
|
37
|
+
for (const match of body.matchAll(queryPattern)) {
|
|
38
|
+
const alias = match[1] ?? "unknown";
|
|
39
|
+
const queryType = match[2] ?? "unknown";
|
|
40
|
+
const args = (match[3] ?? "").split(",").map((arg) => arg.trim());
|
|
41
|
+
const columnName = normalizeColumn(args[0] ?? "unknown");
|
|
42
|
+
const rotation = args.find((arg) => /Rotation::/.test(arg))?.match(/Rotation::([A-Za-z_][A-Za-z0-9_]*)/)?.[1] ?? "cur";
|
|
43
|
+
if (queryType === "selector")
|
|
44
|
+
selectorAliases[alias] = columnName;
|
|
45
|
+
if (queryType === "advice")
|
|
46
|
+
adviceAliases[alias] = columnName;
|
|
47
|
+
if (queryType === "instance")
|
|
48
|
+
instanceAliases[alias] = columnName;
|
|
49
|
+
if (queryType === "fixed")
|
|
50
|
+
fixedAliases[alias] = columnName;
|
|
51
|
+
if (queryType !== "selector")
|
|
52
|
+
rotations.push({ alias, rotation });
|
|
53
|
+
}
|
|
54
|
+
const returnedExpressions = extractVecExpressions(body);
|
|
55
|
+
const variableReferences = [...new Set(returnedExpressions.flatMap((expression) => extractRustSymbols(expression)))];
|
|
56
|
+
return { returnedExpressions, variableReferences, selectorAliases, adviceAliases, instanceAliases, fixedAliases, rotations };
|
|
57
|
+
}
|
|
58
|
+
export function expressionUsesAliasAsMultiplier(expression, alias) {
|
|
59
|
+
const compact = expression.replace(/\s+/g, "");
|
|
60
|
+
return compact.includes(`${alias}*`) || compact.includes(`*${alias}`);
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=halo2-expression-parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"halo2-expression-parser.js","sourceRoot":"","sources":["../../../src/frontends/halo2/halo2-expression-parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export function buildHalo2IR(files) {
|
|
2
|
+
return {
|
|
3
|
+
files,
|
|
4
|
+
columns: files.flatMap((file) => file.columns),
|
|
5
|
+
selectors: files.flatMap((file) => file.selectors),
|
|
6
|
+
gates: files.flatMap((file) => file.gates),
|
|
7
|
+
queries: files.flatMap((file) => file.queries),
|
|
8
|
+
assignments: files.flatMap((file) => file.assignments),
|
|
9
|
+
equalityConstraints: files.flatMap((file) => file.equalityConstraints),
|
|
10
|
+
instanceConstraints: files.flatMap((file) => file.instanceConstraints),
|
|
11
|
+
lookups: files.flatMap((file) => file.lookups),
|
|
12
|
+
regions: files.flatMap((file) => file.regions),
|
|
13
|
+
copyConstraints: files.flatMap((file) => file.copyConstraints),
|
|
14
|
+
parserWarnings: files.flatMap((file) => file.parserWarnings)
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=halo2-ir-builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"halo2-ir-builder.js","sourceRoot":"","sources":["../../../src/frontends/halo2/halo2-ir-builder.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,YAAY,CAAC,KAAyB;IACpD,OAAO;QACL,KAAK;QACL,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC;QAC9C,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC;QAClD,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC;QAC1C,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC;QAC9C,WAAW,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC;QACtD,mBAAmB,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC;QACtE,mBAAmB,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC;QACtE,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC;QAC9C,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC;QAC9C,eAAe,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC;QAC9D,cAAc,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC;KAC7D,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,316 @@
|
|
|
1
|
+
import { columnOf, getLine } from "../../core/source-map.js";
|
|
2
|
+
import { extractRustSymbols, halo2DetectionPatterns, isLikelyHalo2Source } from "./halo2-patterns.js";
|
|
3
|
+
import { parseHalo2GateExpression } from "./halo2-expression-parser.js";
|
|
4
|
+
function lineNumberAt(source, index) {
|
|
5
|
+
return source.slice(0, index).split(/\r?\n/).length;
|
|
6
|
+
}
|
|
7
|
+
function findBalancedBlock(source, startIndex) {
|
|
8
|
+
const open = source.indexOf("{", startIndex);
|
|
9
|
+
if (open < 0)
|
|
10
|
+
return undefined;
|
|
11
|
+
let depth = 0;
|
|
12
|
+
for (let i = open; i < source.length; i += 1) {
|
|
13
|
+
const ch = source[i];
|
|
14
|
+
if (ch === "{")
|
|
15
|
+
depth += 1;
|
|
16
|
+
if (ch === "}")
|
|
17
|
+
depth -= 1;
|
|
18
|
+
if (depth === 0) {
|
|
19
|
+
const startLine = lineNumberAt(source, startIndex);
|
|
20
|
+
return {
|
|
21
|
+
text: source.slice(open + 1, i),
|
|
22
|
+
startLine,
|
|
23
|
+
endLine: lineNumberAt(source, i),
|
|
24
|
+
snippet: getLine(source, startLine).trim()
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return undefined;
|
|
29
|
+
}
|
|
30
|
+
function extractGateName(prefix) {
|
|
31
|
+
const quoted = prefix.match(/create_gate\s*\(\s*"([^"]+)"/);
|
|
32
|
+
return quoted?.[1] ?? "unnamed gate";
|
|
33
|
+
}
|
|
34
|
+
function extractQueries(filePath, source, gateName, lineOffset = 0) {
|
|
35
|
+
const queries = [];
|
|
36
|
+
const regex = /query_(advice|fixed|instance|selector)\s*\(([^)]*)\)/g;
|
|
37
|
+
for (const match of source.matchAll(regex)) {
|
|
38
|
+
const queryType = match[1];
|
|
39
|
+
const args = (match[2] ?? "").split(",").map((arg) => arg.trim());
|
|
40
|
+
const line = lineOffset + lineNumberAt(source, match.index ?? 0);
|
|
41
|
+
queries.push({
|
|
42
|
+
queryType,
|
|
43
|
+
columnName: args[0] ?? "unknown",
|
|
44
|
+
rotation: args[1],
|
|
45
|
+
gateName,
|
|
46
|
+
file: filePath,
|
|
47
|
+
line,
|
|
48
|
+
column: columnOf(getLine(source, line - lineOffset), match[0] ?? ""),
|
|
49
|
+
snippet: getLine(source, line - lineOffset).trim()
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
return queries;
|
|
53
|
+
}
|
|
54
|
+
function extractColumns(filePath, rawSource) {
|
|
55
|
+
const columns = [];
|
|
56
|
+
const lines = rawSource.split(/\r?\n/);
|
|
57
|
+
const regex = /(?:let\s+)?([A-Za-z_][A-Za-z0-9_]*)\s*=\s*(?:meta\.)?(advice_column|fixed_column|instance_column)\s*\(/;
|
|
58
|
+
lines.forEach((lineText, index) => {
|
|
59
|
+
const match = lineText.match(regex);
|
|
60
|
+
if (!match)
|
|
61
|
+
return;
|
|
62
|
+
const kind = match[2] === "advice_column" ? "advice" : match[2] === "fixed_column" ? "fixed" : "instance";
|
|
63
|
+
const name = match[1] ?? "unknown";
|
|
64
|
+
const equalityEnabled = new RegExp(`enable_equality\\s*\\(\\s*${name}\\s*\\)`).test(rawSource);
|
|
65
|
+
columns.push({
|
|
66
|
+
name,
|
|
67
|
+
columnType: kind,
|
|
68
|
+
equalityEnabled,
|
|
69
|
+
file: filePath,
|
|
70
|
+
line: index + 1,
|
|
71
|
+
column: columnOf(lineText, name),
|
|
72
|
+
snippet: lineText.trim()
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
return columns;
|
|
76
|
+
}
|
|
77
|
+
function extractSelectors(filePath, rawSource, gates) {
|
|
78
|
+
const selectors = new Map();
|
|
79
|
+
const lines = rawSource.split(/\r?\n/);
|
|
80
|
+
lines.forEach((lineText, index) => {
|
|
81
|
+
const construct = lineText.match(/(?:let\s+)?([A-Za-z_][A-Za-z0-9_]*)\s*=\s*(?:meta\.)?(selector|complex_selector)\s*\(/);
|
|
82
|
+
const typed = lineText.match(/([A-Za-z_][A-Za-z0-9_]*)\s*:\s*Selector\b/);
|
|
83
|
+
const match = construct ?? typed;
|
|
84
|
+
if (!match)
|
|
85
|
+
return;
|
|
86
|
+
const name = match[1] ?? "selector";
|
|
87
|
+
selectors.set(name, {
|
|
88
|
+
name,
|
|
89
|
+
enabledLines: [],
|
|
90
|
+
usedInGates: [],
|
|
91
|
+
file: filePath,
|
|
92
|
+
line: index + 1,
|
|
93
|
+
column: columnOf(lineText, name),
|
|
94
|
+
snippet: lineText.trim()
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
for (const gate of gates) {
|
|
98
|
+
for (const selector of gate.selectors) {
|
|
99
|
+
const existing = selectors.get(selector) ??
|
|
100
|
+
{
|
|
101
|
+
name: selector,
|
|
102
|
+
enabledLines: [],
|
|
103
|
+
usedInGates: [],
|
|
104
|
+
file: filePath,
|
|
105
|
+
line: gate.line,
|
|
106
|
+
column: gate.column,
|
|
107
|
+
snippet: gate.snippet
|
|
108
|
+
};
|
|
109
|
+
existing.usedInGates.push(gate.name);
|
|
110
|
+
selectors.set(selector, existing);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
lines.forEach((lineText, index) => {
|
|
114
|
+
const enable = lineText.match(/([A-Za-z_][A-Za-z0-9_.]*)\.enable\s*\(/);
|
|
115
|
+
if (!enable)
|
|
116
|
+
return;
|
|
117
|
+
const name = (enable[1] ?? "").split(".").pop() ?? enable[1] ?? "";
|
|
118
|
+
const existing = selectors.get(name) ??
|
|
119
|
+
{
|
|
120
|
+
name,
|
|
121
|
+
enabledLines: [],
|
|
122
|
+
usedInGates: [],
|
|
123
|
+
file: filePath,
|
|
124
|
+
line: index + 1,
|
|
125
|
+
column: columnOf(lineText, name),
|
|
126
|
+
snippet: lineText.trim()
|
|
127
|
+
};
|
|
128
|
+
existing.enabledLines.push(index + 1);
|
|
129
|
+
selectors.set(name, existing);
|
|
130
|
+
});
|
|
131
|
+
return [...selectors.values()];
|
|
132
|
+
}
|
|
133
|
+
function extractGates(filePath, rawSource) {
|
|
134
|
+
const gates = [];
|
|
135
|
+
const regex = /create_gate\s*\(/g;
|
|
136
|
+
for (const match of rawSource.matchAll(regex)) {
|
|
137
|
+
const start = match.index ?? 0;
|
|
138
|
+
const block = findBalancedBlock(rawSource, start);
|
|
139
|
+
if (!block)
|
|
140
|
+
continue;
|
|
141
|
+
const prefix = rawSource.slice(start, rawSource.indexOf("{", start));
|
|
142
|
+
const name = extractGateName(prefix);
|
|
143
|
+
const queries = extractQueries(filePath, block.text, name, block.startLine - 1);
|
|
144
|
+
const parsedExpression = parseHalo2GateExpression(block.text);
|
|
145
|
+
gates.push({
|
|
146
|
+
name,
|
|
147
|
+
body: block.text,
|
|
148
|
+
queries,
|
|
149
|
+
selectors: queries.filter((query) => query.queryType === "selector").map((query) => query.columnName),
|
|
150
|
+
expressions: block.text.split(/\r?\n/).map((line) => line.trim()).filter(Boolean),
|
|
151
|
+
returnedExpressions: parsedExpression.returnedExpressions,
|
|
152
|
+
variableReferences: parsedExpression.variableReferences,
|
|
153
|
+
selectorAliases: parsedExpression.selectorAliases,
|
|
154
|
+
adviceAliases: parsedExpression.adviceAliases,
|
|
155
|
+
instanceAliases: parsedExpression.instanceAliases,
|
|
156
|
+
fixedAliases: parsedExpression.fixedAliases,
|
|
157
|
+
file: filePath,
|
|
158
|
+
line: block.startLine,
|
|
159
|
+
column: 1,
|
|
160
|
+
snippet: block.snippet
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
return gates;
|
|
164
|
+
}
|
|
165
|
+
function extractAssignments(filePath, rawSource) {
|
|
166
|
+
const assignments = [];
|
|
167
|
+
rawSource.split(/\r?\n/).forEach((lineText, index) => {
|
|
168
|
+
const match = lineText.match(/\b(assign_advice|assign_fixed)\s*\((.*)/);
|
|
169
|
+
if (!match)
|
|
170
|
+
return;
|
|
171
|
+
const label = lineText.match(/\|\|\s*"([^"]+)"/)?.[1];
|
|
172
|
+
const args = lineText.split(",");
|
|
173
|
+
const columnName = args.find((arg) => /config\.|\.advice|\.fixed|[A-Za-z_][A-Za-z0-9_]*\./.test(arg))?.trim();
|
|
174
|
+
const rowOffset = args.find((arg) => /^\s*\d+\s*$/.test(arg))?.trim();
|
|
175
|
+
const cellVariable = lineText.match(/(?:let\s+)?([A-Za-z_][A-Za-z0-9_]*)\s*=\s*.*assign_(?:advice|fixed)/)?.[1];
|
|
176
|
+
assignments.push({
|
|
177
|
+
assignmentType: match[1] === "assign_advice" ? "advice" : "fixed",
|
|
178
|
+
target: columnName,
|
|
179
|
+
columnName,
|
|
180
|
+
label,
|
|
181
|
+
rowOffset,
|
|
182
|
+
cellVariable,
|
|
183
|
+
assignedVariable: lineText.match(/Value::known\s*\(([^)]+)\)/)?.[1]?.trim(),
|
|
184
|
+
expression: lineText.trim(),
|
|
185
|
+
referencedSymbols: extractRustSymbols(lineText),
|
|
186
|
+
file: filePath,
|
|
187
|
+
line: index + 1,
|
|
188
|
+
column: columnOf(lineText, match[1] ?? "assign"),
|
|
189
|
+
snippet: lineText.trim()
|
|
190
|
+
});
|
|
191
|
+
});
|
|
192
|
+
return assignments;
|
|
193
|
+
}
|
|
194
|
+
function extractCopyConstraints(filePath, rawSource) {
|
|
195
|
+
return rawSource
|
|
196
|
+
.split(/\r?\n/)
|
|
197
|
+
.map((lineText, index) => ({ lineText, index }))
|
|
198
|
+
.filter(({ lineText }) => /\.copy_advice\s*\(/.test(lineText))
|
|
199
|
+
.map(({ lineText, index }) => ({
|
|
200
|
+
source: lineText.match(/([A-Za-z_][A-Za-z0-9_.]*)\.copy_advice/)?.[1] ?? "unknown",
|
|
201
|
+
targetColumn: lineText.split(",").find((part) => /config\.|\.advice|\.fixed|\.instance/.test(part))?.trim(),
|
|
202
|
+
targetOffset: lineText.split(",").find((part) => /^\s*\d+\s*\)/.test(part))?.replace(/\D/g, ""),
|
|
203
|
+
referencedSymbols: extractRustSymbols(lineText),
|
|
204
|
+
file: filePath,
|
|
205
|
+
line: index + 1,
|
|
206
|
+
column: columnOf(lineText, "copy_advice"),
|
|
207
|
+
snippet: lineText.trim()
|
|
208
|
+
}));
|
|
209
|
+
}
|
|
210
|
+
function extractConstraints(filePath, rawSource) {
|
|
211
|
+
const equalityConstraints = [];
|
|
212
|
+
const instanceConstraints = [];
|
|
213
|
+
rawSource.split(/\r?\n/).forEach((lineText, index) => {
|
|
214
|
+
const equal = lineText.match(/\bconstrain_equal\s*\(([^,]+),\s*([^)]+)\)/);
|
|
215
|
+
if (equal) {
|
|
216
|
+
equalityConstraints.push({
|
|
217
|
+
lhs: (equal[1] ?? "").trim(),
|
|
218
|
+
rhs: (equal[2] ?? "").trim(),
|
|
219
|
+
referencedColumns: extractRustSymbols(lineText),
|
|
220
|
+
file: filePath,
|
|
221
|
+
line: index + 1,
|
|
222
|
+
column: columnOf(lineText, "constrain_equal"),
|
|
223
|
+
snippet: lineText.trim()
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
const instance = lineText.match(/\bconstrain_instance\s*\(([^,]+),\s*([^,]+),\s*([^)]+)\)/);
|
|
227
|
+
if (instance) {
|
|
228
|
+
instanceConstraints.push({
|
|
229
|
+
cell: (instance[1] ?? "").trim(),
|
|
230
|
+
instanceColumn: (instance[2] ?? "").trim(),
|
|
231
|
+
row: (instance[3] ?? "").trim(),
|
|
232
|
+
file: filePath,
|
|
233
|
+
line: index + 1,
|
|
234
|
+
column: columnOf(lineText, "constrain_instance"),
|
|
235
|
+
snippet: lineText.trim()
|
|
236
|
+
});
|
|
237
|
+
}
|
|
238
|
+
});
|
|
239
|
+
return { equalityConstraints, instanceConstraints };
|
|
240
|
+
}
|
|
241
|
+
function extractLookups(filePath, rawSource) {
|
|
242
|
+
return rawSource
|
|
243
|
+
.split(/\r?\n/)
|
|
244
|
+
.map((lineText, index) => ({ lineText, index }))
|
|
245
|
+
.filter(({ lineText }) => /\.lookup\b|create_lookup|lookup_any|lookup_table_column/.test(lineText))
|
|
246
|
+
.map(({ lineText, index }) => ({
|
|
247
|
+
expression: lineText.trim(),
|
|
248
|
+
referencedSymbols: extractRustSymbols(lineText),
|
|
249
|
+
file: filePath,
|
|
250
|
+
line: index + 1,
|
|
251
|
+
column: columnOf(lineText, "lookup"),
|
|
252
|
+
snippet: lineText.trim()
|
|
253
|
+
}));
|
|
254
|
+
}
|
|
255
|
+
function extractRegions(filePath, rawSource, assignments, equalityConstraints, instanceConstraints, copyConstraints) {
|
|
256
|
+
const regions = [];
|
|
257
|
+
const regex = /assign_region\s*\(\s*\|\|\s*"([^"]+)"/g;
|
|
258
|
+
for (const match of rawSource.matchAll(regex)) {
|
|
259
|
+
const start = match.index ?? 0;
|
|
260
|
+
const block = findBalancedBlock(rawSource, start);
|
|
261
|
+
const line = lineNumberAt(rawSource, start);
|
|
262
|
+
const endLine = block?.endLine ?? line;
|
|
263
|
+
regions.push({
|
|
264
|
+
name: match[1] ?? "region",
|
|
265
|
+
assignments: assignments.filter((assignment) => assignment.line >= line && assignment.line <= endLine),
|
|
266
|
+
selectorEnables: (block?.text.match(/([A-Za-z_][A-Za-z0-9_.]*)\.enable\s*\(/g) ?? []).map((value) => value.split(".").at(-2) ?? value),
|
|
267
|
+
copyAdvice: copyConstraints.filter((constraint) => constraint.line >= line && constraint.line <= endLine),
|
|
268
|
+
equalityConstraints: equalityConstraints.filter((constraint) => constraint.line >= line && constraint.line <= endLine),
|
|
269
|
+
instanceConstraints: instanceConstraints.filter((constraint) => constraint.line >= line && constraint.line <= endLine),
|
|
270
|
+
file: filePath,
|
|
271
|
+
line,
|
|
272
|
+
column: 1,
|
|
273
|
+
snippet: getLine(rawSource, line).trim()
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
return regions;
|
|
277
|
+
}
|
|
278
|
+
export function parseHalo2File(filePath, rawSource) {
|
|
279
|
+
const parserWarnings = [];
|
|
280
|
+
const detectedPatterns = halo2DetectionPatterns.filter((pattern) => rawSource.includes(pattern));
|
|
281
|
+
if (!isLikelyHalo2Source(rawSource)) {
|
|
282
|
+
parserWarnings.push({
|
|
283
|
+
message: "Rust file does not contain known Halo2 patterns; parsed with low confidence.",
|
|
284
|
+
file: filePath,
|
|
285
|
+
line: 1,
|
|
286
|
+
column: 1,
|
|
287
|
+
snippet: getLine(rawSource, 1)
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
const gates = extractGates(filePath, rawSource);
|
|
291
|
+
const queries = [...extractQueries(filePath, rawSource), ...gates.flatMap((gate) => gate.queries)];
|
|
292
|
+
const columns = extractColumns(filePath, rawSource);
|
|
293
|
+
const assignments = extractAssignments(filePath, rawSource);
|
|
294
|
+
const { equalityConstraints, instanceConstraints } = extractConstraints(filePath, rawSource);
|
|
295
|
+
const copyConstraints = extractCopyConstraints(filePath, rawSource);
|
|
296
|
+
const lookups = extractLookups(filePath, rawSource);
|
|
297
|
+
const regions = extractRegions(filePath, rawSource, assignments, equalityConstraints, instanceConstraints, copyConstraints);
|
|
298
|
+
const selectors = extractSelectors(filePath, rawSource, gates);
|
|
299
|
+
return {
|
|
300
|
+
filePath,
|
|
301
|
+
rawSource,
|
|
302
|
+
columns,
|
|
303
|
+
selectors,
|
|
304
|
+
gates,
|
|
305
|
+
queries,
|
|
306
|
+
assignments,
|
|
307
|
+
equalityConstraints,
|
|
308
|
+
instanceConstraints,
|
|
309
|
+
lookups,
|
|
310
|
+
regions,
|
|
311
|
+
copyConstraints,
|
|
312
|
+
parserWarnings,
|
|
313
|
+
detectedPatterns
|
|
314
|
+
};
|
|
315
|
+
}
|
|
316
|
+
//# sourceMappingURL=halo2-parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"halo2-parser.js","sourceRoot":"","sources":["../../../src/frontends/halo2/halo2-parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare const halo2DetectionPatterns: string[];
|
|
2
|
+
export declare const halo2DetectionRegex: RegExp;
|
|
3
|
+
export declare function isLikelyHalo2Source(source: string): boolean;
|
|
4
|
+
export declare function extractRustSymbols(expression: string): string[];
|
|
5
|
+
export declare function isHashOrSafeInverseContext(snippet: string): boolean;
|
|
6
|
+
export declare function isEcLikeName(value: string): boolean;
|