# Function Call

Quillscript can execute Blueprint/C++ functions using command lines.

Supposing you want to run a function with the following signature.

UFUNCTION()
void MyFunction(int32 Num, bool Flag);

# Built-in

If the above function belongs to the Interpreter, including custom interpreters, you call it by typing its name and passing the parameters separated by spaces.

$ MyFunction 10 true

# Named Object

You can execute functions that belong to an instanced object by referencing its name, editor's name or display name. For example, if an object is named 'MyActor', start the function with an & (ampersand) followed by the object name, and place a dot between the object name and the function name.

$ &MyActor.MyFunction 10 true

Additionally, Quillscript also provides a Rename Object function to easily set a name for an object.

#include "Utils/Tools.h"
...

UTools::RenameObject(MyObject, "RefName");

# Shortcuts

You can use these names to reference common Unreal Engine objects.

&GameInstance Game Instance Object
&PlayerController Player Controller Actor
&GameMode Game Mode Object
&Pawn Player Pawn Actor
&Character Player Character Actor
&GameState Game State Object
&PlayerState Player State Object
&PlayerCameraManager Player Camera Manager Actor
&Interpreter or &this This script interpreter Actor
&Target Script target object (Passed in the Play Script node)
&Script Script object
&DialogBox Dialog Box Widget
&SelectionBox Selection Box Widget
&BackgroundBox Background Box Widget
&HUD Head-up Display Object
&Level Current Level Script Actor
&World World Object
&Subsystem Quillscript Subsystem Object

# Script References

In addition, you can create a list of object references to use in scripts. To add an object to the list, use the method below:

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

UQuill::AddScriptReference(WorldContextObject, "MyRef", Reference);

And it becomes available in script, by name.

$ &MyRef.MyFunction 10 true

These objects can also be passed as parameter variables to other functions if they match parameter type. A null pointer is passed otherwise.

$ MyOtherFunction {&MyRef}

Object references are also captured when they are sent as return value of a function. For example, the function with the following signature:

UFUNCTION()
AActor* ObjectOutputFunction(UObject*& MyOutputObject);

An object reference for the output parameter is added and becomes immediately available in script.

$ &ReturnValue.MyFunction 10 true
$ &MyOutputObject.MyFunction 10 true

$ MyOtherFunction {&MyOutputObject}

# Script Reference By Path

It's very common to pass an Unreal Engine asset as a parameter to a function. To avoid the need to create a named script reference for every asset required, script references can use the Unreal Engine path pattern to pass asset references without the need to previously name it.

$ Background {&/Game/FolderName/AssetName.AssetName}

The same method can be applied to pass class references:

// Blueprint classes.
$ MyFunction {&/Game/FolderName/MyBlueprint.MyBlueprint_C}

// C++ classes.
$ MyFunction {&Engine.Actor}

Script assets will also reference these assets in the Reference Viewer.

# Script Reference Search Paths

Also, often your assets are all in the same folder. For such cases, you can add that folder to a list of "Search Paths", either project-wide on plugin settings, or per script on the script asset itself. An asset in this specified folder does not need to be referenced by its entire path, but just by its name.

For example, suppose we have a folder named "Backgrounds" on the content browser. Inside this folder are 3 texture assets named "Classroom", "Street", and "Shop". You add this folder to your project search paths and reference these assets by name, without the need to create a script reference manually.

Search Path: /Game/Backgrounds/

$ Background {&Classroom}
$ Background {&Street}
$ Background {&Shop}

# Object, Actors, Widgets or Function Library of Class

You can execute functions in all objects of a given class. For example, if an object has the class "MyClass", start the function with an ^ (Circumflex) and the class name.

Start with the blueprint reference path, without the extension at the end:

$ ^Path/To/My/Blueprint/MyClass.MyFunction 10 true
Example
$ ^Game/MyBlueprint.MyFunction 10 true

Start with the module name and the class name.

$ ^MyModule.MyClass.MyFunction 10 true
Example
$ ^Engine.Actor.MyFunction 10 true

# Tagged Actors

You can execute functions that belong to instanced Actors using their tags. For example, if an Actor has the tag 'MyTag', start the function with a % (Percent Sign) and the tag name.

This method will execute the function in all actors with the specified tag.

$ %MyTag.MyFunction 10 true

# Calling Nested Objects

You can also call functions from nested objects. For example:

$ MyParentObject.ChildObject1.ChildObject2.MyFunction 10 true

# Return Values and Outer Parameters

# Functions

You can capture the return values of a called function and store it in a Quillscript variable.

Suppose you want to capture the return value of the following function.

UFUNCTION()
bool MyFunction(int32& IntParam, FString& StringParam);

When this function is called by one of the methods above, the return values are stored in Quillscript Outer Variables, a particular type of temporary variable that exists during that script execution.

These variables are named like the return value and outer parameters. The following variables are created in the example above: $ReturnValue, $IntParam, and $StringParam

Example
$ &MyParentObject.MyFunction

$ double = {$IntParam} * 2

- Alice | ? {$ReturnValue} == on
  {$StringParam}

# Properties

You can capture the value of an UObject property.

Suppose you want to capture the return value of the following properties.

UPROPERTY()
int32 MyNumber;

UPROPERTY()
FString MyString;

Call the variable by its path and use the property name as an outer variable.

$ &MyParentObject.MyNumber

- Bob | ? {$MyNumber} > 5
  Hello!

And you can do the same for nested objects:

$ MyParentObject.ChildObject1.ChildObject2.MyString

- Alice
  {$MyString}

It's also possible to retrieve an element from some container types using the :: separator.

From Arrays or Sets using the element index number:

$ MyParentObject.MyArray

- Bob
  {$MyArray::0}

From Maps using the element key:

$ MyParentObject.MyMap

- Bob
  {$MyMap::key}

# Localizing Parameters' Text

Although being stored as an Unreal Engine's Text type, Quillscript's Text are culture-invariant by default. If the value of a parameter must be localized, set its value inside `` (backticks) and it will be changed to culture-correct.

// void MyFunction(FString Param1, FString Param2)
$ MyFunction `This param value should be localized` 'This param should not'

# Named Parameters

Is a versatile feature that allows users to call functions with parameters passed in any order. This is achieved by explicitly naming the parameters using the @ParamName:ParamValue syntax. This approach enhances code readability and flexibility, making it easier to understand and edit. At the same time, it also lets the writer pass only the desired parameters in the desired order and omits unnecessary ones.

Consider the following function:

UFUNCTION()
void MyFunction(int32 IntParam, FString StringParam, bool bBooleanParam);

In a Quillscript file, you can call this function like this.

// Same order, but named for better readability.
$ MyFunction @IntParam:10 @StringParam:String @bBooleanParam:true

// Parameters are passed in the writer's desired order.
$ MyFunction @bBooleanParam:true @StringParam:String @IntParam:10

// The intended param is passed, and others are omitted (default value).
$ MyFunction @StringParam:String