This repository has been archived by the owner on Apr 9, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 16
feat(brillig): implemented first blackbox functions #401
Merged
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
sirasistant
changed the title
feat(brillig): implemented first blackbox functions (WIP)
feat(brillig): implemented first blackbox functions
Jun 22, 2023
kevaundray
reviewed
Jun 22, 2023
kevaundray
reviewed
Jun 22, 2023
TomAFrench
reviewed
Jun 26, 2023
TomAFrench
reviewed
Jun 26, 2023
kevaundray
approved these changes
Jun 26, 2023
Merged
2 tasks
Sign up for free
to subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
Implements the blackbox opcodes and the first black box operations.
Here is a reference implementation of this PR in noir=>brillig noir-lang/noir#1788
Also extracted HeapVector and HeapArray as structs same as RegisterIndex because they are handy for passing data to blackbox operations.
Hashes are implemented with HeapVectors so they are as flexible as possible, since HeapArrays can be casted to HeapVector during compilation by just inssuing a Const opcode.
Problem*
Summary*
Additional Context
PR Checklist*
cargo fmt
on default settings.