-
-
Notifications
You must be signed in to change notification settings - Fork 944
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
Rewrite all the dioxus_elements
logic for more modular hotreload
support
#3318
base: main
Are you sure you want to change the base?
Conversation
465b6a3
to
f878665
Compare
f878665
to
f257529
Compare
ROADMAP:
|
First difficulty: where must the element namespace be static, and when does it have to do dynamic ? Right now, the fileds of |
Right now, the hotreloading is enabled by the following trait (https://github.com/DioxusLabs/dioxus/blob/main/packages/core-types/src/hr_context.rs): pub trait HotReloadingContext {
fn map_attribute(
element_name_rust: &str,
attribute_name_rust: &str,
) -> Option<(&'static str, Option<&'static str>)>;
fn map_element(element_name_rust: &str) -> Option<(&'static str, Option<&'static str>)>;
} Meaning that the namespace of the attribute depends on the parent element. If we have to call I have to find a way to compress it, like pointing to an attribute inside the definition of an element |
We currently leak the string in debug mode during hot reloading. Templates are fairly small and the leak only happens in debug mode, so it hasn't been an issue so far, but we have also discussed switching to Currently, the CLI sends a HotReloadedTemplate message to the front end for hot reloading. That is then combined with the dynamic pool to create a full VNode
The svg and global attributes traits could be pulled out into a separate "attribute group" section with a name and then each element could include one or more attribute group. For example, a |
Ok so something like
|
I think I will split the macro functionality into 2:
#[derive(dioxus::ElementSpecification)]
mod div {
static NAME_SPACE: &'static str = "div";
static TAG_NAME: Option<&'static str> = None;
use x::*;
static x: Attribute = (...);
}
#[derive(dioxus::AttributeGroupSpecification)]
mod svg_element {
static x: Attribute = (...);
} |
I have seen that the manganis support crate for the cli has moved to https://github.com/DioxusLabs/dioxus/blob/main/packages/cli-opt/src/lib.rs Is renaming |
From the linker side, it might be easier to model the metadata as a separate variant of the asset enum so we can re-use all of the extraction logic. After we get the data out of the link sections splitting it into a separate field would be good. This PR will already be breaking, so changing public fields isn't an issue. The name
I think both metadata and assets will need to be extracted every time the build runs before serve finishes, so they can share the same link section |
But an important property of an asset is it's path, what path do I set for metadata ? The current rust file ? |
Sorry, I was thinking of the old structure of manganis. Path used to be optional. It could be a different link section or a different top level enum that is either an asset or metadata. |
It is very much a draft.
For now, this channel is mainly a way for me to write down my reasoning about what has to be done.
The final goal of this PR is to get to a state where:
dioxus_elements
in scopeHotReloadCtx
trait)I also have a different PR #3274 that generates the elements spec with codegen, and this work is almost usable right now. I will have to merge the 2 at one point.