Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(world): enable config namespaces key #2880

Closed
wants to merge 77 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
77 commits
Select commit Hold shift + click to select a range
fad51ed
fix(world): namespaces table key must be a valid tables config
yonadaa May 30, 2024
b4c3d30
feat(world): enable namespaces key
yonadaa May 30, 2024
1f45e31
feat: default namespaceDirectories
yonadaa May 30, 2024
7bd6dd7
fix: check if world.namespaces is defined
yonadaa May 30, 2024
d2f2aec
fix: output directory for namespaces
yonadaa May 30, 2024
3002556
fix: types
yonadaa May 30, 2024
42ea56b
refactor: do not mutate input object
yonadaa May 31, 2024
7257b96
fix: codegen default
yonadaa May 31, 2024
2e99abb
fix: better error
yonadaa May 31, 2024
97838a1
refactor: indexFilename can be false
yonadaa May 31, 2024
1bedd85
chore: minimal example has no index
yonadaa May 31, 2024
9b884d4
chore: example with codegen set
yonadaa May 31, 2024
e9e3880
refactor: resolvedStore suggestion
yonadaa May 31, 2024
75a7726
chore: move example
yonadaa May 31, 2024
fa16add
chore: reset example
yonadaa May 31, 2024
50df7bb
chore: build
yonadaa May 31, 2024
6e0189a
chore: delete changelog
yonadaa May 31, 2024
589c386
fix: package name
yonadaa May 31, 2024
ffa7dc5
fix: types
yonadaa May 31, 2024
6ce578e
chore: change test namespace
yonadaa May 31, 2024
348d43e
fix: do not default namespaces key when resolving with shorthand
yonadaa Jun 4, 2024
c6d8f1a
refactor: if statement
yonadaa Jun 4, 2024
ff619ab
chore: changeset
yonadaa Jun 4, 2024
c7e2559
feat: move example project
yonadaa Jun 4, 2024
1d9866e
chore: remove unused interface
yonadaa Jun 4, 2024
6d52753
chore: multiple namespaces in example
yonadaa Jun 4, 2024
819b9fc
refactor: dashes in key name
yonadaa Jun 4, 2024
5f0df8a
chore: systems in example
yonadaa Jun 4, 2024
4dd7a43
refactor: empty string
yonadaa Jun 4, 2024
0483ce3
refactor: do not rely on codegenIndexFilename
yonadaa Jun 4, 2024
0a7e500
refactor: remove codegenIndexFilename
yonadaa Jun 4, 2024
09bc274
test: attempt to fix world test
yonadaa Jun 4, 2024
625cbaf
fix: use generic types
yonadaa Jun 4, 2024
87f0dc2
fix: test outputDirectory
yonadaa Jun 4, 2024
f73355b
Merge remote-tracking branch 'origin/main' into yonadaaa/fix-tables-w…
yonadaa Jun 5, 2024
0d1c6ac
test: remove test object
yonadaa Jun 5, 2024
2f196e2
Merge remote-tracking branch 'origin/main' into yonadaaa/fix-tables-w…
yonadaa Jun 5, 2024
5a07319
chore: update example
yonadaa Jun 5, 2024
463f6cd
Merge remote-tracking branch 'origin/main' into yonadaaa/fix-tables-w…
yonadaa Jun 5, 2024
fb7fe89
chore: fix files
yonadaa Jun 5, 2024
c3fa203
Merge remote-tracking branch 'origin/main' into yonadaaa/fix-tables-w…
yonadaa Jun 5, 2024
a5aed4d
fix: add back workspace file
yonadaa Jun 5, 2024
0138900
chore: delete weird file
yonadaa Jun 5, 2024
15505f1
chore: build
yonadaa Jun 5, 2024
74c443b
feat: throw error if using both keys
yonadaa Jun 5, 2024
6ac5968
feat(world): can only use namespace or namespaces
yonadaa Jun 5, 2024
ca20438
test: delete unused test
yonadaa Jun 5, 2024
7a5e93f
chore: add example to changest
yonadaa Jun 6, 2024
adbe5fc
test: add test for both keys
yonadaa Jun 6, 2024
fef3ceb
feat: updated example
yonadaa Jun 6, 2024
d191134
chore: update example
yonadaa Jun 6, 2024
869a120
chore: comment
yonadaa Jun 6, 2024
2b05ec2
test: fix test
yonadaa Jun 6, 2024
5bd192b
refactor: address constant
yonadaa Jun 6, 2024
ac2db03
chore: remove comment
yonadaa Jun 6, 2024
68f841b
chore: review changeset suggestion
yonadaa Jun 6, 2024
9fb7199
chore: change comment
yonadaa Jun 6, 2024
9946bbb
fix: update runtime error
yonadaa Jun 6, 2024
d70361e
test: fix runtime message
yonadaa Jun 6, 2024
8e74ffe
Merge remote-tracking branch 'origin/main' into yonadaaa/fix-tables-w…
yonadaa Jun 6, 2024
7fdd67c
chore: remove store from changeset
yonadaa Jun 6, 2024
b9432a6
feat: deprecate index.sol
yonadaa Jun 6, 2024
c8e150d
fix: remove index filename from defaults
yonadaa Jun 6, 2024
1fa222d
fix: deprecate comment
yonadaa Jun 6, 2024
ea18aaa
refactor: rename plugin namespace
yonadaa Jun 6, 2024
7304d47
chore: remove access control example
yonadaa Jun 6, 2024
3d18325
chore: changeset namespace
yonadaa Jun 7, 2024
8130d10
chore: do not deprecate excludeSystems yet
yonadaa Jun 7, 2024
76c7fa3
chore: add "revisit pattern" comment
yonadaa Jun 7, 2024
856a6aa
chore: remove todo comment
yonadaa Jun 7, 2024
e43978c
fix: better error messages
yonadaa Jun 7, 2024
fb0a63e
chore: revisit this pattern comment
yonadaa Jun 7, 2024
1bc9ea2
chore: prettier
yonadaa Jun 7, 2024
de03bae
fix: check if tables or systems is set with namespaces
yonadaa Jun 7, 2024
50738f5
fix: check with shorthands
yonadaa Jun 7, 2024
a93cec6
Merge remote-tracking branch 'origin/main' into yonadaaa/fix-tables-w…
holic Jul 2, 2024
7ed17b9
wip
holic Jul 3, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
44 changes: 44 additions & 0 deletions .changeset/violet-flowers-poke.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
---
"@latticexyz/world": patch
---

You can now configure resources (tables, systems, etc.) across multiple namespaces in a single MUD config using the `namespaces` option.

Note that once you start using `namespaces` config option, you will need to move your existing tables, systems, etc. under the corresponding namespace within `namespaces`.

```ts
export default defineWorld({
namespaces: {
game: {
tables: {
Health: {
schema: {
player: "address",
value: "uint32",
},
key: ["player"],
},
Position: {
schema: {
player: "address",
x: "int32",
y: "int32",
},
key: ["player"],
},
},
},
scoreboard: {
tables: {
Score: {
schema: {
player: "address",
value: "uint256",
},
key: ["player"],
},
},
},
},
});
```
58 changes: 44 additions & 14 deletions examples/multiple-namespaces/mud.config.ts
Original file line number Diff line number Diff line change
@@ -1,23 +1,53 @@
import { defineWorld } from "@latticexyz/world";

export default defineWorld({
namespace: "game",
codegen: { namespaceDirectories: true },
tables: {
Health: {
schema: {
player: "address",
value: "uint32",
namespaces: {
game: {
tables: {
Position: {
schema: {
player: "address",
x: "int32",
y: "int32",
},
key: ["player"],
},
Victory: {
schema: {
value: "bool",
},
key: [],
},
},
key: ["player"],
},
Position: {
schema: {
player: "address",
x: "int32",
y: "int32",
scoreboard: {
tables: {
Score: {
schema: {
player: "address",
score: "uint256",
},
key: ["player"],
},
},
},
gameFork: {
holic marked this conversation as resolved.
Show resolved Hide resolved
tables: {
Position: {
schema: {
player: "address",
x: "int32",
y: "int32",
},
key: ["player"],
},
Victory: {
schema: {
value: "bool",
},
key: [],
},
},
key: ["player"],
},
},
});
7 changes: 0 additions & 7 deletions examples/multiple-namespaces/src/codegen/index.sol

This file was deleted.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

5 changes: 3 additions & 2 deletions examples/multiple-namespaces/src/codegen/world/IWorld.sol

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
// SPDX-License-Identifier: MIT
pragma solidity >=0.8.24;
import { System } from "@latticexyz/world/src/System.sol";
import { Position } from "../codegen/game/tables/Position.sol";
import { Position } from "./codegen/tables/Position.sol";

contract MoveSystem is System {
function move(address player, int32 x, int32 y) public {
function move(int32 x, int32 y) public {
address player = _msgSender();
Position.set(player, x, y);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
// SPDX-License-Identifier: MIT
pragma solidity >=0.8.24;
import { System } from "@latticexyz/world/src/System.sol";
import { Victory } from "./codegen/tables/Victory.sol";

contract VictorySystem is System {
function win() public {
Victory.set(true);
}
}

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading
Loading