# Script

The Script Asset object represents your plain-text source script file in a format Unreal Engine can read and understand. It is created by the Lexer when you drag and drop your script file in Unreal Engine's content browser.

When the Play Script function is executed, the function creates an Interpreter and serves it a Script Asset to play.


# Local Settings

When opening a Script Asset in Editor, you can access and edit its local settings. Check Script Local Settings page for more information.


# Parsing

Parsing a script refers to the process of analyzing the structure and syntax of a script. It involves breaking down the script into its individual components, such as keywords, operators, and expressions.

During parsing, each statement is converted into a Struct, and the Script Asset stores them in an array. The Interpreter then uses this array to further analyze and execute the statements into something the player can experience.

# Runtime Parsing

Quillscript allows parsing any valid string into a Script Asset, in editor and during runtime. This lets you create temporary scripts on demand, combining strings and code.

#include "Utils/Quill.h"
...

FString QuillscriptValidString{ "..." };
TObjectPtr<UQuillscriptAsset> Script{ UQuill::ParseScript(QuillscriptValidString) };

# Permissions

# Permission Modes

# All

All permissions, no exception. The default state a script plays.

This should be used only for your own scripts, since external sources can't be trusted.

# Safe

Can play statements, but can't handle variables or call functions.

This mode is useful when external sources can play a story, but not execute game code.

  • PlayDialogues, PlaySelections, PlayRouters, PlayDirectives

# Sandbox

Play this script isolated in its own universe. Can play statements, can call built-in functions, and handle temporary variables.

This is most useful when modders should not have total access over game code but can create temporary variables and use the Interpreter's functions.

  • CallBuiltInFunctions, CreateTemporaryVariables, ModifyTemporaryVariables, DeleteTemporaryVariables, PlayDialogues, PlaySelections, PlayRouters, PlayDirectives

# Permissions

You can also set script permissions manually.

  • CallBuiltInFunctions
  • CallFunctionsByReference
  • CallFunctionsByClass
  • CallFunctionsByTag
  • CreateGlobalVariables
  • ModifyGlobalVariables
  • DeleteGlobalVariables
  • CreateTemporaryVariables
  • ModifyTemporaryVariables
  • DeleteTemporaryVariables
  • PlayDialogues
  • PlaySelections
  • PlayRouters
  • PlayDirectives
Script->SetPermissions({
    EPermission::PlayDialogues,
    EPermission::PlaySelections,
    EPermission::CallBuiltInFunctions
});