Ctags: So parsen Sie den Tagnamen und die Art aus der Ausgabe von ctags -R -x

Erstellt am 12. März 2019  ·  8Kommentare  ·  Quelle: universal-ctags/ctags


Der Name des Parsers: beliebig

Die Befehlszeile, die Sie zum Ausführen von ctags verwendet haben:

$ ctags --options=NONE -R -x

Der Inhalt der Eingabedatei:

$ git clone https://github.com/liuchengxu/vista.vim
$ cd vista.vim
$ ctags --options=NONE -R -x

Die Tag-Ausgabe, mit der Sie nicht zufrieden sind:

Ich habe keine Ahnung, wie ich die Ausgabe von ctags -R -x parsen soll. Ich möchte den Tagnamen und den Bereich aus der Ausgabe von ctags -R -x filtern, weiß aber nicht, wie ich es richtig machen soll.

Die Tag-Ausgabe, die Sie erwarten:

Es ist praktikabel, wenn es auch ein bestimmtes Format für ctags -R gibt:

{tagname}<Tab>{tagfile}<Tab>{tagaddress}[;"<Tab>{tagfield}..]

Die Version von ctags:

$ ctags --version
Universal Ctags 0.0.0(1208e45), Copyright (C) 2015 Universal Ctags Team
Universal Ctags is derived from Exuberant Ctags.
Exuberant Ctags 5.8, Copyright (C) 1996-2009 Darren Hiebert
  Compiled: Mar 11 2019, 17:01:27
  URL: https://ctags.io/
  Optional compiled features: +wildcards, +regex, +iconv, +option-directory, +xpath, +case-insensitive-filenames, +packcc

Wie bekommt man ctags binär:

brew install ctags auf macOS

Alle 8 Kommentare

Ich verstehe deine Frage nicht.

Sind Sie mit der Ausgabe von ctags -R zufrieden? Wenn ja, warum verwenden Sie nicht die Option -x ?
Ich würde gerne mehr über den Hintergrund des Anwendungsfalls erfahren, um Ihre Frage zu beantworten.

Ich kenne kein Vim-Skript. Was jedoch das Lesen von vim.c, dem vim-Parser von ctags, betrifft, füllt es keine Bereichsfelder aus. Wenn Sie der Meinung sind, dass es sich um einen Fehler handelt, teilen Sie uns mit, dass der vim-Parser das Bereichsfeld für welche Art von Eingabe ausfüllt.

Entschuldigung, dass ich es nicht deutlich gemacht habe.

Warum die Option -x verwenden?

Obwohl ctags -R meine Anforderungen erfüllen würde, möchte ich die Tag-Datei nicht generieren, also verwende ich die Option -x .

mein Anwendungsfall.

Derzeit unterstützt vista.vim nur das Anzeigen der Tags in einigen Dateien, aber einige Benutzer möchten alle Tags in einem Projekt anzeigen (https://github.com/liuchengxu/vista.vim/issues/14). Ich habe versucht, Unterstützung für ctags -R hinzuzufügen, weiß aber nicht, wie ich diese Ausgabe richtig extrahieren kann.

Kurz gesagt, wie kann man vista#util#Trim , function , 18 , autoload/vista/util.vim , vista#util#Trim(str) extrahieren?

ctags -R -x :

...
vista#util#Trim  function     18 autoload/vista/util.vim function! vista#util#Trim(str)
vista#util#Truncate function     13 autoload/vista/util.vim function! vista#util#Truncate(msg) abort
vista#util#Warning function     90 autoload/vista/util.vim function! vista#util#Warning(msg) abort
vista#viewer#Display function     90 autoload/vista/viewer.vim function! vista#viewer#Display(data) abort
vista#viewer#Render function     86 autoload/vista/viewer.vim function! vista#viewer#Render(data) abort
vista#viewer#prefixes function     94 autoload/vista/viewer.vim function! vista#viewer#prefixes() abort

Mit der Option -o - gibt ctags die Ausgabe wie folgt an stdout aus:

[yamato@slave]/tmp/vista.vim% u-ctags -R -o - | head 
/   ftplugin/vista.vim  /^nnoremap <buffer> <silent> \/    :<c-u>call vista#finder#fzf#Run()<CR>$/;"    m
<CR>    ftplugin/vista.vim  /^nnoremap <buffer> <silent> <CR> :<c-u>call vista#cursor#FoldOrJump()<CR>$/;"  m
Commands    README.md   /^### Commands$/;"  S
Contributing    README.md   /^## Contributing$/;"   s
Features    README.md   /^## Features$/;"   s
Installation    README.md   /^## Installation$/;"   s
Introduction    README.md   /^## Introduction$/;"   s
License README.md   /^## License$/;"    s
NeoVim  README.md   /^#### NeoVim$/;"   t
Options README.md   /^### Options$/;"   S

Sie können die Ausgabe mit der Option --_xformat= anpassen:

 u-ctags -R -x --_xformat='TAGNAME:%N @@@ KIND:%K !!! LINE:%n +++ INPUT-FILE:%F === PATTERN:%P' | head
TAGNAME:/ @@@ KIND:map !!! LINE:38 +++ INPUT-FILE:ftplugin/vista.vim === PATTERN:/^nnoremap <buffer> <silent> \/    :<c-u>call vista#finder#fzf#Run()<CR>$/
TAGNAME:<CR> @@@ KIND:map !!! LINE:37 +++ INPUT-FILE:ftplugin/vista.vim === PATTERN:/^nnoremap <buffer> <silent> <CR> :<c-u>call vista#cursor#FoldOrJump()<CR>$/
TAGNAME:Commands @@@ KIND:subsection !!! LINE:101 +++ INPUT-FILE:README.md === PATTERN:/^### Commands$/
TAGNAME:Contributing @@@ KIND:section !!! LINE:164 +++ INPUT-FILE:README.md === PATTERN:/^## Contributing$/
TAGNAME:Features @@@ KIND:section !!! LINE:37 +++ INPUT-FILE:README.md === PATTERN:/^## Features$/
TAGNAME:Installation @@@ KIND:section !!! LINE:69 +++ INPUT-FILE:README.md === PATTERN:/^## Installation$/
TAGNAME:Introduction @@@ KIND:section !!! LINE:25 +++ INPUT-FILE:README.md === PATTERN:/^## Introduction$/
TAGNAME:License @@@ KIND:section !!! LINE:168 +++ INPUT-FILE:README.md === PATTERN:/^## License$/
TAGNAME:NeoVim @@@ KIND:subsubsection !!! LINE:90 +++ INPUT-FILE:README.md === PATTERN:/^#### NeoVim$/
TAGNAME:Options @@@ KIND:subsection !!! LINE:113 +++ INPUT-FILE:README.md === PATTERN:/^### Options$/

Siehe http://docs.ctags.io/en/latest/news.html?highlight=--_xformat#customizing -xref-output .

Wenn Sie keinen Parser schreiben möchten, kann --output-format=json eine Wahl sein:

u-ctags -R --output-format=json | head
{"_type": "tag", "name": "/", "path": "ftplugin/vista.vim", "pattern": "/^nnoremap <buffer> <silent> \\/    :<c-u>call vista#finder#fzf#Run()<CR>$/", "kind": "map"}
{"_type": "tag", "name": "<CR>", "path": "ftplugin/vista.vim", "pattern": "/^nnoremap <buffer> <silent> <CR> :<c-u>call vista#cursor#FoldOrJump()<CR>$/", "kind": "map"}
{"_type": "tag", "name": "Commands", "path": "README.md", "pattern": "/^### Commands$/", "kind": "subsection"}
{"_type": "tag", "name": "Contributing", "path": "README.md", "pattern": "/^## Contributing$/", "kind": "section"}
{"_type": "tag", "name": "Features", "path": "README.md", "pattern": "/^## Features$/", "kind": "section"}
{"_type": "tag", "name": "Installation", "path": "README.md", "pattern": "/^## Installation$/", "kind": "section"}
{"_type": "tag", "name": "Introduction", "path": "README.md", "pattern": "/^## Introduction$/", "kind": "section"}
{"_type": "tag", "name": "License", "path": "README.md", "pattern": "/^## License$/", "kind": "section"}
{"_type": "tag", "name": "NeoVim", "path": "README.md", "pattern": "/^#### NeoVim$/", "kind": "subsubsection"}
{"_type": "tag", "name": "Options", "path": "README.md", "pattern": "/^### Options$/", "kind": "subsection"}

Danke! Ich würde die Option --_xformat= ausprobieren, da ctags , das von Brew installiert wurde, --output-format=json standardmäßig nicht unterstützt, egal ob brew install ctags oder brew install --HEAD universal-ctags/universal-ctags/universal-ctags .

@KazuakiM , ist es nicht möglich, ctags mit libjansson.so.4 zu verknüpfen?
u-ctags hat den json-Ausgabemodus. Es ist verfügbar, wenn u-ctags mit libjansson verknüpft ist.
Sagen Sie mir, ob ich dies als neues Problem im Homebrew-Universal-Ctags-Repo melden soll.

@liuchengxu , Tags-Datei, das native Format von ctags kann mit Funktionen in readtags.c analysiert werden.
readtags-Befehl und python-ctags3, eine Python-Bibliothek verwendet readtags.c.

@masatake
Hallo, Homebrew-Universal-Ctags unterstützt Jansson.

$ brew info universal-ctags
universal-ctags/universal-ctags/universal-ctags: HEAD
Maintained ctags implementation
https://github.com/universal-ctags/ctags
Conflicts with:
  ctags (because this formula installs the same executable as the ctags formula)
/usr/local/Cellar/universal-ctags/HEAD-1b747b3 (325 files, 4.3MB) *
  Built from source on 2019-02-02 at 16:45:17
From: https://github.com/universal-ctags/homebrew-universal-ctags/blob/master/universal-ctags.rb
==> Dependencies
Build: autoconf ✔, automake ✔, pkg-config ✔
Optional: jansson ✔, libyaml ✔
==> Options
--with-jansson
        Build with jansson support
--with-libyaml
        Build with libyaml support
--without-doc
        Compile without man pages
--without-xml
        Compile without libxml2
--HEAD
        Install HEAD version
==> Caveats
Under some circumstances, emacs and ctags can conflict. By default,
emacs provides an executable `ctags` that would conflict with the
executable of the same name that ctags provides. To prevent this,
Homebrew removes the emacs `ctags` and its manpage before linking.
However, if you install emacs with the `--keep-ctags` option, then
the `ctags` emacs provides will not be removed. In that case, you
won't be able to install ctags successfully. It will build but not
link.

@KazuakiM Guter Fang, ich habe die Hilfe verpasst. JSON-Unterstützung benötigt die Option --with-jansson .

$ brew reinstall --with-jansson universal-ctags/universal-ctags/universal-ctags
War diese Seite hilfreich?
0 / 5 - 0 Bewertungen

Verwandte Themen

alphaCTzo7G picture alphaCTzo7G  ·  7Kommentare

sparkcanon picture sparkcanon  ·  3Kommentare

blackb1rd picture blackb1rd  ·  8Kommentare

jayceekay picture jayceekay  ·  13Kommentare

masatake picture masatake  ·  18Kommentare