S&box Wiki

The Game Loop

Every Tick




Every Tick (60 times a second by default), the client will send a Command to the server. This command gets simulated. This means it takes the inputs from the command (ie, new ViewAngles) and applies them to the Pawn (ie, set rotation to ViewAngles)

While that's being sent to the server the Client also runs the same command locally. This is called Prediction. This allows inputs like walking, shooting and jumping to feel instant, with no ping delay.

After the client runs the command it stores all of the changed entity variables and when the result for that tick comes back from the server it compares them. If they're different then a prediction error happened.

Every Frame

These things are called every frame on the client.




Every frame we build our input. This converts input from your mouse, keyboard and controller into a Command that can be sent to the server on the next tick.

Within BuildInput you can use Input functions in order to manipulate input - for example, clearing buttons using Input.ClearButtons() - and in order to assign values to properties marked with [ClientInput].

This is done by passing a InputBuilder class down to the gamemode - which then passes it to the current camera and pawn. These callbacks are generally used to do things like change mouse movement into view angles.

You can override all of this behaviour in your Game class by overriding BuildInput.

Frame Simulate



Because Simulate only happens once every tick (60fps by default) and players may have monitors capable of showing framerates much higher than that, things like view direction are going to feel pretty choppy clientside. To get around that mismatch, FrameSimulate is called every clientside frame to give the game an opportunity to smooth out anything that would otherwise be stuttery or choppy.

This is commonly used to update things based on view direction (such as Pawn.AimRay).

It's important to realize that this is clientside only, so if you're setting something here then it needs to be updated in Simulate. If you can't comment out your FrameSimulate code and have the game work normally then you're doing something wrong.


You can also have your game code be triggered on events such as the tick event, allowing you to run logic server side independent of clients.

Wiki editors: I re-made the images on this page in Figma so they should be pretty easy for other people to edit when necessary. Here's the exported Figma file:

Please keep this up to date if you change anything on this page.