Skip to content
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

Construct PortableRegistry dynamically at runtime #164

Merged
merged 51 commits into from
Oct 7, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
8345a3c
WIP: allow constructing MetaTypes at runtime
ascjones Aug 11, 2022
3a14663
Remove fmt config options
ascjones Aug 11, 2022
1e03bd3
Add some docs
ascjones Aug 11, 2022
a68f28c
std feature String
ascjones Aug 11, 2022
da92e9d
fully qualified String
ascjones Aug 11, 2022
592736a
Fix features build
ascjones Aug 11, 2022
4500520
Generic string parameter for MetaType
ascjones Aug 15, 2022
a08ef8a
Remove license_template_path
ascjones Aug 15, 2022
3cacf78
Fmt
ascjones Aug 15, 2022
6476671
Fix fmt
ascjones Aug 15, 2022
6a1343b
Replace MetaFormString trait with cfg based string
ascjones Aug 16, 2022
42db0e3
Remove unused into
ascjones Aug 16, 2022
0c525c6
Fix more errors
ascjones Aug 16, 2022
7dfe55b
Now string types are the same across Meta/Portable, no longer necessa…
ascjones Aug 17, 2022
54ff5fc
Remove custom MetaType and TypeId
ascjones Aug 22, 2022
16e4e79
EXPERIMENT: make all type def fields public to allow construting Port…
ascjones Aug 22, 2022
c46186d
Rename test
ascjones Aug 22, 2022
5b47b1b
Fix up type ids in test
ascjones Aug 22, 2022
40b6047
Fix ui test
ascjones Aug 22, 2022
8255c99
*TEMPORARILY* pub registry for PortableType
ascjones Aug 23, 2022
79c19a9
add constructor for portableregistry
xermicus Aug 28, 2022
d8c3b5e
constructor for PortableType
xermicus Aug 28, 2022
0e4737f
implement remaining constructors for generic Form
xermicus Aug 28, 2022
8319875
make Type::new constructor public
xermicus Aug 28, 2022
ef4c3ee
make remaining constructor public
xermicus Aug 28, 2022
9e48542
add a new custom constructor for path
xermicus Sep 22, 2022
b900f54
Merge branch 'master' into aj/custom-meta-types
xermicus Sep 22, 2022
0b45a89
use new_custom in a test
xermicus Sep 22, 2022
6694dc0
Remove not required builder fn for MetaType
ascjones Sep 22, 2022
83a80ef
WIP propogate Form through builders
ascjones Oct 4, 2022
ae22be7
Fix up path builders
ascjones Oct 4, 2022
ababa57
More fixes
ascjones Oct 4, 2022
383399c
Fix up generated From impls
ascjones Oct 4, 2022
221c2f9
Fix up field builders
ascjones Oct 4, 2022
6caa3d6
Fix up field builder methods for MetaForm
ascjones Oct 4, 2022
a36540a
Rename constructor
ascjones Oct 4, 2022
b027ae8
Hide pub fields and add portable builder helper methods
ascjones Oct 4, 2022
1de0508
Fmt
ascjones Oct 4, 2022
f04d4ef
Explicity export PortableType
ascjones Oct 4, 2022
23c6cb9
Clippy
ascjones Oct 4, 2022
590bc58
Move PortableRegistry to own file, introduce PortableRegistryBuilder
ascjones Oct 5, 2022
b5b5a6f
Remove some stray `Str` type params
ascjones Oct 5, 2022
3c9d8dd
Implement PortableRegistryBuilder to manage ids
ascjones Oct 5, 2022
a2668a9
Default impl for PortableRegistryBuilder
ascjones Oct 5, 2022
220a59d
implement getter for registered types in PortableRegistryBuilder
xermicus Oct 6, 2022
07057ce
Rename new path constructor
ascjones Oct 7, 2022
07aaef8
Rename new_custom methods to new_portable
ascjones Oct 7, 2022
192d12c
Revert reordering of MetaForm
ascjones Oct 7, 2022
403c720
Move path construction back to MetaForm for non-breaking changes
ascjones Oct 7, 2022
1044c8d
Update path tests
ascjones Oct 7, 2022
c9149c2
TypeParameter::new_portable for non breaking change
ascjones Oct 7, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Rename new_custom methods to new_portable
  • Loading branch information
ascjones committed Oct 7, 2022
commit 07aaef823d15e46d64df69a46c5f31e3539256a7
25 changes: 13 additions & 12 deletions src/ty/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -476,20 +476,22 @@ impl TypeDefTuple {
}
}

impl<T> TypeDefTuple<T>
where
T: Form,
{
impl TypeDefTuple<PortableForm> {
/// Creates a new custom type definition from the given types.
pub fn new_custom<I>(type_params: I) -> Self
pub fn new_portable<I>(type_params: I) -> Self
where
I: IntoIterator<Item = T::Type>,
I: IntoIterator<Item = <PortableForm as Form>::Type>,
{
Self {
fields: type_params.into_iter().collect(),
}
}
}

impl<T> TypeDefTuple<T>
where
T: Form,
{
/// Returns the types of the tuple fields.
pub fn fields(&self) -> &[T::Type] {
&self.fields
Expand Down Expand Up @@ -642,13 +644,12 @@ impl TypeDefBitSequence {
}
}

#[cfg(feature = "bit-vec")]
impl<T> TypeDefBitSequence<T>
where
T: Form,
{
impl TypeDefBitSequence<PortableForm> {
/// Creates a new [`TypeDefBitSequence`] for the supplied bit order and bit store types.
pub fn new_custom(bit_store_type: T::Type, bit_order_type: T::Type) -> Self {
pub fn new_portable(
bit_store_type: <PortableForm as Form>::Type,
bit_order_type: <PortableForm as Form>::Type,
) -> Self {
Self {
bit_store_type,
bit_order_type,
Expand Down
5 changes: 0 additions & 5 deletions src/ty/path.rs
Original file line number Diff line number Diff line change
Expand Up @@ -161,11 +161,6 @@ where
}
}

/// Create a new custom path.
pub fn new_custom(segments: Vec<<T as Form>::String>) -> Path<T> {
Self { segments }
}

/// Returns the segments of the Path
pub fn segments(&self) -> &[T::String] {
&self.segments
Expand Down