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

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 Extensionseditor

Editor Main

Core editor bootstrap module. Sets up the global `editor` object, manages extension loading, preferences, edit modes, window registration, selection system, history/undo, and the editor activate/deact

Core editor bootstrap module. Sets up the global editor object, manages extension loading, preferences, edit modes, window registration, selection system, history/undo, and the editor activate/deactivate lifecycle.


Module Overview

AspectDetail
Fileextensions/editor/main.lua
ReturnsM table (assigned to global editor)
Dependenciescore_camera
RoleEditor framework initialization and lifecycle management

Key State

FieldTypeDescription
M.initializedbooleanWhether the editor has been fully initialized
M.activebooleanWhether the editor is currently active
M.safeModebooleanSafe mode limits which extensions load
M.extensionNamestableList of loaded editor extension names
M.allExtensionNamestableAll discovered editor extension names
M.preferencesRegistryobjectPreference storage and notification system

Public Functions - Lifecycle

FunctionDescription
M.initializeModules()Full editor initialization - loads extensions, preferences, state
M.setEditorActive(activate, safeMode)Enters/exits editor mode
M.isEditorActive()Returns whether editor is active
M.toggleActive()Toggles editor on/off

Public Functions - Extensions

FunctionDescription
M.loadEditorExtensions(extNames)Loads editor extensions from a list of names
M.loadEditorExtension(name)Loads a single extension by name
M.unloadEditorExtension(name)Unloads a single extension

Public Functions - Preferences

FunctionDescription
M.saveExtensionsSettings()Saves extension settings
M.loadExtensionsSettings()Loads extension settings
M.loadPreferences()Loads from settings/editor/preferences.json
M.savePreferences()Saves to settings/editor/preferences.json

Public Functions - Logging

FunctionDescription
M.log(msg)Info-level editor log
M.logDebug(msg)Debug-level editor log
M.logWarn(msg)Warning-level editor log
M.logError(msg)Error-level editor log

Extension Discovery

-- Extensions are discovered from:
local extensionFiles = FS:findFiles('/lua/ge/extensions/editor/', '*.lua', 0, false, false)

-- A file is an editor extension if it contains:
-- M.onEditor* or M.onExtension* function declarations

-- Safe mode only loads these extensions:
local safeModeExtensionNames = {
  "editor_extensionsEditor", "editor_fileDialog", "editor_worldEditorHelper",
  "editor_createObjectTool", "editor_gizmoHelper", "editor_logHelper",
  "editor_mainMenu", "editor_mainToolbar", "editor_mainUpdate",
  "editor_preferences", "editor_objectTool", "editor_sceneTree",
  "editor_inspector", "editor_layoutManager"
}

Configuration Paths

PathPurpose
settings/editor/preferences.jsonEditor preferences
settings/editor/currentState.jsonPersisted editor state
settings/editor/extensions.jsonExtension enable/disable settings

Hook System

The editor broadcasts hooks to all loaded extensions:

  • onEditorInitialized, onEditorActivated, onEditorDeactivated
  • onEditorGui, onEditorMainMenuBar
  • onEditorObjectSelectionChanged, onEditorInspectorFieldChanged
  • onEditorRegisterPreferences, onEditorPreferenceValueChanged
  • onEditorHeadlessMainMenuBar, onEditorHeadlessChange

Module Variables

  • M.dependencies (table) - {"core_camera"}.
  • M.additionalActionMaps (table) - Extra action maps to push when editor activates.
  • M.extensionsSettings (any) - Extension enable/disable settings.
  • M.guiModule (any) - Reference to editor/api/gui module.
  • M.coreModule (any) - Reference to editor/api/core module.
  • M.assetsModule (any) - Reference to editor/api/assets module.
  • M.cameraModule (any) - Reference to editor/api/camera module.
  • M.dataBlockModule (any) - Reference to editor/api/dataBlock module.
  • M.decalModule (any) - Reference to editor/api/decal module.
  • M.gizmoModule (any) - Reference to editor/api/gizmo module.
  • M.materialModule (any) - Reference to editor/api/material module.
  • M.navigationModule (any) - Reference to editor/api/navigation module.
  • M.objectModule (any) - Reference to editor/api/object module.
  • M.roadRiverModule (any) - Reference to editor/api/roadRiver module.
  • M.sketchModule (any) - Reference to editor/api/sketch module.
  • M.terrainModule (any) - Reference to editor/api/terrain module.
  • M.forestModule (any) - Reference to editor/api/forest module.
  • M.modulesInitialized (boolean) - Whether API modules have been initialized.

Functions

M.logInfo(msg)

Info-level editor log (alias for M.log).

  • msg (string)

M.initializeModules()

Initializes all editor API modules (gui, core, assets, camera, etc.).

M.setEditorActive(activate, safeMode)

Sets the editor active or inactive.

  • activate (boolean)
  • safeMode (boolean)

M.isEditorActive()

Checks if editor is currently active.

Returns: boolean

M.saveState(filePath)

Saves editor state to file.

  • filePath (string)

M.loadState(filePath)

Loads editor state from file.

  • filePath (string)

Returns: table

M.loadExtensionsSettings()

Loads extension enable/disable settings from settings/editor/extensions.json.

M.saveExtensionsSettings()

Saves extension enable/disable settings to settings/editor/extensions.json.

M.loadEditorExtensions(names)

Loads multiple editor extensions by name.

  • names (table)

M.shutdown()

Shuts down the editor, unloads extensions.

M.onClientStartMission()

Callback for client start mission event.

M.onClientEndMission()

Callback for client end mission event.

M.onExit()

Callback for exit event.

M.onPreWindowClose()

Callback for pre window close event.

M.onExtensionLoaded()

Callback for extension loaded event.

M.onExtensionUnloaded()

Callback for extension unloaded event.

M.onSerialize()

Callback for serialize event.

Returns: table

M.onDeserialized(data)

Callback for deserialized event.

  • data (table)

M.onFirstUpdate()

Callback for first update event.

M.onUpdate()

Callback for update event.

M.toggleActive()

Toggles editor active/inactive state.

M.loadEditorExtension(name)

Loads a single editor extension by name.

  • name (string)

M.savePreferences()

Saves preferences to settings/editor/preferences.json.

M.loadPreferences()

Loads preferences from settings/editor/preferences.json.


See Also

  • Editor AI Tests - Related reference
  • Editor AI Visualization - Related reference
  • Editor – Assembly Spline Tool - Related reference
  • World Editor Guide - Guide

Editor Log Helper

Displays live log statistics (error and warning counts) in the editor's main menu bar. Uses `Lua:getDevLogStats()` to fetch counters.

Editor Main Menu

Manages the editor's main menu bar, notification system, window menu organization, layout management UI, and scene metrics display. Depends on `editor_layoutManager` for layout persistence.

On this page

Module OverviewKey StatePublic Functions - LifecyclePublic Functions - ExtensionsPublic Functions - PreferencesPublic Functions - LoggingExtension DiscoveryConfiguration PathsHook SystemModule VariablesFunctionsM.logInfo(msg)M.initializeModules()M.setEditorActive(activate, safeMode)M.isEditorActive()M.saveState(filePath)M.loadState(filePath)M.loadExtensionsSettings()M.saveExtensionsSettings()M.loadEditorExtensions(names)M.shutdown()M.onClientStartMission()M.onClientEndMission()M.onExit()M.onPreWindowClose()M.onExtensionLoaded()M.onExtensionUnloaded()M.onSerialize()M.onDeserialized(data)M.onFirstUpdate()M.onUpdate()M.toggleActive()M.loadEditorExtension(name)M.savePreferences()M.loadPreferences()See Also