mirror of
https://github.com/kaosat-dev/Blender_bevy_components_workflow.git
synced 2024-11-22 11:50:53 +00:00
feat(bevy_registry_export):
* added key & value type information for maps/hashmaps * added filtering out of components/resources
This commit is contained in:
parent
e7e680b92c
commit
3154b8e8c7
@ -20,9 +20,18 @@ pub fn export_types(world: &mut World) {
|
|||||||
println!("registry_save_path {}", registry_save_path.display());
|
println!("registry_save_path {}", registry_save_path.display());
|
||||||
let writer = File::create(registry_save_path).expect("should have created schema file");
|
let writer = File::create(registry_save_path).expect("should have created schema file");
|
||||||
|
|
||||||
|
let components_to_filter_out = &config.component_filter.clone();
|
||||||
|
let resources_to_filter_out = &config.resource_filter.clone();
|
||||||
|
|
||||||
let types = world.resource_mut::<AppTypeRegistry>();
|
let types = world.resource_mut::<AppTypeRegistry>();
|
||||||
let types = types.read();
|
let types = types.read();
|
||||||
let schemas = types.iter().map(export_type).collect::<Map<_, _>>();
|
let schemas = types.iter()
|
||||||
|
.filter(|type_info| {
|
||||||
|
let type_id = type_info.type_id();
|
||||||
|
return components_to_filter_out.is_allowed_by_id(type_id) && resources_to_filter_out.is_allowed_by_id(type_id);
|
||||||
|
})
|
||||||
|
.map(export_type)
|
||||||
|
.collect::<Map<_, _>>();
|
||||||
|
|
||||||
serde_json::to_writer_pretty(
|
serde_json::to_writer_pretty(
|
||||||
writer,
|
writer,
|
||||||
@ -41,7 +50,6 @@ pub fn export_type(reg: &TypeRegistration) -> (String, Value) {
|
|||||||
let t = reg.type_info();
|
let t = reg.type_info();
|
||||||
let binding = t.type_path_table();
|
let binding = t.type_path_table();
|
||||||
let short_name = binding.short_path();
|
let short_name = binding.short_path();
|
||||||
println!("T YOOO {:?}", t);
|
|
||||||
let mut schema = match t {
|
let mut schema = match t {
|
||||||
TypeInfo::Struct(info) => {
|
TypeInfo::Struct(info) => {
|
||||||
let properties = info
|
let properties = info
|
||||||
@ -164,7 +172,8 @@ pub fn export_type(reg: &TypeRegistration) -> (String, Value) {
|
|||||||
"long_name": t.type_path(),
|
"long_name": t.type_path(),
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"typeInfo": "Map",
|
"typeInfo": "Map",
|
||||||
"additionalProperties": json!({"type": typ(info.value_type_path_table().path())}),
|
"valueType": json!({"type": typ(info.value_type_path_table().path())}),
|
||||||
|
"keyType": json!({"type": typ(info.key_type_path_table().path())}),
|
||||||
}),
|
}),
|
||||||
TypeInfo::Tuple(info) => json!({
|
TypeInfo::Tuple(info) => json!({
|
||||||
"long_name": t.type_path(),
|
"long_name": t.type_path(),
|
||||||
|
@ -16,9 +16,9 @@ use bevy::{
|
|||||||
pub struct ExportComponentsConfig {
|
pub struct ExportComponentsConfig {
|
||||||
pub(crate) save_path: PathBuf,
|
pub(crate) save_path: PathBuf,
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
pub(crate) component_filter: SceneFilter, // unused for now
|
pub(crate) component_filter: SceneFilter,
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
pub(crate) resource_filter: SceneFilter, // unused for now
|
pub(crate) resource_filter: SceneFilter,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct ExportRegistryPlugin {
|
pub struct ExportRegistryPlugin {
|
||||||
@ -30,8 +30,8 @@ pub struct ExportRegistryPlugin {
|
|||||||
impl Default for ExportRegistryPlugin {
|
impl Default for ExportRegistryPlugin {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self {
|
Self {
|
||||||
component_filter: SceneFilter::default(), // unused for now
|
component_filter: SceneFilter::default(),
|
||||||
resource_filter: SceneFilter::default(), // unused for now
|
resource_filter: SceneFilter::default(),
|
||||||
save_path: PathBuf::from("registry.json"), // relative to assets folder
|
save_path: PathBuf::from("registry.json"), // relative to assets folder
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user