RLS Studios
ProjectsPatreonCommunityDocsAbout
Join Patreon
BeamNG Modding Docs

Guides

Reference

Server CommandsGE UtilitiesGame Engine MainNavigation GraphScreenshot CaptureServerServer ConnectionSpawnpoint ManagerSimulation TimeVehicle SpawningSuspension Frequency Tester
Editor AI TestsEditor AI VisualizationEditor – Assembly Spline ToolAsset BrowserAsset DeduplicatorAsset Management ToolSFX Previewer (Audio Events List)Audio Ribbon EditorAutoSaveBarriers EditorBiome ToolBuilding EditorBulk RenameCamera BookmarksCamera TransformCamera Path EditorCEF HelperCo-Simulation Signal EditorCrawl Data EditorCreate Object ToolDataBlock EditorDecal EditorDecal Spline EditorDocumentation HelperDrag Race EditorDrift Data EditorDrive Path EditorDynamic Decals Tool (Vehicle Livery Creator)Engine Audio DebugExtensions DebugExtensions EditorFFI Pointer Leak TestFile DialogFlowgraph EditorForest EditorForest ViewEditor Gizmo HelperEditor Ground Model Debug HelperEditor Headless Editor TestEditor Icon OverviewEditor ImGui C DemoEditor InspectorEditor Layout ManagerEditor Level SettingsEditor Level ValidatorEditor LoggerEditor Log HelperEditor MainEditor Main MenuEditor Main ToolbarEditor Main UpdateMap Sensor EditorMaster Spline EditorMaterial EditorMeasures Inspector HeaderMesh Editor (Base)Mesh Road EditorMesh Spline EditorMission EditorMission PlaybookMission Start Position EditorMulti Spawn Manager (Vehicle Groups)Navigation Mesh EditorEditor News MessageObject Tool (Object Select Edit Mode)Object To Spline EditorParticle EditorPerformance Profiler / Camera RecorderPhysics ReloaderPrefab Instance EditorEditor PreferencesRace / Path EditorRally EditorRaycast Test Editor ToolRenderer Components Editor ToolRender Test Editor ToolResource Checker Editor ToolRiver EditorRoad Architect EditorRoad DecorationsRoad Editor (Decal Road)Road Network ExporterRoad River Cache HandlerRoad River GUIRoad Spline EditorRoad Template EditorRoad UtilitiesScene TreeScene ViewScreenshot Creator BootstrapScript AI EditorScript AI ManagerSensor Configuration EditorSensor DebuggerShape EditorShortcut LegendSidewalk Spline EditorSites EditorSlot Traffic EditorSuspension Audio DebugTech Server ManagerTerraform ToolTerrain And Road ImporterTerrain EditorTerrain Materials EditorText EditorTool ManagerTool ShortcutsTraffic DebugTraffic ManagerTraffic Signals EditorUndo History ViewerVehicle Bridge TestVehicle Detail ViewerVehicle Editor MainEditor - VisualizationEditor Viz HelperEditor Water Object HelperEditor Windows Manager
Sidewalk Spline KitSidewalk Spline PopulateSidewalk Spline Manager

UI

Resources

BeamNG Game Engine Lua Cheat SheetGE Developer RecipesMCP Server Setup

// RLS.STUDIOS=true

Premium Mods for BeamNG.drive. Career systems, custom vehicles, and immersive gameplay experiences.

Index

HomeProjectsPatreon

Socials

DiscordPatreon (RLS)Patreon (Vehicles)

© 2026 RLS Studios. All rights reserved.

Modding since 2024

API ReferenceGE ExtensionseditorsidewalkSpline

Sidewalk Spline Manager

Manages sidewalk spline data structures, including creation, removal, splitting, joining, undo/redo, profile copy/paste, and serialization. Works with `kit`, `populate`, and `geom` submodules.

Manages sidewalk spline data structures, including creation, removal, splitting, joining, undo/redo, profile copy/paste, and serialization. Works with kit, populate, and geom submodules.


Public Functions

FunctionDescription
M.getToolPrefixStr()Returns the tool prefix string 'Sidewalk Spline'
M.getEditModeKey()Returns the edit mode key 'sidewalkSplineEditMode'
M.getSidewalkSplines()Returns the array of all sidewalk splines
M.getSplineMap()Returns the spline id-to-index map
M.setSidewalkSpline(spline, idx)Sets a spline at the given index with scene tree folder
M.setSidewalkSplines(splines)Replaces the entire spline collection
M.getDefaultSliderParams()Returns default UI slider parameters
M.addNewSidewalkSpline()Creates a new empty sidewalk spline with scene tree folder
M.removeSidewalkSpline(idx)Removes a spline at the given index and cleans up scene tree
M.removeAllSidewalkSplines(isIncludeDisabled)Removes all (or just enabled) splines
M.deepCopySidewalkSpline(spline)Deep copies a single spline (clears secondary geometry)
M.deepCopySidewalkSplineState()Deep copies the full collection of splines
M.splitSidewalkSpline(splineIdx, nodeIdx)Splits a spline at a node into two splines A and B
M.joinSidewalkSplines(splineIdx1, nodeIdx1, splineIdx2, nodeIdx2)Joins two unlooped splines into one
M.singleSplineEditUndo(data)Undo callback for single-spline edits
M.singleSplineEditRedo(data)Redo callback for single-spline edits
M.transSplineEditUndo(data)Undo callback for trans-spline edits (full replace)
M.transSplineEditRedo(data)Redo callback for trans-spline edits (full replace)
M.objectSelectUndo(data)Undo callback for object select operations
M.objectSelectRedo(data)Redo callback for object select operations
M.copySidewalkSplineProfile(spline)Copies spline profile settings to clipboard
M.pasteSidewalkSplineProfile(spline)Pastes clipboard profile settings onto a spline
M.hasCopiedProfile()Returns true if a profile is copied
M.copyProfileTemplate(spline)Copies profile template data for serialization
M.pasteProfileTemplate(spline, templateData)Pastes profile template data onto a spline
M.serializeSidewalkSpline(spline)Serializes a sidewalk spline using string.buffer
M.deserializeSidewalkSpline(data, isFromFile)Deserializes a spline, reloads kit, creates folder
M.updateDirtySidewalkSplines()Updates geometry and meshes of any dirty splines

Example: Creating, Populating, and Managing Splines

local splineMgr = require('editor/sidewalkSpline/splineMgr')

-- Create a new sidewalk spline
splineMgr.addNewSidewalkSpline()
local splines = splineMgr.getSidewalkSplines()
local spline = splines[#splines]

-- Add nodes to the spline (external code sets spline.nodes, widths, nmls)
spline.nodes = { vec3(0, 0, 0), vec3(10, 0, 0), vec3(20, 5, 0) }
spline.widths = { 2.0, 2.0, 2.0 }
spline.nmls = { vec3(0, 0, 1), vec3(0, 0, 1), vec3(0, 0, 1) }
spline.isDirty = true

-- Update all dirty splines (recomputes geometry and populates meshes)
splineMgr.updateDirtySidewalkSplines()

-- Deep copy a spline for undo state
local backup = splineMgr.deepCopySidewalkSpline(spline)

-- Split a spline at node 2 into two halves
splineMgr.splitSidewalkSpline(1, 2)

-- Copy and paste profile between splines
splineMgr.copySidewalkSplineProfile(splines[1])
if splineMgr.hasCopiedProfile() then
  splineMgr.pasteSidewalkSplineProfile(splines[2])
end

-- Serialize for save/load
local data = splineMgr.serializeSidewalkSpline(spline)
local restored = splineMgr.deserializeSidewalkSpline(data, true)

-- Remove a spline
splineMgr.removeSidewalkSpline(1)

-- Remove all splines (including disabled)
splineMgr.removeAllSidewalkSplines(true)

-- Get default slider parameters for UI
local params = splineMgr.getDefaultSliderParams()
-- params.verticalOffset, params.jitterAmount, params.alignmentWeight, params.splineRandomSeed

Spline Data Structure

Each spline contains:

  • name, id, isLoop, isEnabled, isDirty
  • nodes, widths, nmls - primary geometry
  • divPoints, divWidths, tangents, binormals, normals - secondary (computed) geometry
  • verticalOffset, jitterAmount, alignmentWeight, splineRandomSeed
  • kitFolderPath, meshKit, kitDescription, pieceEnabledStates
  • sceneTreeFolderId - SimGroup folder in scene tree

Functions

singleSplineEditUndo(sidewalkSplineData)

Handles single spline edit undo.

  • sidewalkSplineData (any)

singleSplineEditRedo(sidewalkSplineData)

Handles single spline edit redo.

  • sidewalkSplineData (any)

transSplineEditUndo(data)

Handles trans spline edit undo.

  • data (table)

transSplineEditRedo(data)

Handles trans spline edit redo.

  • data (table)

objectSelectUndo(data)

Handles object select undo.

  • data (table)

objectSelectRedo(data)

Handles object select redo.

  • data (table)

Returns: self

Functions

singleSplineEditUndo(sidewalkSplineData)

Handles single spline edit undo.

  • sidewalkSplineData (any)

singleSplineEditRedo(sidewalkSplineData)

Handles single spline edit redo.

  • sidewalkSplineData (any)

transSplineEditUndo(data)

Handles trans spline edit undo.

  • data (table)

transSplineEditRedo(data)

Handles trans spline edit redo.

  • data (table)

objectSelectUndo(data)

Handles object select undo.

  • data (table)

objectSelectRedo(data)

Handles object select redo.

  • data (table)

Returns: self


See Also

  • Sidewalk Spline Kit - Related reference
  • Sidewalk Spline Populate - Related reference
  • World Editor Guide - Guide

Sidewalk Spline Populate

Handles the procedural placement of sidewalk meshes along splines - places rectangular pieces along the path with parallel-transport framing, fills gaps with triangular "pizza" pieces at turns, and ma

Sites Editor - Locations

Sub-editor for managing location elements within the Sites Editor. Handles hit-testing, gizmo-based transform editing (translate/scale), and undo/redo for location creation/removal.

On this page

Public FunctionsExample: Creating, Populating, and Managing SplinesSpline Data StructureFunctionssingleSplineEditUndo(sidewalkSplineData)singleSplineEditRedo(sidewalkSplineData)transSplineEditUndo(data)transSplineEditRedo(data)objectSelectUndo(data)objectSelectRedo(data)FunctionssingleSplineEditUndo(sidewalkSplineData)singleSplineEditRedo(sidewalkSplineData)transSplineEditUndo(data)transSplineEditRedo(data)objectSelectUndo(data)objectSelectRedo(data)See Also