File: ctags-lang-tcl.7.rst

package info (click to toggle)
universal-ctags 6.2.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 37,612 kB
  • sloc: ansic: 158,498; sh: 8,621; lisp: 7,742; vhdl: 6,518; cpp: 2,583; perl: 2,578; python: 2,324; javascript: 2,054; cs: 1,193; lex: 1,015; sql: 897; makefile: 787; ruby: 764; php: 755; cobol: 741; f90: 566; ada: 559; asm: 509; yacc: 465; fortran: 412; xml: 405; objc: 289; tcl: 280; java: 173; erlang: 65; pascal: 58; ml: 49; awk: 44; haskell: 42
file content (73 lines) | stat: -rw-r--r-- 1,912 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
.. _ctags-lang-tcl(7):

==============================================================
ctags-lang-tcl
==============================================================

Random notes about tagging tcl source code with Universal Ctags

:Version: 6.2.1
:Manual group: Universal Ctags
:Manual section: 7

SYNOPSIS
--------
|	**ctags** ... --languages=+Tcl ...
|	**ctags** ... --language-force=Tcl ...
|	**ctags** ... --map-Tcl=+.tcl ...

DESCRIPTION
-----------
This man page gathers random notes about tagging tcl source code.

TAGGING language objects of OO Extensions
-----------------------------------------

TclOO parser and ITcl parser are subparsers running on the Tcl parser.
As the names of parsers show, they are for tagging language objects of
object oriented programming extensions for the Tcl language.

A pattern, "namespace import oo" in an input file activates the TclOO
parser. A pattern, "namespace import itcl" in an input file activates
the ITcl parser.

There are cases that one of the OO extensions is used though neither
pattern are appeared in an input file.

Consider the following input files:

"main.tcl"

.. code-block:: Tcl

	package require Itcl
	namespace import itcl::*
	source input.tcl

"input.tcl"

.. code-block:: Tcl

	class MyClass {
		public method foo {} {
		}
	}

The pattern for activating the ITcl parser is not appeared
in "input.tcl" though "class" command is used. As a result,
ctags cannot extract "MyClass".

The parameters `TclOO.forceUse=true|[false]` and
`ITcl.forceuse=true|[false]` for handling this situation. With the
parameter, you can force ctags to activate one of the subparsers.

You can use the parameters like ``--param-ITcl.forceuse=true``
in a command-line.

Note that you can enable only one of ITcl parser or TclOO parser.
Enabling both parsers with specifying the parameters can cause
unexpected results.

SEE ALSO
--------
:ref:`ctags(1) <ctags(1)>`