mirror of
https://github.com/AleoHQ/leo.git
synced 2024-12-01 18:56:38 +03:00
refactor leo core modules
This commit is contained in:
parent
97f24ae1f1
commit
20fbf96784
18
core/src/circuits/mod.rs
Normal file
18
core/src/circuits/mod.rs
Normal file
@ -0,0 +1,18 @@
|
||||
// Copyright (C) 2019-2020 Aleo Systems Inc.
|
||||
// This file is part of the Leo library.
|
||||
|
||||
// The Leo library is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
|
||||
// The Leo library is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
pub mod unstable;
|
||||
pub use self::unstable::*;
|
0
core/src/errors/core_package.rs
Normal file
0
core/src/errors/core_package.rs
Normal file
208
core/src/lib.rs
208
core/src/lib.rs
@ -14,199 +14,29 @@
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
pub mod core_circuit;
|
||||
pub use self::core_circuit::*;
|
||||
pub mod circuits;
|
||||
pub use self::circuits::*;
|
||||
|
||||
pub mod errors;
|
||||
pub use self::errors::*;
|
||||
|
||||
pub mod unstable;
|
||||
pub use self::unstable::*;
|
||||
|
||||
use crate::{unstable::blake2s::Blake2sFunction, CoreCircuit};
|
||||
use leo_gadgets::signed_integer::*;
|
||||
use leo_typed::{Circuit, Identifier, ImportSymbol, Package, PackageAccess, Span};
|
||||
pub mod types;
|
||||
pub use self::types::*;
|
||||
|
||||
use crate::CoreCircuit;
|
||||
use leo_typed::Span;
|
||||
use snarkos_models::{
|
||||
curves::{Field, PrimeField},
|
||||
gadgets::{
|
||||
r1cs::ConstraintSystem,
|
||||
utilities::{
|
||||
boolean::Boolean,
|
||||
uint::{UInt128, UInt16, UInt32, UInt64, UInt8},
|
||||
},
|
||||
},
|
||||
gadgets::r1cs::ConstraintSystem,
|
||||
};
|
||||
|
||||
static UNSTABLE_CORE_PACKAGE_KEYWORD: &str = "unstable";
|
||||
|
||||
/// A core package dependency to be imported into a Leo program
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct CorePackage {
|
||||
name: Identifier,
|
||||
unstable: bool,
|
||||
symbols: Vec<ImportSymbol>,
|
||||
}
|
||||
|
||||
impl CorePackage {
|
||||
pub(crate) fn new(name: Identifier) -> Self {
|
||||
Self {
|
||||
name,
|
||||
unstable: false,
|
||||
symbols: vec![],
|
||||
}
|
||||
}
|
||||
|
||||
// Set the `unstable` flag to true if we are importing an unstable core package
|
||||
pub(crate) fn set_unstable(&mut self) {
|
||||
self.unstable = true;
|
||||
}
|
||||
|
||||
// Recursively set all symbols we are importing from a core package
|
||||
pub(crate) fn set_symbols(&mut self, access: PackageAccess) {
|
||||
match access {
|
||||
PackageAccess::SubPackage(package) => {
|
||||
self.set_symbols(package.access);
|
||||
}
|
||||
PackageAccess::Star(_) => unimplemented!("cannot import star from core package"),
|
||||
PackageAccess::Multiple(accesses) => {
|
||||
for access in accesses {
|
||||
self.set_symbols(access);
|
||||
}
|
||||
}
|
||||
PackageAccess::Symbol(symbol) => self.symbols.push(symbol),
|
||||
}
|
||||
}
|
||||
|
||||
// Resolve import symbols into core circuits and store them in the program context
|
||||
pub(crate) fn append_symbols(&self, symbols: &mut CoreSymbolList) {
|
||||
for symbol in &self.symbols {
|
||||
let symbol_name = symbol.symbol.name.as_str();
|
||||
let span = symbol.span.clone();
|
||||
|
||||
// take the alias if it is present
|
||||
let id = symbol.alias.clone().unwrap_or(symbol.symbol.clone());
|
||||
let name = id.name.clone();
|
||||
|
||||
let circuit = if self.unstable {
|
||||
// match unstable core circuit
|
||||
match symbol_name {
|
||||
CORE_UNSTABLE_BLAKE2S_NAME => Blake2sFunction::ast(symbol.symbol.clone(), span),
|
||||
_ => unimplemented!("unstable core circuit `{}` not implemented", symbol_name),
|
||||
}
|
||||
} else {
|
||||
// match core circuit
|
||||
match symbol_name {
|
||||
_ => unimplemented!("core circuit `{}` not implemented", symbol_name),
|
||||
}
|
||||
};
|
||||
|
||||
symbols.push(name, circuit)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Package> for CorePackage {
|
||||
fn from(package: Package) -> Self {
|
||||
// Create new core package
|
||||
let mut core_package = Self::new(package.name);
|
||||
|
||||
// Fetch all circuit symbols imported from core package
|
||||
core_package.set_symbols(package.access);
|
||||
|
||||
core_package
|
||||
}
|
||||
}
|
||||
|
||||
/// A list of core package dependencies
|
||||
#[derive(Debug)]
|
||||
pub struct CorePackageList {
|
||||
packages: Vec<CorePackage>,
|
||||
}
|
||||
|
||||
impl CorePackageList {
|
||||
pub(crate) fn new() -> Self {
|
||||
Self { packages: vec![] }
|
||||
}
|
||||
|
||||
pub(crate) fn push(&mut self, package: CorePackage) {
|
||||
self.packages.push(package);
|
||||
}
|
||||
|
||||
// Return a list of all symbols that need to be stored in the current function
|
||||
pub fn to_symbols(&self) -> CoreSymbolList {
|
||||
let mut symbols = CoreSymbolList::new();
|
||||
|
||||
for package in &self.packages {
|
||||
package.append_symbols(&mut symbols);
|
||||
}
|
||||
|
||||
symbols
|
||||
}
|
||||
|
||||
// Parse all dependencies after `core.`
|
||||
pub fn from_package_access(access: PackageAccess) -> Self {
|
||||
let mut new = Self::new();
|
||||
|
||||
package_access_helper(&mut new, access, false);
|
||||
|
||||
new
|
||||
}
|
||||
}
|
||||
|
||||
fn package_access_helper(list: &mut CorePackageList, access: PackageAccess, is_unstable: bool) {
|
||||
match access {
|
||||
PackageAccess::Symbol(_symbol) => unimplemented!("cannot import a symbol directly from Leo core"),
|
||||
PackageAccess::Multiple(core_functions) => {
|
||||
for access in core_functions {
|
||||
package_access_helper(list, access, is_unstable);
|
||||
}
|
||||
}
|
||||
PackageAccess::SubPackage(package) => {
|
||||
// Set the `unstable` flag to true if we are importing an unstable core package
|
||||
if package.name.name.eq(UNSTABLE_CORE_PACKAGE_KEYWORD) {
|
||||
package_access_helper(list, package.access, true);
|
||||
} else {
|
||||
let mut core_package = CorePackage::from(*package);
|
||||
|
||||
if is_unstable {
|
||||
core_package.set_unstable()
|
||||
}
|
||||
|
||||
list.push(core_package);
|
||||
}
|
||||
}
|
||||
PackageAccess::Star(_) => unimplemented!("cannot import star from Leo core"),
|
||||
}
|
||||
}
|
||||
|
||||
/// List of imported core function circuits
|
||||
pub struct CoreSymbolList {
|
||||
/// [(circuit_name, circuit_struct)]
|
||||
symbols: Vec<(String, Circuit)>,
|
||||
}
|
||||
|
||||
impl CoreSymbolList {
|
||||
pub(crate) fn new() -> Self {
|
||||
Self { symbols: vec![] }
|
||||
}
|
||||
|
||||
pub(crate) fn push(&mut self, name: String, circuit: Circuit) {
|
||||
self.symbols.push((name, circuit))
|
||||
}
|
||||
|
||||
pub fn symbols(&self) -> Vec<(String, Circuit)> {
|
||||
self.symbols.clone()
|
||||
}
|
||||
}
|
||||
|
||||
/// Calls a core function by it's given name.
|
||||
/// This function should be called by the compiler when enforcing the result of calling a core circuit function.
|
||||
pub fn call_core_function<F: Field + PrimeField, CS: ConstraintSystem<F>>(
|
||||
cs: CS,
|
||||
function_name: String,
|
||||
arguments: Vec<Value>,
|
||||
span: Span, // todo: return errors using `leo-typed` span
|
||||
span: Span, // TODO(collinc97): return errors using `leo-typed` span
|
||||
) -> Vec<Value> {
|
||||
// Match core function name
|
||||
match function_name.as_str() {
|
||||
@ -214,25 +44,3 @@ pub fn call_core_function<F: Field + PrimeField, CS: ConstraintSystem<F>>(
|
||||
_ => unimplemented!("core function {} unimplemented", function_name),
|
||||
}
|
||||
}
|
||||
|
||||
/// An intermediate value format that can be converted into a `ConstrainedValue` for the compiler
|
||||
/// Todo: implement other constrained values
|
||||
#[derive(Clone)]
|
||||
pub enum Value {
|
||||
Boolean(Boolean),
|
||||
|
||||
U8(UInt8),
|
||||
U16(UInt16),
|
||||
U32(UInt32),
|
||||
U64(UInt64),
|
||||
U128(UInt128),
|
||||
|
||||
I8(Int8),
|
||||
I16(Int16),
|
||||
I32(Int32),
|
||||
I64(Int64),
|
||||
I128(Int128),
|
||||
|
||||
Array(Vec<Value>),
|
||||
Tuple(Vec<Value>),
|
||||
}
|
||||
|
100
core/src/types/core_package.rs
Normal file
100
core/src/types/core_package.rs
Normal file
@ -0,0 +1,100 @@
|
||||
// Copyright (C) 2019-2020 Aleo Systems Inc.
|
||||
// This file is part of the Leo library.
|
||||
|
||||
// The Leo library is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
|
||||
// The Leo library is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
use crate::{
|
||||
unstable::blake2s::{Blake2sFunction, CORE_UNSTABLE_BLAKE2S_NAME},
|
||||
CoreCircuit,
|
||||
CoreSymbolList,
|
||||
};
|
||||
use leo_typed::{Identifier, ImportSymbol, Package, PackageAccess};
|
||||
|
||||
/// A core package dependency to be imported into a Leo program
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct CorePackage {
|
||||
name: Identifier,
|
||||
unstable: bool,
|
||||
symbols: Vec<ImportSymbol>,
|
||||
}
|
||||
|
||||
impl CorePackage {
|
||||
pub(crate) fn new(name: Identifier) -> Self {
|
||||
Self {
|
||||
name,
|
||||
unstable: false,
|
||||
symbols: vec![],
|
||||
}
|
||||
}
|
||||
|
||||
// Set the `unstable` flag to true if we are importing an unstable core package
|
||||
pub(crate) fn set_unstable(&mut self) {
|
||||
self.unstable = true;
|
||||
}
|
||||
|
||||
// Recursively set all symbols we are importing from a core package
|
||||
pub(crate) fn set_symbols(&mut self, access: PackageAccess) {
|
||||
match access {
|
||||
PackageAccess::SubPackage(package) => {
|
||||
self.set_symbols(package.access);
|
||||
}
|
||||
PackageAccess::Star(_) => unimplemented!("cannot import star from core package"),
|
||||
PackageAccess::Multiple(accesses) => {
|
||||
for access in accesses {
|
||||
self.set_symbols(access);
|
||||
}
|
||||
}
|
||||
PackageAccess::Symbol(symbol) => self.symbols.push(symbol),
|
||||
}
|
||||
}
|
||||
|
||||
// Resolve import symbols into core circuits and store them in the program context
|
||||
pub(crate) fn append_symbols(&self, symbols: &mut CoreSymbolList) {
|
||||
for symbol in &self.symbols {
|
||||
let symbol_name = symbol.symbol.name.as_str();
|
||||
let span = symbol.span.clone();
|
||||
|
||||
// take the alias if it is present
|
||||
let id = symbol.alias.clone().unwrap_or(symbol.symbol.clone());
|
||||
let name = id.name.clone();
|
||||
|
||||
let circuit = if self.unstable {
|
||||
// match unstable core circuit
|
||||
match symbol_name {
|
||||
CORE_UNSTABLE_BLAKE2S_NAME => Blake2sFunction::ast(symbol.symbol.clone(), span),
|
||||
_ => unimplemented!("unstable core circuit `{}` not implemented", symbol_name),
|
||||
}
|
||||
} else {
|
||||
// match core circuit
|
||||
match symbol_name {
|
||||
_ => unimplemented!("core circuit `{}` not implemented", symbol_name),
|
||||
}
|
||||
};
|
||||
|
||||
symbols.push(name, circuit)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Package> for CorePackage {
|
||||
fn from(package: Package) -> Self {
|
||||
// Create new core package
|
||||
let mut core_package = Self::new(package.name);
|
||||
|
||||
// Fetch all circuit symbols imported from core package
|
||||
core_package.set_symbols(package.access);
|
||||
|
||||
core_package
|
||||
}
|
||||
}
|
81
core/src/types/core_package_list.rs
Normal file
81
core/src/types/core_package_list.rs
Normal file
@ -0,0 +1,81 @@
|
||||
// Copyright (C) 2019-2020 Aleo Systems Inc.
|
||||
// This file is part of the Leo library.
|
||||
|
||||
// The Leo library is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
|
||||
// The Leo library is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
use crate::{CorePackage, CoreSymbolList, UNSTABLE_CORE_PACKAGE_KEYWORD};
|
||||
use leo_typed::PackageAccess;
|
||||
|
||||
/// A list of core package dependencies.
|
||||
/// This struct is created when the compiler parses a core import statement.
|
||||
#[derive(Debug)]
|
||||
pub struct CorePackageList {
|
||||
packages: Vec<CorePackage>,
|
||||
}
|
||||
|
||||
impl CorePackageList {
|
||||
pub(crate) fn new() -> Self {
|
||||
Self { packages: vec![] }
|
||||
}
|
||||
|
||||
pub(crate) fn push(&mut self, package: CorePackage) {
|
||||
self.packages.push(package);
|
||||
}
|
||||
|
||||
// Parse all dependencies after `core.`
|
||||
pub fn from_package_access(access: PackageAccess) -> Self {
|
||||
let mut new = Self::new();
|
||||
|
||||
package_access_helper(&mut new, access, false);
|
||||
|
||||
new
|
||||
}
|
||||
|
||||
// Return a list of all symbols that need to be stored in the current function
|
||||
pub fn to_symbols(&self) -> CoreSymbolList {
|
||||
let mut symbols = CoreSymbolList::new();
|
||||
|
||||
for package in &self.packages {
|
||||
package.append_symbols(&mut symbols);
|
||||
}
|
||||
|
||||
symbols
|
||||
}
|
||||
}
|
||||
|
||||
fn package_access_helper(list: &mut CorePackageList, access: PackageAccess, is_unstable: bool) {
|
||||
match access {
|
||||
PackageAccess::Symbol(_symbol) => unimplemented!("cannot import a symbol directly from Leo core"),
|
||||
PackageAccess::Multiple(core_functions) => {
|
||||
for access in core_functions {
|
||||
package_access_helper(list, access, is_unstable);
|
||||
}
|
||||
}
|
||||
PackageAccess::SubPackage(package) => {
|
||||
// Set the `unstable` flag to true if we are importing an unstable core package
|
||||
if package.name.name.eq(UNSTABLE_CORE_PACKAGE_KEYWORD) {
|
||||
package_access_helper(list, package.access, true);
|
||||
} else {
|
||||
let mut core_package = CorePackage::from(*package);
|
||||
|
||||
if is_unstable {
|
||||
core_package.set_unstable()
|
||||
}
|
||||
|
||||
list.push(core_package);
|
||||
}
|
||||
}
|
||||
PackageAccess::Star(_) => unimplemented!("cannot import star from Leo core"),
|
||||
}
|
||||
}
|
38
core/src/types/core_symbol_list.rs
Normal file
38
core/src/types/core_symbol_list.rs
Normal file
@ -0,0 +1,38 @@
|
||||
// Copyright (C) 2019-2020 Aleo Systems Inc.
|
||||
// This file is part of the Leo library.
|
||||
|
||||
// The Leo library is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
|
||||
// The Leo library is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
use leo_typed::Circuit;
|
||||
|
||||
/// List of imported core function circuits.
|
||||
/// This struct is created from a `CorePackageList`
|
||||
pub struct CoreSymbolList {
|
||||
/// [(circuit_name, circuit_struct)]
|
||||
symbols: Vec<(String, Circuit)>,
|
||||
}
|
||||
|
||||
impl CoreSymbolList {
|
||||
pub(crate) fn new() -> Self {
|
||||
Self { symbols: vec![] }
|
||||
}
|
||||
|
||||
pub(crate) fn push(&mut self, name: String, circuit: Circuit) {
|
||||
self.symbols.push((name, circuit))
|
||||
}
|
||||
|
||||
pub fn symbols(&self) -> Vec<(String, Circuit)> {
|
||||
self.symbols.clone()
|
||||
}
|
||||
}
|
32
core/src/types/mod.rs
Normal file
32
core/src/types/mod.rs
Normal file
@ -0,0 +1,32 @@
|
||||
// Copyright (C) 2019-2020 Aleo Systems Inc.
|
||||
// This file is part of the Leo library.
|
||||
|
||||
// The Leo library is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
|
||||
// The Leo library is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
pub mod core_circuit;
|
||||
pub use self::core_circuit::*;
|
||||
|
||||
pub mod core_package;
|
||||
pub use self::core_package::*;
|
||||
|
||||
pub mod core_package_list;
|
||||
pub use self::core_package_list::*;
|
||||
|
||||
pub mod core_symbol_list;
|
||||
pub use self::core_symbol_list::*;
|
||||
|
||||
pub mod value;
|
||||
pub use self::value::*;
|
||||
|
||||
pub static UNSTABLE_CORE_PACKAGE_KEYWORD: &str = "unstable";
|
40
core/src/types/value.rs
Normal file
40
core/src/types/value.rs
Normal file
@ -0,0 +1,40 @@
|
||||
// Copyright (C) 2019-2020 Aleo Systems Inc.
|
||||
// This file is part of the Leo library.
|
||||
|
||||
// The Leo library is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
|
||||
// The Leo library is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
use leo_gadgets::signed_integer::*;
|
||||
use snarkos_models::gadgets::utilities::{boolean::Boolean, uint::*};
|
||||
|
||||
/// An intermediate value format that can be converted into a `ConstrainedValue` for the compiler
|
||||
/// TODO(collinc97): implement other constrained values
|
||||
#[derive(Clone)]
|
||||
pub enum Value {
|
||||
Boolean(Boolean),
|
||||
|
||||
U8(UInt8),
|
||||
U16(UInt16),
|
||||
U32(UInt32),
|
||||
U64(UInt64),
|
||||
U128(UInt128),
|
||||
|
||||
I8(Int8),
|
||||
I16(Int16),
|
||||
I32(Int32),
|
||||
I64(Int64),
|
||||
I128(Int128),
|
||||
|
||||
Array(Vec<Value>),
|
||||
Tuple(Vec<Value>),
|
||||
}
|
Loading…
Reference in New Issue
Block a user