Skip to content

Commit

Permalink
catch some more schemas
Browse files Browse the repository at this point in the history
  • Loading branch information
alvrs committed Sep 14, 2023
1 parent 26df50f commit 4189c86
Show file tree
Hide file tree
Showing 18 changed files with 73 additions and 67 deletions.
2 changes: 1 addition & 1 deletion docs/pages/client-side.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ const config = mudConfig({
tables: {
NameComponent: "string",
PlayerComponent: "bool",
PositionComponent: { schema: { x: "int32", y: "int32" } },
PositionComponent: { valueSchema: { x: "int32", y: "int32" } },
},
});
```
Expand Down
2 changes: 1 addition & 1 deletion docs/pages/ecs.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ export default mudConfig({
tables: {
PlayerComponent: "bool",
PositionComponent: {
schema: { x: "int32", y: "int32" },
valueSchema: { x: "int32", y: "int32" },
},
NameComponent: "string",
DamageComponent: uint256,
Expand Down
9 changes: 4 additions & 5 deletions docs/pages/quick-start.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ export default mudConfig({
tables: {
Counter: {
keySchema: {},
schema: "uint32",
valueSchema: "uint32",
},
},
});
Expand Down Expand Up @@ -117,7 +117,7 @@ contract IncrementSystem is System {
}
```

The increment system is able to import `Counter` (from its autogenerated table schema) and operate on it by increasing its value by one.
The increment system is able to import `Counter` (from its autogenerated table library) and operate on it by increasing its value by one.

Each system can contain any number of methods, though this system only has the single method—`increment`. These methods can then be called in the client to execute them in a transaction.

Expand All @@ -127,7 +127,6 @@ The client package will vary depending on which template used (vanilla, react, p

- You can adjust `createClientComponents.ts` to either override contract components or add client-only components.
- If you are using chains other than foundry/anvil and lattice testnet, you can add them in `getNetworkConfig.ts`
- `createSystemCalls` represents how the client talks to the system contracts via our `worldSend` helper
- `setup.ts`

Beyond these files you can concern yourself simply with building out the frontend of the client.
Expand All @@ -136,13 +135,13 @@ Beyond these files you can concern yourself simply with building out the fronten

Now that you’re familiar with the basic structure of the client package, let’s go over how you can call on systems from the contracts package.

The starter project comes with `IncrementSystem.sol`—you can see it being called in `index.ts` (or `index.tsx` in the react template).
The starter project comes with `IncrementSystem.sol`—you can see it being called in `index.ts` (or `App.tsx` in the react template).

```tsx
// Just for demonstration purposes: we create a global function that can be
// called to invoke the Increment system contract via the world. (See IncrementSystem.sol.)
(window as any).increment = async () => {
const tx = await worldSend("increment", []);
const tx = await worldContract.write.increment();

console.log("increment tx", tx);
console.log("increment result", await tx.wait());
Expand Down
12 changes: 6 additions & 6 deletions docs/pages/store/advanced-features.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export default mudConfig({
tables: {
CounterSingleton: {
keySchema: {},
schema: "uint256",
valueSchema: "uint256",
},
},
});
Expand Down Expand Up @@ -48,7 +48,7 @@ import { mudConfig } from "@latticexyz/store/register";
export default mudConfig({
tables: {
TradeExecuted: {
schema: {
valueSchema: {
amount: "uint32",
receiver: "bytes32",
},
Expand Down Expand Up @@ -84,8 +84,8 @@ uint256 constant indexerTableId = uint256(keccak256("indexer.table"));
contract MirrorSubscriber is IStoreHook {
uint256 _table;
constructor(uint256 table, Schema schema, Schema keySchema) {
IStore(msg.sender).registerSchema(indexerTableId, schema, keySchema);
constructor(uint256 table, Schema keySchema, Schema valueSchema) {
IStore(msg.sender).registerSchema(indexerTableId, valueSchema, keySchema);
_table = table;
}
Expand All @@ -110,9 +110,9 @@ Registering the hook can be done using the low-level Store API:

```solidity
uint256 table = keccak256("table");
Schema schema = SchemaLib.encode(SchemaType.UINT256, SchemaType.UINT256);
Schema valueSchema = SchemaLib.encode(SchemaType.UINT256, SchemaType.UINT256);
Schema keySchema = SchemaLib.encode(SchemaType.UINT256);
MirrorSubscriber subscriber = new MirrorSubscriber(table, schema, keySchema);
MirrorSubscriber subscriber = new MirrorSubscriber(table, keySchema, valueSchema);
StoreCore.registerStoreHook(table, subscriber);
```

Expand Down
12 changes: 6 additions & 6 deletions docs/pages/store/config.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ import { mudConfig } from "@latticexyz/store/register";
export default mudConfig({
tables: {
MyTable: {
schema: {
valueSchema: {
value: "uint32",
},
},
Expand All @@ -62,7 +62,7 @@ The table configuration can have these properties:

**`fileSelector` (optional)** _only used with the World framework_: a `string`: where to create the table in the namespace.

**`tableIdArgument` (optional)**: `bool`: whether to create getter and setter functions with the table ID as an argument, this is used to generate a single library to operate on multiple tables with the same schema and key structure.
**`tableIdArgument` (optional)**: `bool`: whether to create getter and setter functions with the table ID as an argument, this is used to generate a single library to operate on multiple tables with the same key and value structure.

**`storeArgument` (optional)**: `bool`: whether to create getter and setter functions with the store address as an argument, this is used to generate a single library to operate on the same table in multiple stores. This adds new functions to the library, doubling the amount of functions created (each getter/setter will comes in a pair of “with `storeArgument`” and “without `storeArgument`”)

Expand All @@ -86,7 +86,7 @@ Example:
```tsx
tables: {
MyTableWithTwoKeys: {
schema: {
valueSchema: {
value1: "uint32",
value2: "uint32",
},
Expand All @@ -98,14 +98,14 @@ tables: {
}
```

**`schema` (required)**: an object with keys being the column name, and value being types from `SchemaType`
**`valueSchema` (required)**: an object with keys being the column name, and value being types from `SchemaType`

Example:

```tsx
tables: {
MyTableWithFourValues: {
schema: {
valueSchema: {
x: "uint32",
y: "uint32",
stringField: "string",
Expand Down Expand Up @@ -135,7 +135,7 @@ Example:
```tsx
tables: {
MySingletonTable: {
schema: {
valueSchema: {
value1: "uint32",
value2: "uint32",
},
Expand Down
8 changes: 4 additions & 4 deletions docs/pages/store/reading-and-writing.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ This section assumes the existence of “MyTable” as described with the config
// definition of MyTable
tables: {
MyTable: {
schema: {
valueSchema: {
foo: "uint256",
bar: "bool",
fooArray: "uint256[]", // Store supports dynamic arrays
Expand Down Expand Up @@ -106,7 +106,7 @@ This section assumes the existence of “MyTable” as described with the config
// definition of MyTable
tables: {
MyTable: {
schema: {
valueSchema: {
foo: "uint256",
bar: "bool",
},
Expand Down Expand Up @@ -147,8 +147,8 @@ uint256 tableId = uint256(keccak256("MyTable"));
bytes32[] memory key = new bytes32[](1);
key[0] = keccak256("some.key");
// Retrieve a record
Schema schema = SchemaLib.encode(SchemaType.UINT256, SchemaType.UINT256);
bytes memory loadedData = StoreCore.getRecord(tableId, key, schema);
Schema valueSchema = SchemaLib.encode(SchemaType.UINT256, SchemaType.UINT256);
bytes memory loadedData = StoreCore.getRecord(tableId, key, valueSchema);
uint256 foo = (uint256(Bytes.slice4(loadedData, 0)));
uint256 bar = (uint256(Bytes.slice4(loadedData, 32)));
```
Expand Down
19 changes: 13 additions & 6 deletions docs/pages/store/using-without-world.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ import { mudConfig } from "@latticexyz/store/register";
export default mudConfig({
tables: {
MyTable: {
schema: {
valueSchema: {
field1: "uint256",
field2: "uint256",
},
Expand Down Expand Up @@ -78,18 +78,25 @@ contract Contract is Store {
```solidity
import { Store } from "@latticexyz/store/src/Store.sol";
import { StoreCore } from "@latticexyz/store/src/StoreCore.sol";
import { Schema, SchemaLib } from "@latticexyz/store/src/Schema.sol";
import { FieldLayout, FieldLayoutLib } from "@latticexyz/store/src/FieldLayout.sol";
contract Contract is Store {
constructor() {
bytes32 tableId = bytes32("MyTable");
FieldLayout fieldLayout = FieldLayoutLib.encode(32, 32);
Schema keySchema = SchemaLib.encode(SchemaType.UINT256);
Schema schema = SchemaLib.encode(SchemaType.UINT256, SchemaType.UINT256);
uint256 table = uint256(keccak256("MyTable"));
StoreCore.registerSchema(table, schema, keySchema);
// Setting metadata is optional. It helps off-chain actors name columns
Schema valueSchema = SchemaLib.encode(SchemaType.UINT256, SchemaType.UINT256);
string[] memory keyNames = new string[](1);
keyNames[0] = "field1";
string[] memory fieldNames = new string[](2);
fieldNames[0] = "field1";
fieldNames[1] = "field2";
StoreSwitch.setMetadata(table, "MyTable", fieldNames);
StoreCore.registerTable(tableId, fieldLayout, keySchema, valueSchema, keyNames, fieldNames);
}
}
```
20 changes: 10 additions & 10 deletions docs/pages/tutorials/emojimon/a-wild-emojimon-appears.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ export default mudConfig({
keySchema: {
player: "bytes32",
},
schema: {
valueSchema: {
exists: "bool",
monster: "bytes32",
catchAttempts: "uint256",
Expand All @@ -57,7 +57,7 @@ export default mudConfig({
MapConfig: {
keySchema: {},
dataStruct: false,
schema: {
valueSchema: {
width: "uint32",
height: "uint32",
terrain: "bytes",
Expand All @@ -68,7 +68,7 @@ export default mudConfig({
Player: "bool",
Position: {
dataStruct: false,
schema: {
valueSchema: {
x: "uint32",
y: "uint32",
},
Expand Down Expand Up @@ -523,7 +523,7 @@ export default mudConfig({
keySchema: {
player: "bytes32",
},
schema: {
valueSchema: {
exists: "bool",
monster: "bytes32",
catchAttempts: "uint256",
Expand All @@ -534,7 +534,7 @@ export default mudConfig({
MapConfig: {
keySchema: {},
dataStruct: false,
schema: {
valueSchema: {
width: "uint32",
height: "uint32",
terrain: "bytes",
Expand All @@ -546,7 +546,7 @@ export default mudConfig({
Player: "bool",
Position: {
dataStruct: false,
schema: {
valueSchema: {
x: "uint32",
y: "uint32",
},
Expand Down Expand Up @@ -749,7 +749,7 @@ export default mudConfig({
keySchema: {
player: "bytes32",
},
schema: {
valueSchema: {
exists: "bool",
monster: "bytes32",
catchAttempts: "uint256",
Expand All @@ -760,7 +760,7 @@ export default mudConfig({
MapConfig: {
keySchema: {},
dataStruct: false,
schema: {
valueSchema: {
width: "uint32",
height: "uint32",
terrain: "bytes",
Expand All @@ -772,7 +772,7 @@ export default mudConfig({
keySchema: {
encounter: "bytes32",
},
schema: {
valueSchema: {
result: "MonsterCatchResult",
},
},
Expand All @@ -783,7 +783,7 @@ export default mudConfig({
Player: "bool",
Position: {
dataStruct: false,
schema: {
valueSchema: {
x: "uint32",
y: "uint32",
},
Expand Down
8 changes: 4 additions & 4 deletions docs/pages/tutorials/emojimon/map-and-terrain.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ export default mudConfig({
MapConfig: {
keySchema: {},
dataStruct: false,
schema: {
valueSchema: {
width: "uint32",
height: "uint32",
terrain: "bytes",
Expand All @@ -37,7 +37,7 @@ export default mudConfig({
Player: "bool",
Position: {
dataStruct: false,
schema: {
valueSchema: {
x: "uint32",
y: "uint32",
},
Expand Down Expand Up @@ -205,7 +205,7 @@ export default mudConfig({
MapConfig: {
keySchema: {},
dataStruct: false,
schema: {
valueSchema: {
width: "uint32",
height: "uint32",
terrain: "bytes",
Expand All @@ -216,7 +216,7 @@ export default mudConfig({
Player: "bool",
Position: {
dataStruct: false,
schema: {
valueSchema: {
x: "uint32",
y: "uint32",
},
Expand Down
4 changes: 2 additions & 2 deletions docs/pages/tutorials/emojimon/players-and-movement.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ We're going to start by defining three new tables:

1. `Player: 'bool'` → determine which entities are players (e.g. distinct wallet addresses)
2. `Movable: 'bool'` → determine whether or not an entity can move
3. `Position: { schema: { x: 'uint32', y: 'uint32' } }` → determine which position an entity is located on a 2D grid
3. `Position: { valueSchema: { x: 'uint32', y: 'uint32' } }` → determine which position an entity is located on a 2D grid

The syntax is as follows:

Expand All @@ -34,7 +34,7 @@ export default mudConfig({
Player: "bool",
Position: {
dataStruct: false,
schema: {
valueSchema: {
x: "uint32",
y: "uint32",
},
Expand Down
6 changes: 3 additions & 3 deletions docs/pages/tutorials/minimal/add-table.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,13 @@ For the sake of simplicity, we will implement this in the `increment` function r
tables: {
Counter: {
keySchema: {},
schema: "uint32",
valueSchema: "uint32",
},
History: {
keySchema: {
counterValue: "uint32",
},
schema: {
valueSchema: {
blockNumber: "uint256",
time: "uint256",
},
Expand All @@ -45,7 +45,7 @@ For the sake of simplicity, we will implement this in the `increment` function r
A MUD table has two schemas:

- `keySchema`, the key used to find entries
- `schema`, the value in the entry (soon to be renamed to `valueSchema`)
- `valueSchema`, the value in the entry

Each schema is represented as a structure with field names as keys, and the appropriate [Solidity data types](https://docs.soliditylang.org/en/latest/types.html) as their values.

Expand Down
Loading

0 comments on commit 4189c86

Please sign in to comment.