Provided by: universal-ctags_6.2.1-1_amd64 bug

Name

       ctags-lang-gdscript - Random notes about tagging GDScript source code with Universal Ctags

SYNOPSIS

       ctags ... --languages=+GDScript ...
       ctags ... --language-force=GDScript ...
       ctags ... --map-GDScript=+.gd ...

DESCRIPTION

       This man page gathers random notes about tagging GDScript source code with Universal Ctags.

Storing Annotations

       Like  the  Python parser storing decorations to decorations field, the GDScript parser stores annotations
       starting from @ to the language specific field, annotations.  Though the field is enabled  explicitly  in
       following examples, the field is enabled by default.

       "input.gd"

          @export
          var s = "Hello"

          @master
          func f(msg):
                  print(msg)

       "output.tags" with "--options=NONE --sort=no --fields-GDScript=+{annotations} -o - input.gd"

          s       input.gd        /^var s = "Hello"$/;"   v       annotations:export
          f       input.gd        /^func f(msg):$/;"      m       annotations:master

Extracting func

       A  language  object  defined  with func keyword is tagged with method kind.  Like annotations, the parser
       stores keywords modifying func like static to the annotations field.

       "input.gd"

          func f(x):
                  return x

          static func f_s(x):
                  reutrn x

          remote func f_r(x):
                  return x

       "output.tags" with "--options=NONE --sort=no --fields=+K --fields-GDScript=+{annotations} -o - input.gd"

          f       input.gd        /^func f(x):$/;"        method
          f_s     input.gd        /^static func f_s(x):$/;"       method  annotations:static
          f_r     input.gd        /^remote func f_r(x):$/;"       method  annotations:remote

Tagging implicitly defined classes

       "A file is a class!" in GDScript.  A class is implicitly defined. Functions,  variables,  constants,  and
       signals are parts of the class though the class is unnamed by default.

       If  the  language  specific  extra,  implicitClass,  is enabled, the parser makes a anonymous tag for the
       class. The parser fills the scope fields of the tags for all language objects defined in  the  file  with
       the anonymous tag.

       Let's see an example demonstrating the effect of the extra.

       Turning off the extra:

       "input.gd"

          func f(x):
                  return x

       "output.tags" with "--options=NONE --fields=+KZ --extras-GDScript=-{implicitClass} -o - input.gd"

          f       input.gd        /^func f(x):$/;"        method

       Turning on the extra:

       "input.gd"

          func g(x):
                  return x

       "output.tags" with "--options=NONE --fields=+KZ --extras-GDScript=+{implicitClass} -o - input.gd"

          anon_class_84011bee0100 input.gd        /^func g(x):$/;"        class
          g       input.gd        /^func g(x):$/;"        method  scope:class:anon_class_84011bee0100

Tagging the name specified with class_name

       class_name  is  a  keyword for giving a name to the implicitly defined class.  If implicitClass is turned
       off, the parser just extract the name coming after the keyword  with  class  kind.  If  implicitClass  is
       turned  on,  the  parser converts the anonymous tag to a non-anonymous tag with the specified name.  When
       converting, the parser also updates scope fields of the other tags in the file.

       Turning off the extra:

       "input.gd"

          class_name c

          func f(x):
                  return x

       "output.tags" with "--options=NONE --fields=+KZ --extras-GDScript=-{implicitClass} -o - input.gd"

          c       input.gd        /^class_name c$/;"      class
          f       input.gd        /^func f(x):$/;"        method

       Turning on the extra:

       "input.gd"

          class_name C
          func g(x):
                  return x

       "output.tags" with "--options=NONE --fields=+KZ --extras-GDScript=+{implicitClass} -o - input.gd"

          C       input.gd        /^class_name C$/;"      class
          g       input.gd        /^func g(x):$/;"        method  scope:class:C

Filling inherits field

       extends keyword specifies the super class for the implicitly defined class.  If  implicitClass  extra  is
       turned  on,  the parser fills inherits field of the tag for the implicitly defined class with the name of
       super class.

       "input.gd"

          extends B
          class_name C

       "output.tags" with "--options=NONE --fields=+Ki --extras-GDScript=+{implicitClass} -o - input.gd"

          C       input.gd        /^class_name C$/;"      class   inherits:B

       When --extras=+r is given, the parser extracts  the  class  specified  with  the  extends  keyword  as  a
       reference tag of class kind with extended role.

       "input.gd"

          extends B

       "output.tags" with "--options=NONE --fields=+rEK --extras=+r -o - input.gd"

          B       input.gd        /^extends B$/;" class   roles:extended  extras:reference

SEE ALSO

       ctags(1)

6.2.1                                                                                     ctags-lang-gdscript(7)