mirror of
https://github.com/rojo-rbx/rojo.git
synced 2026-04-24 22:56:02 +00:00
Add support for snapshotting rbxlx files
This commit is contained in:
@@ -11,6 +11,7 @@ mod json_model;
|
|||||||
mod lua;
|
mod lua;
|
||||||
mod middleware;
|
mod middleware;
|
||||||
mod project;
|
mod project;
|
||||||
|
mod rbxlx;
|
||||||
mod rbxm;
|
mod rbxm;
|
||||||
mod rbxmx;
|
mod rbxmx;
|
||||||
mod txt;
|
mod txt;
|
||||||
@@ -24,6 +25,7 @@ use self::{
|
|||||||
lua::SnapshotLua,
|
lua::SnapshotLua,
|
||||||
middleware::{SnapshotFileResult, SnapshotInstanceResult, SnapshotMiddleware},
|
middleware::{SnapshotFileResult, SnapshotInstanceResult, SnapshotMiddleware},
|
||||||
project::SnapshotProject,
|
project::SnapshotProject,
|
||||||
|
rbxlx::SnapshotRbxlx,
|
||||||
rbxm::SnapshotRbxm,
|
rbxm::SnapshotRbxm,
|
||||||
rbxmx::SnapshotRbxmx,
|
rbxmx::SnapshotRbxmx,
|
||||||
txt::SnapshotTxt,
|
txt::SnapshotTxt,
|
||||||
@@ -67,6 +69,7 @@ macro_rules! middlewares {
|
|||||||
middlewares! {
|
middlewares! {
|
||||||
SnapshotProject,
|
SnapshotProject,
|
||||||
SnapshotJsonModel,
|
SnapshotJsonModel,
|
||||||
|
SnapshotRbxlx,
|
||||||
SnapshotRbxmx,
|
SnapshotRbxmx,
|
||||||
SnapshotRbxm,
|
SnapshotRbxm,
|
||||||
SnapshotLua,
|
SnapshotLua,
|
||||||
|
|||||||
54
src/snapshot_middleware/rbxlx.rs
Normal file
54
src/snapshot_middleware/rbxlx.rs
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
use std::borrow::Cow;
|
||||||
|
|
||||||
|
use rbx_dom_weak::{RbxId, RbxTree};
|
||||||
|
|
||||||
|
use crate::{
|
||||||
|
imfs::{Imfs, ImfsEntry, ImfsFetcher},
|
||||||
|
snapshot::InstanceSnapshot,
|
||||||
|
};
|
||||||
|
|
||||||
|
use super::middleware::{SnapshotFileResult, SnapshotInstanceResult, SnapshotMiddleware};
|
||||||
|
|
||||||
|
pub struct SnapshotRbxlx;
|
||||||
|
|
||||||
|
impl SnapshotMiddleware for SnapshotRbxlx {
|
||||||
|
fn from_imfs<F: ImfsFetcher>(
|
||||||
|
imfs: &mut Imfs<F>,
|
||||||
|
entry: &ImfsEntry,
|
||||||
|
) -> SnapshotInstanceResult<'static> {
|
||||||
|
if entry.is_directory() {
|
||||||
|
return Ok(None);
|
||||||
|
}
|
||||||
|
|
||||||
|
let file_name = entry.path().file_name().unwrap().to_string_lossy();
|
||||||
|
|
||||||
|
if !file_name.ends_with(".rbxlx") {
|
||||||
|
return Ok(None);
|
||||||
|
}
|
||||||
|
|
||||||
|
let instance_name = entry
|
||||||
|
.path()
|
||||||
|
.file_stem()
|
||||||
|
.expect("Could not extract file stem")
|
||||||
|
.to_string_lossy()
|
||||||
|
.to_string();
|
||||||
|
|
||||||
|
let options = rbx_xml::DecodeOptions::new()
|
||||||
|
.property_behavior(rbx_xml::DecodePropertyBehavior::ReadUnknown);
|
||||||
|
|
||||||
|
let temp_tree = rbx_xml::from_reader(entry.contents(imfs)?, options)
|
||||||
|
.expect("TODO: Handle rbx_xml errors");
|
||||||
|
|
||||||
|
let root_id = temp_tree.get_root_id();
|
||||||
|
|
||||||
|
let mut snapshot = InstanceSnapshot::from_tree(&temp_tree, root_id);
|
||||||
|
snapshot.name = Cow::Owned(instance_name);
|
||||||
|
// TODO: Assign snapshot.source
|
||||||
|
|
||||||
|
Ok(Some(snapshot))
|
||||||
|
}
|
||||||
|
|
||||||
|
fn from_instance(_tree: &RbxTree, _id: RbxId) -> SnapshotFileResult {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user