Skip to content

Commit

Permalink
Merge pull request #7828 from Calinou/static-typing-for-loop
Browse files Browse the repository at this point in the history
  • Loading branch information
mhilbrunner authored Aug 21, 2023
2 parents 746e02b + 8e4f72f commit c6f6b48
Showing 1 changed file with 21 additions and 24 deletions.
45 changes: 21 additions & 24 deletions tutorials/scripting/gdscript/static_typing.rst
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,6 @@ or write code like you always did!
Static types can be used on variables, constants, functions, parameters,
and return types.

.. note::

Typed GDScript is available since Godot 3.1.

A brief look at static typing
-----------------------------

Expand Down Expand Up @@ -271,6 +267,18 @@ Nested array types are not supported.
var s: String = scores[0]
scores[0] = "lots"

Since Godot 4.2, you can also specify a type for the loop variable in a ``for`` loop.
For instance, you can write:

::

var names = ["John", "Marta", "Samantha", "Jimmy"]
for name: String in names:
pass

The array will remain untyped, but the ``name`` variable within the ``for`` loop
will always be of String type.

Typed or dynamic: stick to one style
------------------------------------

Expand Down Expand Up @@ -350,33 +358,22 @@ Warning system
Documentation about the GDScript warning system has been moved to
:ref:`doc_gdscript_warning_system`.

Cases where you can't specify types
-----------------------------------
A case where you can't specify types
------------------------------------

To wrap up this introduction, let's cover a few cases where you can't
use type hints. All the examples below **will trigger errors**.
To wrap up this introduction, let's mention a case where you can't
use type hints. This will trigger a **syntax error**.

You can't specify the type of individual members in an array. This will
give you an error:
You can't specify the type of individual members in an array:

::

var enemies: Array = [$Goblin: Enemy, $Zombie: Enemy]

You can't force the assignment of types in a ``for`` loop, as each
element the ``for`` keyword loops over already has a different type. So you
**cannot** write:

::

var names = ["John", "Marta", "Samantha", "Jimmy"]
for name: String in names:
pass

Summary
-------

Typed GDScript is a powerful tool. Available as of version 3.1 of Godot, it
helps you write more structured code, avoid common errors, and
create scalable systems. In the future, static types will also bring you
a nice performance boost thanks to upcoming compiler optimizations.
Typed GDScript is a powerful tool. It helps you write more structured code,
avoid common errors, and create scalable systems. In the future, static types
will also bring you a nice performance boost thanks to upcoming compiler
optimizations.

0 comments on commit c6f6b48

Please sign in to comment.