2022-03-18 17:46:08 +01:00
|
|
|
.. _doc_creating_script_templates:
|
|
|
|
|
|
|
|
Creating script templates
|
|
|
|
=========================
|
|
|
|
|
|
|
|
Godot provides a way to use script templates as seen in the
|
2023-01-12 19:43:03 +01:00
|
|
|
`Script Create Dialog` while creating a new script:
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. image:: img/script_create_dialog_templates.png
|
|
|
|
|
|
|
|
A set of default script templates is provided by default, but it's also possible
|
|
|
|
to modify existing and create new ones, both per project and the editor.
|
|
|
|
|
|
|
|
Locating the templates
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
There are two places where templates can be managed.
|
|
|
|
|
|
|
|
Editor-defined templates
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
These are available globally throughout any project. The location of these
|
|
|
|
templates are determined per each OS:
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
- Windows: `%APPDATA%\Godot\script_templates\`
|
|
|
|
- Linux: `$HOME/.config/godot/script_templates/`
|
|
|
|
- macOS: `$HOME/Library/Application Support/Godot/script_templates/`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
If no `script_templates` is detected, Godot will create a default set of
|
2022-03-18 17:46:08 +01:00
|
|
|
built-in templates automatically, so this logic can be used to reset the default
|
|
|
|
templates in case you've accidentally overwritten them.
|
|
|
|
|
|
|
|
Project-defined templates
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The default path to search for templates is the
|
2023-01-12 19:43:03 +01:00
|
|
|
`res://script_templates/` directory. The path can be changed by configuring
|
|
|
|
the `editor/script_templates_search_path` setting in the
|
2023-01-12 19:30:47 +01:00
|
|
|
`ProjectSettings`, both via code and the editor.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
If no `script_templates` directory is found within a project, it is simply
|
2022-03-18 17:46:08 +01:00
|
|
|
ignored.
|
|
|
|
|
|
|
|
Language support and overriding behavior
|
|
|
|
----------------------------------------
|
|
|
|
|
|
|
|
Depending on whether a particular language implements a way to generate scripts
|
|
|
|
out of templates, it's possible to create a template which can be recognized by
|
|
|
|
that language according to template's file extension. For GDScript and C#, the
|
2023-01-12 19:43:03 +01:00
|
|
|
extensions must be `gd` and `cs` respectively.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. note:: The script templates have the same extension as the regular script
|
|
|
|
files. This may lead to an issue of a script parser treating those templates as
|
|
|
|
actual scripts within a project. To avoid this, make sure to ignore the
|
2023-01-12 19:43:03 +01:00
|
|
|
directory containing them by creating an empty `.gdignore` file. The directory won't be
|
2022-03-18 17:46:08 +01:00
|
|
|
visible throughout the project's filesystem anymore, yet the templates can be
|
|
|
|
modified by an external text editor anytime.
|
|
|
|
|
|
|
|
The built-in editor templates are automatically shadowed by the project-specific
|
|
|
|
templates given both scripts have the same filename.
|
|
|
|
|
|
|
|
Default template
|
|
|
|
----------------
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The `Default` template is always generated dynamically per language and cannot
|
2022-03-18 17:46:08 +01:00
|
|
|
be configured nor overridden, but you can use these as the base for creating
|
|
|
|
other templates.
|
|
|
|
|
|
|
|
|
2023-01-12 18:31:02 +01:00
|
|
|
gdscript GDScript
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 18:31:02 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
extends %BASE%
|
|
|
|
|
|
|
|
|
|
|
|
# Declare member variables here. Examples:
|
|
|
|
# var a%INT_TYPE% = 2
|
|
|
|
# var b%STRING_TYPE% = "text"
|
|
|
|
|
|
|
|
|
|
|
|
# Called when the node enters the scene tree for the first time.
|
|
|
|
func _ready()%VOID_RETURN%:
|
|
|
|
pass # Replace with function body.
|
|
|
|
|
|
|
|
|
|
|
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
|
|
|
#func _process(delta%FLOAT_TYPE%)%VOID_RETURN%:
|
|
|
|
# pass
|
2023-01-12 18:31:02 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
List of template placeholders
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
The following describes the complete list of built-in template placeholders
|
|
|
|
which are currently implemented.
|
|
|
|
|
|
|
|
Base placeholders
|
|
|
|
~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
+-------------+----------------------------------------------------------------+
|
|
|
|
| Placeholder | Description |
|
|
|
|
+=============+================================================================+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `%CLASS%` | The name of the new class (used in C# only). |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-------------+----------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `%BASE%` | The base type a new script inherits from. |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-------------+----------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `%TS%` | Indentation placeholder. The exact type and number of |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | whitespace characters used for indentation is determined by |
|
2023-01-12 19:43:03 +01:00
|
|
|
| | the `text_editor/indent/type` and `text_editor/indent/size`|
|
2023-01-12 19:30:47 +01:00
|
|
|
| | settings in the `EditorSettings` |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | respectively. |
|
|
|
|
+-------------+----------------------------------------------------------------+
|
|
|
|
|
|
|
|
Type placeholders
|
|
|
|
~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
These are only relevant for GDScript with static typing. Whether these
|
|
|
|
placeholders are actually replaced is determined by the
|
2023-01-12 19:43:03 +01:00
|
|
|
`text_editor/completion/add_type_hints` setting in the
|
2023-01-12 19:30:47 +01:00
|
|
|
`EditorSettings`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
+-------------------+--------------+
|
|
|
|
| Placeholder | Value |
|
|
|
|
+===================+==============+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `%INT_TYPE%` | `: int` |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-------------------+--------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `%STRING_TYPE%` | `: String` |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-------------------+--------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `%FLOAT_TYPE%` | `: float` |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-------------------+--------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `%VOID_RETURN%` | `-> void` |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-------------------+--------------+
|