From 7bd9288d29fcca6ee766d8f41224facd507525c1 Mon Sep 17 00:00:00 2001 From: hoontee Date: Mon, 11 Nov 2024 22:25:51 -0600 Subject: [PATCH] Update README.md --- README.md | 77 +++++++++++++++++++++++++++++-------------------------- 1 file changed, 41 insertions(+), 36 deletions(-) diff --git a/README.md b/README.md index 520e30b..ca9a421 100644 --- a/README.md +++ b/README.md @@ -29,7 +29,7 @@ No Controllers or Services, just Modules and Remotes. # Core Module Functions ## Remotes -```lua +```luau -- Creation local exampleRemote = Remotes.Server:CreateToClient(name: string, requiredParameterTypes: {string}, remoteType: ("Unreliable" | "Reliable" | "Returns")?): any local exampleRemote = Remotes.Server:CreateToServer(name: string, requiredParameterTypes: {string}, remoteType: ("Unreliable" | "Reliable" | "Returns")?, func: (Player, ...any) -> (...any)?): any @@ -54,16 +54,16 @@ exampleRemote:Fire(...) ``` ## Debug -```lua +```luau Print(...) Warn(...) Trace(...) ``` ## New -```lua +```luau New.Instance(className: string, parent: Instance?, name: string?, properties: {[string]: any, children: {Instance}?, attributes: {[string]: any}?, tags: {string}?}?): Instance -New.Clone(instance: Instance?, parent: Instance?, name: string?, properties: {[string]: any, children: {Instance}?, attributes: {[string]: any}?, tags: {string}?}?): +New.Clone(instance: T, parent: Instance?, name: string?, properties: {[string]: any, children: {Instance}?, attributes: {[string]: any}?, tags: {string}?}?): T -- New.Instance / New.Clone -- Parent, Name, and Properties optional parameters can be provided in any combination and order. -- Ex. New.Instance("Part", {Properties}) @@ -72,34 +72,39 @@ New.Clone(instance: Instance?, parent: Instance?, name: string?, properties: {[s -- Can contain an "Attributes" key with type {[string]: any}. -- Can contain a "Tags" key with type {string}. -- RBXScriptSignal properties (e.g. "Changed") can be assigned a function. -New.Event(): { - Fire: (self: any, ...any) -> (); - Connect: (self: any, callback: Callback) -> ({Disconnect: (self: any) -> ()}); - Once: (self: any, callback: Callback) -> ({Disconnect: (self: any) -> ()}); - Wait: (self: any) -> (any); - DisconnectAll: (self: any) -> (); +New.Event(): Event = { + Fire: (self: Event, T...) -> (); + Connect: (self: Event, callback: Callback) -> (Connection); + Once: (self: Event, callback: Callback) -> (Connection); + Wait: (self: Event, timeout: number?) -> (T...); + DisconnectAll: (self: Event) -> (); } -New.QueuedEvent(): { - Fire: (self: any, ...any) -> (); - Connect: (self: any, callback: Callback) -> ({Disconnect: (self: any) -> ()}); - Once: (self: any, callback: Callback) -> ({Disconnect: (self: any) -> ()}); - Wait: (self: any) -> (any); - DisconnectAll: (self: any) -> (); +New.QueuedEvent(): Event = { + Fire: (self: Event, T...) -> (); + Connect: (self: Event, callback: Callback) -> (Connection); + Once: (self: Event, callback: Callback) -> (Connection); + Wait: (self: Event, timeout: number?) -> (T...); + DisconnectAll: (self: Event) -> (); } -New.TrackedVariable(Variable: any): { - Get: (self: any) -> (any); - Set: (self: any, value: any) -> (); - Connect: (self: any, callback: Callback) -> ({Disconnect: (self: any) -> ()}); - Once: (self: any, callback: Callback) -> ({Disconnect: (self: any) -> ()}); - Wait: (self: any) -> (any); - DisconnectAll: (self: any) -> (); +New.TrackedVariable(variable: any): TrackedVariable = { + Get: (self: TrackedVariable) -> (T); + Set: (self: TrackedVariable, value: T) -> (); + Connect: (self: TrackedVariable, callback: Callback) -> (Connection); + Once: (self: TrackedVariable, callback: Callback) -> (Connection); + Wait: (self: TrackedVariable) -> (T, T) & (self: TrackedVariable, timeout: number) -> (T?, T?); + DisconnectAll: (self: TrackedVariable) -> (); +} +New.InstanceStream(): InstanceStream = { + Instances: {Instance}; + Start: (self: InstanceStream, players: Player | {Player}, instances: {Instance}) -> (string); + Listen: (self: InstanceStream, uid: string) -> (Event, Event); } ``` # Code Snippets ## Script Boilerplate -```lua +```luau local Pronghorn = require(game:GetService("ReplicatedStorage").Pronghorn) Pronghorn:SetEnabledChannels({ Remotes = false; @@ -116,7 +121,7 @@ Pronghorn:Import({ ``` ## Module Boilerplate -```lua +```luau local ExampleModule = {} -- Services @@ -140,50 +145,50 @@ return ExampleModule ``` ## Automated Module Functions -```lua -function ExampleModule:Init() +```luau +function ExampleModule:Init(): () -- Runs after all modules are imported. Cannot yield. end -function ExampleModule:Deferred() +function ExampleModule:Deferred(): () -- Runs after all modules have initialized. end -function ExampleModule.PlayerAdded(player: Player) +function ExampleModule.PlayerAdded(player: Player): () -- Players.PlayerAdded shortcut. end -function ExampleModule.PlayerAddedDeferred(player: Player) +function ExampleModule.PlayerAddedDeferred(player: Player): () -- Players.PlayerAdded shortcut. Runs after all PlayerAdded functions. end -function ExampleModule.PlayerRemoving(player: Player) +function ExampleModule.PlayerRemoving(player: Player): () -- Players.PlayerRemoving shortcut. end -function ExampleModule.PlayerRemovingDeferred(player: Player) +function ExampleModule.PlayerRemovingDeferred(player: Player): () -- Players.PlayerRemoving shortcut. Runs after all PlayerRemoving functions. end ``` ## Creating and Invoking a Remote -```lua +```luau -- On Server local tableCounted = Remotes.Server:CreateToClient("TableCounted", {"string"}) -- Second parameter is nil, so this Remote is non-returning. -Remotes.Server:CreateToServer("CountTable", {"table"}, "Returns", function(player: Player, tableToCount: {any}) +Remotes.Server:CreateToServer("CountTable", {"table"}, "Returns", function(player: Player, tableToCount: {any}): () Remotes.Server.ExampleServerModule.TableCounted:FireAll(player.Name) -- Absolute method tableCounted:FireAll(player.Name) -- Shortcut method return #tableToCount end) -- Second parameter is true, so this Remote returns. ``` -```lua +```luau -- On Client -function ExampleClientModule:Deferred() +function ExampleClientModule:Deferred(): () Remotes.Client.ExampleServerModule.TableCounted:Connect(function(playerName: string) Print(playerName, "requested a Table to be counted.") end)