-
Notifications
You must be signed in to change notification settings - Fork 7
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
refactor: use type schemes in extension definitions wherever possible #678
Changes from 14 commits
fffb696
4ec9c75
7eb7bc8
3f3e5ea
8be903e
f5f994b
6355fa2
76b1995
1508ead
09dbb1b
3ddd6ab
c068c40
aeb7ef6
d93d5e6
b5159e9
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -331,6 +331,23 @@ impl Extension { | |
SignatureFunc::TypeScheme(type_scheme), | ||
) | ||
} | ||
|
||
/// Create an OpDef with a signature (inputs+outputs) read from e.g. | ||
/// declarative YAML; and no "misc" or "lowering functions" defined. | ||
pub fn add_op_type_scheme_simple( | ||
&mut self, | ||
name: SmolStr, | ||
description: String, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hmmm, how about There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. All the other methods take String so I think I'd rather leave that for a |
||
type_scheme: PolyFuncType, | ||
) -> Result<&OpDef, ExtensionBuildError> { | ||
self.add_op( | ||
name, | ||
description, | ||
Default::default(), | ||
vec![], | ||
SignatureFunc::TypeScheme(type_scheme), | ||
) | ||
} | ||
} | ||
|
||
#[cfg(test)] | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,9 @@ | ||
//! Basic floating-point operations. | ||
|
||
use crate::{ | ||
extension::{ExtensionId, ExtensionSet, SignatureError}, | ||
extension::{ExtensionId, ExtensionSet}, | ||
type_row, | ||
types::{type_param::TypeArg, FunctionType}, | ||
types::{FunctionType, PolyFuncType}, | ||
Extension, | ||
}; | ||
|
||
|
@@ -12,25 +12,20 @@ use super::float_types::FLOAT64_TYPE; | |
/// The extension identifier. | ||
pub const EXTENSION_ID: ExtensionId = ExtensionId::new_unchecked("arithmetic.float"); | ||
|
||
fn fcmp_sig(_arg_values: &[TypeArg]) -> Result<FunctionType, SignatureError> { | ||
Ok(FunctionType::new( | ||
fn fcmp_sig() -> PolyFuncType { | ||
FunctionType::new( | ||
type_row![FLOAT64_TYPE; 2], | ||
type_row![crate::extension::prelude::BOOL_T], | ||
)) | ||
) | ||
.into() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hah. Yes, it doesn't make much sense that you need to |
||
} | ||
|
||
fn fbinop_sig(_arg_values: &[TypeArg]) -> Result<FunctionType, SignatureError> { | ||
Ok(FunctionType::new( | ||
type_row![FLOAT64_TYPE; 2], | ||
type_row![FLOAT64_TYPE], | ||
)) | ||
fn fbinop_sig() -> PolyFuncType { | ||
FunctionType::new(type_row![FLOAT64_TYPE; 2], type_row![FLOAT64_TYPE]).into() | ||
} | ||
|
||
fn funop_sig(_arg_values: &[TypeArg]) -> Result<FunctionType, SignatureError> { | ||
Ok(FunctionType::new( | ||
type_row![FLOAT64_TYPE], | ||
type_row![FLOAT64_TYPE], | ||
)) | ||
fn funop_sig() -> PolyFuncType { | ||
FunctionType::new(type_row![FLOAT64_TYPE], type_row![FLOAT64_TYPE]).into() | ||
} | ||
|
||
/// Extension for basic arithmetic operations. | ||
|
@@ -40,78 +35,76 @@ pub fn extension() -> Extension { | |
ExtensionSet::singleton(&super::float_types::EXTENSION_ID), | ||
); | ||
|
||
let fcmp_sig = fcmp_sig(); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. You could just inline the functions here, these are the only callsites |
||
let fbinop_sig = fbinop_sig(); | ||
let funop_sig = funop_sig(); | ||
extension | ||
.add_op_custom_sig_simple("feq".into(), "equality test".to_owned(), vec![], fcmp_sig) | ||
.add_op_type_scheme_simple("feq".into(), "equality test".to_owned(), fcmp_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("fne".into(), "inequality test".to_owned(), vec![], fcmp_sig) | ||
.add_op_type_scheme_simple("fne".into(), "inequality test".to_owned(), fcmp_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("flt".into(), "\"less than\"".to_owned(), vec![], fcmp_sig) | ||
.add_op_type_scheme_simple("flt".into(), "\"less than\"".to_owned(), fcmp_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple( | ||
.add_op_type_scheme_simple( | ||
"fgt".into(), | ||
"\"greater than\"".to_owned(), | ||
vec![], | ||
fcmp_sig, | ||
fcmp_sig.clone(), | ||
) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple( | ||
.add_op_type_scheme_simple( | ||
"fle".into(), | ||
"\"less than or equal\"".to_owned(), | ||
vec![], | ||
fcmp_sig, | ||
fcmp_sig.clone(), | ||
) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple( | ||
.add_op_type_scheme_simple( | ||
"fge".into(), | ||
"\"greater than or equal\"".to_owned(), | ||
vec![], | ||
fcmp_sig, | ||
) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("fmax".into(), "maximum".to_owned(), vec![], fbinop_sig) | ||
.add_op_type_scheme_simple("fmax".into(), "maximum".to_owned(), fbinop_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("fmin".into(), "minimum".to_owned(), vec![], fbinop_sig) | ||
.add_op_type_scheme_simple("fmin".into(), "minimum".to_owned(), fbinop_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("fadd".into(), "addition".to_owned(), vec![], fbinop_sig) | ||
.add_op_type_scheme_simple("fadd".into(), "addition".to_owned(), fbinop_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("fsub".into(), "subtraction".to_owned(), vec![], fbinop_sig) | ||
.add_op_type_scheme_simple("fsub".into(), "subtraction".to_owned(), fbinop_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("fneg".into(), "negation".to_owned(), vec![], funop_sig) | ||
.add_op_type_scheme_simple("fneg".into(), "negation".to_owned(), funop_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple( | ||
.add_op_type_scheme_simple( | ||
"fabs".into(), | ||
"absolute value".to_owned(), | ||
vec![], | ||
funop_sig, | ||
funop_sig.clone(), | ||
) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple( | ||
.add_op_type_scheme_simple( | ||
"fmul".into(), | ||
"multiplication".to_owned(), | ||
vec![], | ||
fbinop_sig, | ||
fbinop_sig.clone(), | ||
) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("fdiv".into(), "division".to_owned(), vec![], fbinop_sig) | ||
.add_op_type_scheme_simple("fdiv".into(), "division".to_owned(), fbinop_sig) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("ffloor".into(), "floor".to_owned(), vec![], funop_sig) | ||
.add_op_type_scheme_simple("ffloor".into(), "floor".to_owned(), funop_sig.clone()) | ||
.unwrap(); | ||
extension | ||
.add_op_custom_sig_simple("fceil".into(), "ceiling".to_owned(), vec![], funop_sig) | ||
.add_op_type_scheme_simple("fceil".into(), "ceiling".to_owned(), funop_sig) | ||
.unwrap(); | ||
|
||
extension | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -100,6 +100,11 @@ mod test { | |
fn test_float_consts() { | ||
let const_f64_1 = ConstF64::new(1.0); | ||
let const_f64_2 = ConstF64::new(2.0); | ||
|
||
assert_eq!(const_f64_1.value(), 1.0); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is unrelated extra test coverage - doesn't need your custom consts PR or anything? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. no, the commits are separate so i could cherry pick them, but its "related" in the sense that the changes in this PR highlight the remaining missing coverage better |
||
assert_eq!(*const_f64_2, 2.0); | ||
assert_eq!(const_f64_1.name(), "f64(1)"); | ||
assert!(const_f64_1.equal_consts(&ConstF64::new(1.0))); | ||
assert_ne!(const_f64_1, const_f64_2); | ||
assert_eq!(const_f64_1, ConstF64::new(1.0)); | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍