-
-
Notifications
You must be signed in to change notification settings - Fork 68
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
Add minimal documentation to in ir
in trustfall_core
#139
Merged
Merged
Changes from 5 commits
Commits
Show all changes
6 commits
Select commit
Hold shift + click to select a range
d135da3
Add minimal documentation to in
ginger51011 464fa9d
Fix rustfmt
ginger51011 bf2ea7b
Update trustfall_core/src/ir/mod.rs
ginger51011 239fd1c
Apply suggestions from code review
ginger51011 b0ae0e5
Fix conflict
ginger51011 d7b1236
Update trustfall_core/src/ir/mod.rs
obi1kenobi File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,4 @@ | ||
//! Trustfall intermediate representation (IR) | ||
#![allow(dead_code)] | ||
|
||
pub mod indexed; | ||
|
@@ -26,17 +27,21 @@ lazy_static! { | |
pub(crate) static ref TYPENAME_META_FIELD_ARC: Arc<str> = Arc::from(TYPENAME_META_FIELD); | ||
} | ||
|
||
/// Vertex ID | ||
#[doc(alias("vertex", "node"))] | ||
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. Very nice! 💯 |
||
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash, PartialOrd, Ord, Serialize, Deserialize)] | ||
pub struct Vid(pub(crate) NonZeroUsize); // vertex ID | ||
pub struct Vid(pub(crate) NonZeroUsize); | ||
|
||
impl Vid { | ||
pub fn new(id: NonZeroUsize) -> Vid { | ||
Vid(id) | ||
} | ||
} | ||
|
||
/// Edge ID | ||
#[doc(alias = "edge")] | ||
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash, PartialOrd, Ord, Serialize, Deserialize)] | ||
pub struct Eid(pub(crate) NonZeroUsize); // edge ID | ||
pub struct Eid(pub(crate) NonZeroUsize); | ||
|
||
impl Eid { | ||
pub fn new(id: NonZeroUsize) -> Eid { | ||
|
@@ -49,8 +54,13 @@ pub struct EdgeParameters( | |
#[serde(default, skip_serializing_if = "BTreeMap::is_empty")] pub BTreeMap<Arc<str>, FieldValue>, | ||
); | ||
|
||
/// A complete component of a query; may itself contain one or more components. | ||
/// | ||
/// Contains information about the Vid where the component is rooted, | ||
/// as well as well as maps of all vertices, edges, folds, and outputs from this component. | ||
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)] | ||
pub struct IRQueryComponent { | ||
/// The [Vid] of the root, or entry point, of the component. | ||
pub root: Vid, | ||
|
||
#[serde(default, skip_serializing_if = "BTreeMap::is_empty")] | ||
|
@@ -66,6 +76,7 @@ pub struct IRQueryComponent { | |
pub outputs: BTreeMap<Arc<str>, ContextField>, | ||
} | ||
|
||
/// Intermediate representation of a query | ||
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)] | ||
pub struct IRQuery { | ||
pub root_name: Arc<str>, | ||
|
@@ -94,6 +105,9 @@ pub struct IREdge { | |
#[serde(default, skip_serializing_if = "Option::is_none")] | ||
pub parameters: Option<Arc<EdgeParameters>>, | ||
|
||
/// Indicating if this edge is optional. | ||
/// | ||
/// Corresponds to the `@optional` directive. | ||
#[serde(default = "default_optional", skip_serializing_if = "is_false")] | ||
pub optional: bool, | ||
|
||
|
@@ -123,9 +137,13 @@ impl Recursive { | |
} | ||
} | ||
|
||
/// Representation of a vertex (node) in the Trustfall intermediate | ||
/// representation (IR). | ||
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)] | ||
pub struct IRVertex { | ||
pub vid: Vid, | ||
|
||
/// The name of the type of the vertex as a string. | ||
pub type_name: Arc<str>, | ||
|
||
#[serde(default, skip_serializing_if = "Option::is_none")] | ||
|
@@ -282,6 +300,14 @@ impl Argument { | |
} | ||
} | ||
|
||
/// Operations that can be made in the graph. | ||
/// | ||
/// In a Trustfall query, the `@filter` directive produces `Operation` values: | ||
/// ```graphql | ||
/// name @filter(op: "=", values: ["$input"]) | ||
/// ``` | ||
/// would produce the `Operation::Equals` variant, for example. | ||
/// ``` | ||
obi1kenobi marked this conversation as resolved.
Show resolved
Hide resolved
|
||
#[non_exhaustive] | ||
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)] | ||
pub enum Operation<LeftT, RightT> | ||
|
@@ -365,6 +391,7 @@ where | |
} | ||
} | ||
|
||
/// The operation name, as it would have appeared in the `@filter` directive `op` argument. | ||
pub(crate) fn operation_name(&self) -> &'static str { | ||
match self { | ||
Operation::IsNull(..) => "is_null", | ||
|
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,11 @@ | ||
/// IR of the values of Trustfall fields. | ||
use async_graphql_value::{ConstValue, Number, Value}; | ||
use chrono::{DateTime, Utc}; | ||
use serde::{Deserialize, Serialize}; | ||
|
||
/// Values of fields in Trustfall. | ||
/// | ||
/// For version that is serialized as an untagged enum, see [TransparentValue]. | ||
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. awesome! |
||
#[derive(Debug, Clone, Serialize, Deserialize)] | ||
pub enum FieldValue { | ||
// Order may matter here! Deserialization, if ever configured for untagged serialization, | ||
|
@@ -10,17 +14,21 @@ pub enum FieldValue { | |
// This is because we want to prioritize the standard Integer GraphQL type over our custom u64, | ||
// and prioritize exact integers over lossy floats. | ||
Null, | ||
Int64(i64), // AKA Integer | ||
/// AKA integer | ||
Int64(i64), | ||
Uint64(u64), | ||
Float64(f64), // AKA Float, and also not allowed to be NaN | ||
/// AKA Float, and also not allowed to be NaN | ||
Float64(f64), | ||
String(String), | ||
Boolean(bool), | ||
DateTimeUtc(DateTime<Utc>), | ||
Enum(String), | ||
List(Vec<FieldValue>), | ||
} | ||
|
||
/// Same as FieldValue, but serialized as an untagged enum, | ||
/// Values of fields in GraphQL types. | ||
/// | ||
/// Same as [FieldValue], but serialized as an untagged enum, | ||
/// which may be more suitable e.g. when serializing to JSON. | ||
#[derive(Debug, Clone, Serialize, Deserialize)] | ||
#[serde(untagged)] | ||
|
@@ -190,6 +198,7 @@ impl From<bool> for FieldValue { | |
} | ||
} | ||
|
||
/// Represents a finite (non-infinite, not-NaN) [f64] value | ||
pub struct FiniteF64(f64); | ||
impl From<FiniteF64> for FieldValue { | ||
fn from(f: FiniteF64) -> FieldValue { | ||
|
@@ -320,6 +329,7 @@ impl<T: Clone + Into<FieldValue>> From<&[T]> for FieldValue { | |
} | ||
} | ||
|
||
/// Converts a JSON number to a [FieldValue] | ||
fn convert_number_to_field_value(n: &Number) -> Result<FieldValue, String> { | ||
// The order here matters! | ||
// Int64 must be before Uint64, which must be before Float64. | ||
|
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.
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.
Doesn't have to be in this PR, just wondering: can we link
ContextField
here too?