mirror of
https://github.com/rojo-rbx/rojo.git
synced 2026-04-25 07:06:12 +00:00
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:
@@ -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
|
||||||
|
|||||||
@@ -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>
|
||||||
@@ -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>
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
13
rojo-test/build-tests/nested_runcontext/default.project.json
Normal file
13
rojo-test/build-tests/nested_runcontext/default.project.json
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"name": "nested_runcontext",
|
||||||
|
"emitLegacyScripts": false,
|
||||||
|
"tree": {
|
||||||
|
"$className": "Folder",
|
||||||
|
"folder1": {
|
||||||
|
"$path": "folder1"
|
||||||
|
},
|
||||||
|
"folder2": {
|
||||||
|
"$path": "folder2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
{
|
||||||
|
"name": "nested_runcontext",
|
||||||
|
"emitLegacyScripts": true,
|
||||||
|
"tree": {
|
||||||
|
"$path": "folder3"
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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")]
|
||||||
|
|||||||
@@ -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)?;
|
||||||
|
|||||||
@@ -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()),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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: []
|
||||||
|
|
||||||
|
|||||||
@@ -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: []
|
||||||
|
|
||||||
|
|||||||
@@ -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: []
|
||||||
|
|
||||||
|
|||||||
@@ -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: []
|
||||||
|
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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"),
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -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.
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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:
|
||||||
@@ -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:
|
||||||
@@ -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:
|
||||||
@@ -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: []
|
||||||
@@ -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: []
|
||||||
@@ -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: []
|
||||||
@@ -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:
|
||||||
|
|||||||
@@ -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: []
|
||||||
|
|
||||||
@@ -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: []
|
||||||
|
|
||||||
@@ -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: []
|
||||||
|
|
||||||
@@ -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: []
|
||||||
|
|
||||||
@@ -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: []
|
||||||
|
|
||||||
@@ -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: []
|
||||||
|
|
||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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: {}
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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)
|
||||||
|
}
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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)
|
||||||
|
);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user