Add RunContext support for script outputs (#765)

Resolves #667

This PR:

- Introduces a new field in the project file: `scriptType` which has the
default value of `Class` (in parity with previous versions), but can
also be `RunContext`.
- This is then passed to `InstanceContext` from the `Project` struct.
- This then changes the RunContext in the lua `snapshot_middleware`

---------

Co-authored-by: Micah <dekkonot@rocketmail.com>
This commit is contained in:
Sasial
2023-09-24 06:28:09 +10:00
committed by GitHub
parent 539cd0d418
commit bb8dd1402d
56 changed files with 602 additions and 95 deletions

View File

@@ -28,6 +28,12 @@
* Added support for `Terrain.MaterialColors` ([#770]) * Added support for `Terrain.MaterialColors` ([#770])
* Allow `Terrain` to be specified without a classname ([#771]) * Allow `Terrain` to be specified without a classname ([#771])
* Add Confirmation Behavior setting ([#774]) * Add Confirmation Behavior setting ([#774])
* Added the `emitLegacyScripts` field to the project format ([#765]). The behavior is outlined below:
| `emitLegacyScripts` Value | Action Taken by Rojo |
|----------------------------|--------------------------------------------------------------------------------------------------------------------|
| false | Rojo emits Scripts with the appropriate `RunContext` for `*.client.lua` and `*.server.lua` files in the project. |
| true (default) | Rojo emits LocalScripts and Scripts with legacy `RunContext` (same behavior as previously). |
[#761]: https://github.com/rojo-rbx/rojo/pull/761 [#761]: https://github.com/rojo-rbx/rojo/pull/761
[#745]: https://github.com/rojo-rbx/rojo/pull/745 [#745]: https://github.com/rojo-rbx/rojo/pull/745
@@ -53,6 +59,7 @@
[#748]: https://github.com/rojo-rbx/rojo/pull/748 [#748]: https://github.com/rojo-rbx/rojo/pull/748
[#755]: https://github.com/rojo-rbx/rojo/pull/755 [#755]: https://github.com/rojo-rbx/rojo/pull/755
[#760]: https://github.com/rojo-rbx/rojo/pull/760 [#760]: https://github.com/rojo-rbx/rojo/pull/760
[#765]: https://github.com/rojo-rbx/rojo/pull/765
[#770]: https://github.com/rojo-rbx/rojo/pull/770 [#770]: https://github.com/rojo-rbx/rojo/pull/770
[#771]: https://github.com/rojo-rbx/rojo/pull/771 [#771]: https://github.com/rojo-rbx/rojo/pull/771
[#774]: https://github.com/rojo-rbx/rojo/pull/774 [#774]: https://github.com/rojo-rbx/rojo/pull/774

View File

@@ -0,0 +1,35 @@
---
source: tests/tests/build.rs
expression: contents
---
<roblox version="4">
<Item class="Folder" referent="0">
<Properties>
<string name="Name">nested_runcontext</string>
</Properties>
<Item class="Folder" referent="1">
<Properties>
<string name="Name">folder1</string>
</Properties>
<Item class="Script" referent="2">
<Properties>
<string name="Name">test</string>
<token name="RunContext">1</token>
<string name="Source"></string>
</Properties>
</Item>
</Item>
<Item class="Folder" referent="3">
<Properties>
<string name="Name">folder2</string>
</Properties>
<Item class="Script" referent="4">
<Properties>
<string name="Name">test</string>
<token name="RunContext">0</token>
<string name="Source"></string>
</Properties>
</Item>
</Item>
</Item>
</roblox>

View File

@@ -11,6 +11,7 @@ expression: contents
<Properties> <Properties>
<string name="Name">hello</string> <string name="Name">hello</string>
<bool name="Disabled">true</bool> <bool name="Disabled">true</bool>
<token name="RunContext">0</token>
<string name="Source">-- This script should be marked 'Disabled'</string> <string name="Source">-- This script should be marked 'Disabled'</string>
</Properties> </Properties>
</Item> </Item>

View File

@@ -10,6 +10,7 @@ expression: contents
<Item class="Script" referent="1"> <Item class="Script" referent="1">
<Properties> <Properties>
<string name="Name">serverScript</string> <string name="Name">serverScript</string>
<token name="RunContext">0</token>
<string name="Source">-- This is a Lua server script</string> <string name="Source">-- This is a Lua server script</string>
</Properties> </Properties>
</Item> </Item>

View File

@@ -6,6 +6,7 @@ expression: contents
<Item class="Script" referent="0"> <Item class="Script" referent="0">
<Properties> <Properties>
<string name="Name">server_init</string> <string name="Name">server_init</string>
<token name="RunContext">0</token>
<string name="Source">return "From folder/init.server.lua"</string> <string name="Source">return "From folder/init.server.lua"</string>
</Properties> </Properties>
</Item> </Item>

View File

@@ -0,0 +1,13 @@
{
"name": "nested_runcontext",
"emitLegacyScripts": false,
"tree": {
"$className": "Folder",
"folder1": {
"$path": "folder1"
},
"folder2": {
"$path": "folder2"
}
}
}

View File

@@ -0,0 +1,7 @@
{
"name": "nested_runcontext",
"emitLegacyScripts": true,
"tree": {
"$path": "folder3"
}
}

View File

@@ -24,6 +24,8 @@ instances:
Name: bar Name: bar
Parent: id-2 Parent: id-2
Properties: Properties:
RunContext:
Enum: 0
Source: Source:
String: "-- Hello, from bar!" String: "-- Hello, from bar!"
id-4: id-4:

View File

@@ -24,6 +24,8 @@ instances:
Name: bar Name: bar
Parent: id-2 Parent: id-2
Properties: Properties:
RunContext:
Enum: 0
Source: Source:
String: "-- Hello, from bar!" String: "-- Hello, from bar!"
id-4: id-4:

View File

@@ -8,7 +8,9 @@ use std::{
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use thiserror::Error; use thiserror::Error;
use crate::{glob::Glob, resolution::UnresolvedValue}; use crate::{
glob::Glob, resolution::UnresolvedValue, snapshot_middleware::emit_legacy_scripts_default,
};
static PROJECT_FILENAME: &str = "default.project.json"; static PROJECT_FILENAME: &str = "default.project.json";
@@ -73,6 +75,14 @@ pub struct Project {
#[serde(skip_serializing_if = "Option::is_none")] #[serde(skip_serializing_if = "Option::is_none")]
pub serve_address: Option<IpAddr>, pub serve_address: Option<IpAddr>,
/// Determines if rojo should emit scripts with the appropriate `RunContext` for `*.client.lua` and `*.server.lua` files in the project.
/// Or, if rojo should keep the legacy behavior of emitting LocalScripts and Scripts with legacy Runcontext
#[serde(
default = "emit_legacy_scripts_default",
skip_serializing_if = "Option::is_none"
)]
pub emit_legacy_scripts: Option<bool>,
/// A list of globs, relative to the folder the project file is in, that /// A list of globs, relative to the folder the project file is in, that
/// match files that should be excluded if Rojo encounters them. /// match files that should be excluded if Rojo encounters them.
#[serde(default, skip_serializing_if = "Vec::is_empty")] #[serde(default, skip_serializing_if = "Vec::is_empty")]

View File

@@ -123,7 +123,8 @@ impl ServeSession {
let root_id = tree.get_root_id(); let root_id = tree.get_root_id();
let instance_context = InstanceContext::default(); let instance_context =
InstanceContext::with_emit_legacy_scripts(root_project.emit_legacy_scripts);
log::trace!("Generating snapshot of instances from VFS"); log::trace!("Generating snapshot of instances from VFS");
let snapshot = snapshot_from_vfs(&instance_context, &vfs, start_path)?; let snapshot = snapshot_from_vfs(&instance_context, &vfs, start_path)?;

View File

@@ -6,7 +6,10 @@ use std::{
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use crate::{glob::Glob, path_serializer, project::ProjectNode}; use crate::{
glob::Glob, path_serializer, project::ProjectNode,
snapshot_middleware::emit_legacy_scripts_default,
};
/// Rojo-specific metadata that can be associated with an instance or a snapshot /// Rojo-specific metadata that can be associated with an instance or a snapshot
/// of an instance. /// of an instance.
@@ -103,9 +106,26 @@ impl Default for InstanceMetadata {
pub struct InstanceContext { pub struct InstanceContext {
#[serde(skip_serializing_if = "Vec::is_empty")] #[serde(skip_serializing_if = "Vec::is_empty")]
pub path_ignore_rules: Arc<Vec<PathIgnoreRule>>, pub path_ignore_rules: Arc<Vec<PathIgnoreRule>>,
pub emit_legacy_scripts: bool,
} }
impl InstanceContext { impl InstanceContext {
pub fn new() -> Self {
Self {
path_ignore_rules: Arc::new(Vec::new()),
emit_legacy_scripts: emit_legacy_scripts_default().unwrap(),
}
}
pub fn with_emit_legacy_scripts(emit_legacy_scripts: Option<bool>) -> Self {
Self {
emit_legacy_scripts: emit_legacy_scripts
.or_else(emit_legacy_scripts_default)
.unwrap(),
..Self::new()
}
}
/// Extend the list of ignore rules in the context with the given new rules. /// Extend the list of ignore rules in the context with the given new rules.
pub fn add_path_ignore_rules<I>(&mut self, new_rules: I) pub fn add_path_ignore_rules<I>(&mut self, new_rules: I)
where where
@@ -123,13 +143,15 @@ impl InstanceContext {
let rules = Arc::make_mut(&mut self.path_ignore_rules); let rules = Arc::make_mut(&mut self.path_ignore_rules);
rules.extend(new_rules); rules.extend(new_rules);
} }
pub fn set_emit_legacy_scripts(&mut self, emit_legacy_scripts: bool) {
self.emit_legacy_scripts = emit_legacy_scripts;
}
} }
impl Default for InstanceContext { impl Default for InstanceContext {
fn default() -> Self { fn default() -> Self {
InstanceContext { Self::new()
path_ignore_rules: Arc::new(Vec::new()),
}
} }
} }

View File

@@ -1,7 +1,6 @@
--- ---
source: src/snapshot/tests/apply.rs source: src/snapshot/tests/apply.rs
expression: tree_view expression: tree_view
--- ---
id: id-1 id: id-1
name: ROOT name: ROOT
@@ -12,6 +11,7 @@ properties:
metadata: metadata:
ignore_unknown_instances: false ignore_unknown_instances: false
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
children: [] children: []

View File

@@ -9,5 +9,7 @@ properties: {}
metadata: metadata:
ignore_unknown_instances: false ignore_unknown_instances: false
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
children: [] children: []

View File

@@ -1,7 +1,6 @@
--- ---
source: src/snapshot/tests/apply.rs source: src/snapshot/tests/apply.rs
expression: tree_view expression: tree_view
--- ---
id: id-1 id: id-1
name: ROOT name: ROOT
@@ -12,6 +11,7 @@ properties:
metadata: metadata:
ignore_unknown_instances: false ignore_unknown_instances: false
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
children: [] children: []

View File

@@ -9,5 +9,7 @@ properties: {}
metadata: metadata:
ignore_unknown_instances: false ignore_unknown_instances: false
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
children: [] children: []

View File

@@ -10,7 +10,8 @@ added_instances:
metadata: metadata:
ignore_unknown_instances: false ignore_unknown_instances: false
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
name: New name: New
class_name: Folder class_name: Folder
properties: {} properties: {}

View File

@@ -1,8 +1,8 @@
use std::{path::Path, str}; use std::{collections::HashMap, path::Path, str};
use anyhow::Context; use anyhow::Context;
use maplit::hashmap;
use memofs::{IoResultExt, Vfs}; use memofs::{IoResultExt, Vfs};
use rbx_dom_weak::types::Enum;
use crate::snapshot::{InstanceContext, InstanceMetadata, InstanceSnapshot}; use crate::snapshot::{InstanceContext, InstanceMetadata, InstanceSnapshot};
@@ -12,6 +12,13 @@ use super::{
util::match_trailing, util::match_trailing,
}; };
#[derive(Debug)]
enum ScriptType {
Server,
Client,
Module,
}
/// Core routine for turning Lua files into snapshots. /// Core routine for turning Lua files into snapshots.
pub fn snapshot_lua( pub fn snapshot_lua(
context: &InstanceContext, context: &InstanceContext,
@@ -20,36 +27,58 @@ pub fn snapshot_lua(
) -> anyhow::Result<Option<InstanceSnapshot>> { ) -> anyhow::Result<Option<InstanceSnapshot>> {
let file_name = path.file_name().unwrap().to_string_lossy(); let file_name = path.file_name().unwrap().to_string_lossy();
let (class_name, instance_name) = if let Some(name) = match_trailing(&file_name, ".server.lua") let run_context_enums = &rbx_reflection_database::get()
.enums
.get("RunContext")
.expect("Unable to get RunContext enums!")
.items;
let (script_type, instance_name) = if let Some(name) = match_trailing(&file_name, ".server.lua")
{ {
("Script", name) (ScriptType::Server, name)
} else if let Some(name) = match_trailing(&file_name, ".client.lua") { } else if let Some(name) = match_trailing(&file_name, ".client.lua") {
("LocalScript", name) (ScriptType::Client, name)
} else if let Some(name) = match_trailing(&file_name, ".lua") { } else if let Some(name) = match_trailing(&file_name, ".lua") {
("ModuleScript", name) (ScriptType::Module, name)
} else if let Some(name) = match_trailing(&file_name, ".server.luau") { } else if let Some(name) = match_trailing(&file_name, ".server.luau") {
("Script", name) (ScriptType::Server, name)
} else if let Some(name) = match_trailing(&file_name, ".client.luau") { } else if let Some(name) = match_trailing(&file_name, ".client.luau") {
("LocalScript", name) (ScriptType::Client, name)
} else if let Some(name) = match_trailing(&file_name, ".luau") { } else if let Some(name) = match_trailing(&file_name, ".luau") {
("ModuleScript", name) (ScriptType::Module, name)
} else { } else {
return Ok(None); return Ok(None);
}; };
let (class_name, run_context) = match (context.emit_legacy_scripts, script_type) {
(false, ScriptType::Server) => ("Script", run_context_enums.get("Server")),
(false, ScriptType::Client) => ("Script", run_context_enums.get("Client")),
(true, ScriptType::Server) => ("Script", run_context_enums.get("Legacy")),
(true, ScriptType::Client) => ("LocalScript", None),
(_, ScriptType::Module) => ("ModuleScript", None),
};
let contents = vfs.read(path)?; let contents = vfs.read(path)?;
let contents_str = str::from_utf8(&contents) let contents_str = str::from_utf8(&contents)
.with_context(|| format!("File was not valid UTF-8: {}", path.display()))? .with_context(|| format!("File was not valid UTF-8: {}", path.display()))?
.to_owned(); .to_owned();
let mut properties = HashMap::with_capacity(2);
properties.insert("Source".to_owned(), contents_str.into());
if let Some(run_context) = run_context {
properties.insert(
"RunContext".to_owned(),
Enum::from_u32(run_context.to_owned()).into(),
);
}
let meta_path = path.with_file_name(format!("{}.meta.json", instance_name)); let meta_path = path.with_file_name(format!("{}.meta.json", instance_name));
let mut snapshot = InstanceSnapshot::new() let mut snapshot = InstanceSnapshot::new()
.name(instance_name) .name(instance_name)
.class_name(class_name) .class_name(class_name)
.properties(hashmap! { .properties(properties)
"Source".to_owned() => contents_str.into(),
})
.metadata( .metadata(
InstanceMetadata::new() InstanceMetadata::new()
.instigating_source(path) .instigating_source(path)
@@ -107,26 +136,53 @@ pub fn snapshot_lua_init(
mod test { mod test {
use super::*; use super::*;
use maplit::hashmap;
use memofs::{InMemoryFs, VfsSnapshot}; use memofs::{InMemoryFs, VfsSnapshot};
#[test] #[test]
fn module_from_vfs() { fn class_module_from_vfs() {
let mut imfs = InMemoryFs::new(); let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.lua", VfsSnapshot::file("Hello there!")) imfs.load_snapshot("/foo.lua", VfsSnapshot::file("Hello there!"))
.unwrap(); .unwrap();
let mut vfs = Vfs::new(imfs); let mut vfs = Vfs::new(imfs);
let instance_snapshot = let instance_snapshot = snapshot_lua(
snapshot_lua(&InstanceContext::default(), &mut vfs, Path::new("/foo.lua")) &InstanceContext::with_emit_legacy_scripts(Some(true)),
.unwrap() &mut vfs,
.unwrap(); Path::new("/foo.lua"),
)
.unwrap()
.unwrap();
insta::assert_yaml_snapshot!(instance_snapshot); insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
} }
#[test] #[test]
fn server_from_vfs() { fn runcontext_module_from_vfs() {
let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.lua", VfsSnapshot::file("Hello there!"))
.unwrap();
let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua(
&InstanceContext::with_emit_legacy_scripts(Some(false)),
&mut vfs,
Path::new("/foo.lua"),
)
.unwrap()
.unwrap();
insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
}
#[test]
fn class_server_from_vfs() {
let mut imfs = InMemoryFs::new(); let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.server.lua", VfsSnapshot::file("Hello there!")) imfs.load_snapshot("/foo.server.lua", VfsSnapshot::file("Hello there!"))
.unwrap(); .unwrap();
@@ -134,18 +190,41 @@ mod test {
let mut vfs = Vfs::new(imfs); let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua( let instance_snapshot = snapshot_lua(
&InstanceContext::default(), &InstanceContext::with_emit_legacy_scripts(Some(true)),
&mut vfs, &mut vfs,
Path::new("/foo.server.lua"), Path::new("/foo.server.lua"),
) )
.unwrap() .unwrap()
.unwrap(); .unwrap();
insta::assert_yaml_snapshot!(instance_snapshot); insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
} }
#[test] #[test]
fn client_from_vfs() { fn runcontext_server_from_vfs() {
let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.server.lua", VfsSnapshot::file("Hello there!"))
.unwrap();
let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua(
&InstanceContext::with_emit_legacy_scripts(Some(false)),
&mut vfs,
Path::new("/foo.server.lua"),
)
.unwrap()
.unwrap();
insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
}
#[test]
fn class_client_from_vfs() {
let mut imfs = InMemoryFs::new(); let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.client.lua", VfsSnapshot::file("Hello there!")) imfs.load_snapshot("/foo.client.lua", VfsSnapshot::file("Hello there!"))
.unwrap(); .unwrap();
@@ -153,14 +232,37 @@ mod test {
let mut vfs = Vfs::new(imfs); let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua( let instance_snapshot = snapshot_lua(
&InstanceContext::default(), &InstanceContext::with_emit_legacy_scripts(Some(true)),
&mut vfs, &mut vfs,
Path::new("/foo.client.lua"), Path::new("/foo.client.lua"),
) )
.unwrap() .unwrap()
.unwrap(); .unwrap();
insta::assert_yaml_snapshot!(instance_snapshot); insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
}
#[test]
fn runcontext_client_from_vfs() {
let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.client.lua", VfsSnapshot::file("Hello there!"))
.unwrap();
let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua(
&InstanceContext::with_emit_legacy_scripts(Some(false)),
&mut vfs,
Path::new("/foo.client.lua"),
)
.unwrap()
.unwrap();
insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
} }
#[ignore = "init.lua functionality has moved to the root snapshot function"] #[ignore = "init.lua functionality has moved to the root snapshot function"]
@@ -177,16 +279,21 @@ mod test {
let mut vfs = Vfs::new(imfs); let mut vfs = Vfs::new(imfs);
let instance_snapshot = let instance_snapshot = snapshot_lua(
snapshot_lua(&InstanceContext::default(), &mut vfs, Path::new("/root")) &InstanceContext::with_emit_legacy_scripts(Some(true)),
.unwrap() &mut vfs,
.unwrap(); Path::new("/root"),
)
.unwrap()
.unwrap();
insta::assert_yaml_snapshot!(instance_snapshot); insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
} }
#[test] #[test]
fn module_with_meta() { fn class_module_with_meta() {
let mut imfs = InMemoryFs::new(); let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.lua", VfsSnapshot::file("Hello there!")) imfs.load_snapshot("/foo.lua", VfsSnapshot::file("Hello there!"))
.unwrap(); .unwrap();
@@ -204,16 +311,53 @@ mod test {
let mut vfs = Vfs::new(imfs); let mut vfs = Vfs::new(imfs);
let instance_snapshot = let instance_snapshot = snapshot_lua(
snapshot_lua(&InstanceContext::default(), &mut vfs, Path::new("/foo.lua")) &InstanceContext::with_emit_legacy_scripts(Some(true)),
.unwrap() &mut vfs,
.unwrap(); Path::new("/foo.lua"),
)
.unwrap()
.unwrap();
insta::assert_yaml_snapshot!(instance_snapshot); insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
} }
#[test] #[test]
fn script_with_meta() { fn runcontext_module_with_meta() {
let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.lua", VfsSnapshot::file("Hello there!"))
.unwrap();
imfs.load_snapshot(
"/foo.meta.json",
VfsSnapshot::file(
r#"
{
"ignoreUnknownInstances": true
}
"#,
),
)
.unwrap();
let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua(
&InstanceContext::with_emit_legacy_scripts(Some(false)),
&mut vfs,
Path::new("/foo.lua"),
)
.unwrap()
.unwrap();
insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
}
#[test]
fn class_script_with_meta() {
let mut imfs = InMemoryFs::new(); let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.server.lua", VfsSnapshot::file("Hello there!")) imfs.load_snapshot("/foo.server.lua", VfsSnapshot::file("Hello there!"))
.unwrap(); .unwrap();
@@ -232,18 +376,52 @@ mod test {
let mut vfs = Vfs::new(imfs); let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua( let instance_snapshot = snapshot_lua(
&InstanceContext::default(), &InstanceContext::with_emit_legacy_scripts(Some(true)),
&mut vfs, &mut vfs,
Path::new("/foo.server.lua"), Path::new("/foo.server.lua"),
) )
.unwrap() .unwrap()
.unwrap(); .unwrap();
insta::assert_yaml_snapshot!(instance_snapshot); insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
} }
#[test] #[test]
fn script_disabled() { fn runcontext_script_with_meta() {
let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/foo.server.lua", VfsSnapshot::file("Hello there!"))
.unwrap();
imfs.load_snapshot(
"/foo.meta.json",
VfsSnapshot::file(
r#"
{
"ignoreUnknownInstances": true
}
"#,
),
)
.unwrap();
let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua(
&InstanceContext::with_emit_legacy_scripts(Some(false)),
&mut vfs,
Path::new("/foo.server.lua"),
)
.unwrap()
.unwrap();
insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
}
#[test]
fn class_script_disabled() {
let mut imfs = InMemoryFs::new(); let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/bar.server.lua", VfsSnapshot::file("Hello there!")) imfs.load_snapshot("/bar.server.lua", VfsSnapshot::file("Hello there!"))
.unwrap(); .unwrap();
@@ -264,7 +442,41 @@ mod test {
let mut vfs = Vfs::new(imfs); let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua( let instance_snapshot = snapshot_lua(
&InstanceContext::default(), &InstanceContext::with_emit_legacy_scripts(Some(true)),
&mut vfs,
Path::new("/bar.server.lua"),
)
.unwrap()
.unwrap();
insta::with_settings!({ sort_maps => true }, {
insta::assert_yaml_snapshot!(instance_snapshot);
});
}
#[test]
fn runcontext_script_disabled() {
let mut imfs = InMemoryFs::new();
imfs.load_snapshot("/bar.server.lua", VfsSnapshot::file("Hello there!"))
.unwrap();
imfs.load_snapshot(
"/bar.meta.json",
VfsSnapshot::file(
r#"
{
"properties": {
"Disabled": true
}
}
"#,
),
)
.unwrap();
let mut vfs = Vfs::new(imfs);
let instance_snapshot = snapshot_lua(
&InstanceContext::with_emit_legacy_scripts(Some(false)),
&mut vfs, &mut vfs,
Path::new("/bar.server.lua"), Path::new("/bar.server.lua"),
) )

View File

@@ -38,7 +38,7 @@ use self::{
util::PathExt, util::PathExt,
}; };
pub use self::project::snapshot_project_node; pub use self::{project::snapshot_project_node, util::emit_legacy_scripts_default};
/// The main entrypoint to the snapshot function. This function can be pointed /// The main entrypoint to the snapshot function. This function can be pointed
/// at any path and will return something if Rojo knows how to deal with it. /// at any path and will return something if Rojo knows how to deal with it.

View File

@@ -12,7 +12,7 @@ use crate::{
}, },
}; };
use super::snapshot_from_vfs; use super::{emit_legacy_scripts_default, snapshot_from_vfs};
pub fn snapshot_project( pub fn snapshot_project(
context: &InstanceContext, context: &InstanceContext,
@@ -30,6 +30,12 @@ pub fn snapshot_project(
}); });
context.add_path_ignore_rules(rules); context.add_path_ignore_rules(rules);
context.set_emit_legacy_scripts(
project
.emit_legacy_scripts
.or_else(emit_legacy_scripts_default)
.unwrap(),
);
match snapshot_project_node(&context, path, &project.name, &project.tree, vfs, None)? { match snapshot_project_node(&context, path, &project.name, &project.tree, vfs, None)? {
Some(found_snapshot) => { Some(found_snapshot) => {
@@ -77,7 +83,7 @@ pub fn snapshot_project_node(
let name = Cow::Owned(instance_name.to_owned()); let name = Cow::Owned(instance_name.to_owned());
let mut properties = HashMap::new(); let mut properties = HashMap::new();
let mut children = Vec::new(); let mut children = Vec::new();
let mut metadata = InstanceMetadata::default(); let mut metadata = InstanceMetadata::new().context(context);
if let Some(path_node) = &node.path { if let Some(path_node) = &node.path {
let path = path_node.path(); let path = path_node.path();

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo.csv - /foo.csv
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: LocalizationTable class_name: LocalizationTable
properties: properties:

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo.csv - /foo.csv
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: LocalizationTable class_name: LocalizationTable
properties: properties:

View File

@@ -17,7 +17,8 @@ metadata:
- /foo/init.client.lua - /foo/init.client.lua
- /foo/init.client.luau - /foo/init.client.luau
- /foo/init.csv - /foo/init.csv
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: Folder class_name: Folder
properties: {} properties: {}

View File

@@ -17,7 +17,8 @@ metadata:
- /foo/init.client.lua - /foo/init.client.lua
- /foo/init.client.luau - /foo/init.client.luau
- /foo/init.csv - /foo/init.csv
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: Folder class_name: Folder
properties: {} properties: {}
@@ -37,7 +38,8 @@ children:
- /foo/Child/init.client.lua - /foo/Child/init.client.lua
- /foo/Child/init.client.luau - /foo/Child/init.client.luau
- /foo/Child/init.csv - /foo/Child/init.csv
context: {} context:
emit_legacy_scripts: true
name: Child name: Child
class_name: Folder class_name: Folder
properties: {} properties: {}

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo.json - /foo.json
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: ModuleScript class_name: ModuleScript
properties: properties:

View File

@@ -9,7 +9,8 @@ metadata:
Path: /foo.model.json Path: /foo.model.json
relevant_paths: relevant_paths:
- /foo.model.json - /foo.model.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: IntValue class_name: IntValue
properties: properties:
@@ -20,7 +21,8 @@ children:
metadata: metadata:
ignore_unknown_instances: false ignore_unknown_instances: false
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
name: The Child name: The Child
class_name: StringValue class_name: StringValue
properties: {} properties: {}

View File

@@ -9,7 +9,8 @@ metadata:
Path: /foo.model.json Path: /foo.model.json
relevant_paths: relevant_paths:
- /foo.model.json - /foo.model.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: IntValue class_name: IntValue
properties: properties:
@@ -20,7 +21,8 @@ children:
metadata: metadata:
ignore_unknown_instances: false ignore_unknown_instances: false
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
name: The Child name: The Child
class_name: StringValue class_name: StringValue
properties: {} properties: {}

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo.client.lua - /foo.client.lua
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: LocalScript class_name: LocalScript
properties: properties:

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo.lua - /foo.lua
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: ModuleScript class_name: ModuleScript
properties: properties:

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo.lua - /foo.lua
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: ModuleScript class_name: ModuleScript
properties: properties:

View File

@@ -10,12 +10,15 @@ metadata:
relevant_paths: relevant_paths:
- /bar.server.lua - /bar.server.lua
- /bar.meta.json - /bar.meta.json
context: {} context:
emit_legacy_scripts: true
name: bar name: bar
class_name: Script class_name: Script
properties: properties:
Disabled: Disabled:
Bool: true Bool: true
RunContext:
Enum: 0
Source: Source:
String: Hello there! String: Hello there!
children: [] children: []

View File

@@ -10,10 +10,13 @@ metadata:
relevant_paths: relevant_paths:
- /foo.server.lua - /foo.server.lua
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: Script class_name: Script
properties: properties:
RunContext:
Enum: 0
Source: Source:
String: Hello there! String: Hello there!
children: [] children: []

View File

@@ -10,10 +10,13 @@ metadata:
relevant_paths: relevant_paths:
- /foo.server.lua - /foo.server.lua
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: Script class_name: Script
properties: properties:
RunContext:
Enum: 0
Source: Source:
String: Hello there! String: Hello there!
children: [] children: []

View File

@@ -13,7 +13,8 @@ metadata:
- /root/init.lua - /root/init.lua
- /root/init.server.lua - /root/init.server.lua
- /root/init.client.lua - /root/init.client.lua
context: {} context:
script_type: Class
name: root name: root
class_name: ModuleScript class_name: ModuleScript
properties: properties:

View File

@@ -0,0 +1,23 @@
---
source: src/snapshot_middleware/lua.rs
expression: instance_snapshot
---
snapshot_id: "00000000000000000000000000000000"
metadata:
ignore_unknown_instances: false
instigating_source:
Path: /foo.client.lua
relevant_paths:
- /foo.client.lua
- /foo.meta.json
context:
emit_legacy_scripts: false
name: foo
class_name: Script
properties:
RunContext:
Enum: 2
Source:
String: Hello there!
children: []

View File

@@ -0,0 +1,21 @@
---
source: src/snapshot_middleware/lua.rs
expression: instance_snapshot
---
snapshot_id: "00000000000000000000000000000000"
metadata:
ignore_unknown_instances: false
instigating_source:
Path: /foo.lua
relevant_paths:
- /foo.lua
- /foo.meta.json
context:
emit_legacy_scripts: false
name: foo
class_name: ModuleScript
properties:
Source:
String: Hello there!
children: []

View File

@@ -0,0 +1,21 @@
---
source: src/snapshot_middleware/lua.rs
expression: instance_snapshot
---
snapshot_id: "00000000000000000000000000000000"
metadata:
ignore_unknown_instances: true
instigating_source:
Path: /foo.lua
relevant_paths:
- /foo.lua
- /foo.meta.json
context:
emit_legacy_scripts: false
name: foo
class_name: ModuleScript
properties:
Source:
String: Hello there!
children: []

View File

@@ -0,0 +1,25 @@
---
source: src/snapshot_middleware/lua.rs
expression: instance_snapshot
---
snapshot_id: "00000000000000000000000000000000"
metadata:
ignore_unknown_instances: false
instigating_source:
Path: /bar.server.lua
relevant_paths:
- /bar.server.lua
- /bar.meta.json
context:
emit_legacy_scripts: false
name: bar
class_name: Script
properties:
Disabled:
Bool: true
RunContext:
Enum: 1
Source:
String: Hello there!
children: []

View File

@@ -0,0 +1,23 @@
---
source: src/snapshot_middleware/lua.rs
expression: instance_snapshot
---
snapshot_id: "00000000000000000000000000000000"
metadata:
ignore_unknown_instances: true
instigating_source:
Path: /foo.server.lua
relevant_paths:
- /foo.server.lua
- /foo.meta.json
context:
emit_legacy_scripts: false
name: foo
class_name: Script
properties:
RunContext:
Enum: 1
Source:
String: Hello there!
children: []

View File

@@ -0,0 +1,23 @@
---
source: src/snapshot_middleware/lua.rs
expression: instance_snapshot
---
snapshot_id: "00000000000000000000000000000000"
metadata:
ignore_unknown_instances: false
instigating_source:
Path: /foo.server.lua
relevant_paths:
- /foo.server.lua
- /foo.meta.json
context:
emit_legacy_scripts: false
name: foo
class_name: Script
properties:
RunContext:
Enum: 1
Source:
String: Hello there!
children: []

View File

@@ -9,7 +9,8 @@ metadata:
Path: /foo/hello.project.json Path: /foo/hello.project.json
relevant_paths: relevant_paths:
- /foo/hello.project.json - /foo/hello.project.json
context: {} context:
emit_legacy_scripts: true
name: direct-project name: direct-project
class_name: Model class_name: Model
properties: {} properties: {}

View File

@@ -9,7 +9,8 @@ metadata:
Path: /foo/default.project.json Path: /foo/default.project.json
relevant_paths: relevant_paths:
- /foo/default.project.json - /foo/default.project.json
context: {} context:
script_type: Class
name: indirect-project name: indirect-project
class_name: Folder class_name: Folder
properties: {} properties: {}

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo/other.project.json - /foo/other.project.json
- /foo/default.project.json - /foo/default.project.json
context: {} context:
emit_legacy_scripts: true
name: path-property-override name: path-property-override
class_name: StringValue class_name: StringValue
properties: properties:

View File

@@ -9,7 +9,8 @@ metadata:
Path: /foo.project.json Path: /foo.project.json
relevant_paths: relevant_paths:
- /foo.project.json - /foo.project.json
context: {} context:
emit_legacy_scripts: true
name: children name: children
class_name: Folder class_name: Folder
properties: {} properties: {}
@@ -24,7 +25,8 @@ children:
- $className: Model - $className: Model
- Folder - Folder
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
name: Child name: Child
class_name: Model class_name: Model
properties: {} properties: {}

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo/other.project.json - /foo/other.project.json
- /foo/default.project.json - /foo/default.project.json
context: {} context:
emit_legacy_scripts: true
name: path-project name: path-project
class_name: Model class_name: Model
properties: {} properties: {}

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo/other.project.json - /foo/other.project.json
- /foo/default.project.json - /foo/default.project.json
context: {} context:
emit_legacy_scripts: true
name: path-child-project name: path-child-project
class_name: Folder class_name: Folder
properties: {} properties: {}
@@ -25,7 +26,8 @@ children:
- $className: Model - $className: Model
- Folder - Folder
relevant_paths: [] relevant_paths: []
context: {} context:
emit_legacy_scripts: true
name: SomeChild name: SomeChild
class_name: Model class_name: Model
properties: {} properties: {}

View File

@@ -11,7 +11,8 @@ metadata:
- /foo/other.txt - /foo/other.txt
- /foo/other.meta.json - /foo/other.meta.json
- /foo/default.project.json - /foo/default.project.json
context: {} context:
emit_legacy_scripts: true
name: path-project name: path-project
class_name: StringValue class_name: StringValue
properties: properties:

View File

@@ -9,7 +9,8 @@ metadata:
Path: /foo.project.json Path: /foo.project.json
relevant_paths: relevant_paths:
- /foo.project.json - /foo.project.json
context: {} context:
emit_legacy_scripts: true
name: resolved-properties name: resolved-properties
class_name: StringValue class_name: StringValue
properties: properties:

View File

@@ -9,7 +9,8 @@ metadata:
Path: /foo.project.json Path: /foo.project.json
relevant_paths: relevant_paths:
- /foo.project.json - /foo.project.json
context: {} context:
emit_legacy_scripts: true
name: unresolved-properties name: unresolved-properties
class_name: StringValue class_name: StringValue
properties: properties:

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo.toml - /foo.toml
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: ModuleScript class_name: ModuleScript
properties: properties:

View File

@@ -10,7 +10,8 @@ metadata:
relevant_paths: relevant_paths:
- /foo.txt - /foo.txt
- /foo.meta.json - /foo.meta.json
context: {} context:
emit_legacy_scripts: true
name: foo name: foo
class_name: StringValue class_name: StringValue
properties: properties:

View File

@@ -41,3 +41,8 @@ where
.with_context(|| format!("Path did not end in {}: {}", suffix, path.display())) .with_context(|| format!("Path did not end in {}: {}", suffix, path.display()))
} }
} }
// TEMP function until rojo 8.0, when it can be replaced with bool::default (aka false)
pub fn emit_legacy_scripts_default() -> Option<bool> {
Some(true)
}

View File

@@ -44,6 +44,7 @@ gen_build_tests! {
json_model_legacy_name, json_model_legacy_name,
module_in_folder, module_in_folder,
module_init, module_init,
nested_runcontext,
optional, optional,
project_composed_default, project_composed_default,
project_composed_file, project_composed_file,

View File

@@ -1,6 +1,6 @@
use std::fs; use std::fs;
use insta::assert_yaml_snapshot; use insta::{assert_yaml_snapshot, with_settings};
use tempfile::tempdir; use tempfile::tempdir;
use crate::rojo_test::{internable::InternAndRedact, serve_util::run_serve_test}; use crate::rojo_test::{internable::InternAndRedact, serve_util::run_serve_test};
@@ -30,10 +30,12 @@ fn scripts() {
assert_yaml_snapshot!("scripts_info", redactions.redacted_yaml(info)); assert_yaml_snapshot!("scripts_info", redactions.redacted_yaml(info));
let read_response = session.get_api_read(root_id).unwrap(); let read_response = session.get_api_read(root_id).unwrap();
assert_yaml_snapshot!( with_settings!({ sort_maps => true }, {
"scripts_all", assert_yaml_snapshot!(
read_response.intern_and_redact(&mut redactions, root_id) "scripts_all",
); read_response.intern_and_redact(&mut redactions, root_id)
);
});
fs::write(session.path().join("src/foo.lua"), "Updated foo!").unwrap(); fs::write(session.path().join("src/foo.lua"), "Updated foo!").unwrap();
@@ -44,10 +46,12 @@ fn scripts() {
); );
let read_response = session.get_api_read(root_id).unwrap(); let read_response = session.get_api_read(root_id).unwrap();
assert_yaml_snapshot!( with_settings!({ sort_maps => true }, {
"scripts_all-2", assert_yaml_snapshot!(
read_response.intern_and_redact(&mut redactions, root_id) "scripts_all-2",
); read_response.intern_and_redact(&mut redactions, root_id)
);
});
}); });
} }