DoxyDoc
A sublime text plugin for C++ document autocompletion
Details
Installs
- Total 16K
- Win 7K
- Mac 3K
- Linux 6K
Jan 21 | Jan 20 | Jan 19 | Jan 18 | Jan 17 | Jan 16 | Jan 15 | Jan 14 | Jan 13 | Jan 12 | Jan 11 | Jan 10 | Jan 9 | Jan 8 | Jan 7 | Jan 6 | Jan 5 | Jan 4 | Jan 3 | Jan 2 | Jan 1 | Dec 31 | Dec 30 | Dec 29 | Dec 28 | Dec 27 | Dec 26 | Dec 25 | Dec 24 | Dec 23 | Dec 22 | Dec 21 | Dec 20 | Dec 19 | Dec 18 | Dec 17 | Dec 16 | Dec 15 | Dec 14 | Dec 13 | Dec 12 | Dec 11 | Dec 10 | Dec 9 | Dec 8 | Dec 7 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Windows | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 2 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 | 1 | 0 | 0 | 1 | 0 | 0 | 1 |
Mac | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
Linux | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
Readme
- Source
- raw.githubusercontent.com
DoxyDoc
DoxyDoc is a plug-in that allows you to auto-complete doc block comments for C++ using Doxygen. Inspired by PhpDoc and DocBlockr this was made due to frustrations due to lack of proper C++ support from DocBlockr. The latter plug-in had no capabilities to parse templated functions or classes and would just leave the comment hanging.
There are no plans to support other languages as DocBlockr does this job fairly well.
Installation
The easy way to install this is through Package Control.
- Press Ctrl + Shift + P
- Type “install” without quotes to get to Package Control: Install Package
- Type “DoxyDoc” without quotes and you'll see this package.
Another way to install this is through running git clone
of this repository in your package directory.
The command to do so is the following:
git clone https://github.com/Rapptz/doxydoc.git DoxyDoc
Usage
Just like DocBlockr, pressing /**
and then enter or tab would automatically insert the corresponding documentation.
There are no keyboard shortcuts to memorise.
As you can see, pressing enter consecutively would automatically continue the comment.
DoxyDoc also supports C++ function documenting in various forms.
A basic function is trivial to document:
If a function has a template parameter, a @tparam
property is automatically added as well.
However if the function uses the template type parameter in the function it'll try its best to not include it.
DoxyDoc also supports adding the @return
property if the return value is not void.
DoxyDoc also supports basic documenting of class names, templated or not.
Note that all the fields are just Sublime Text snippets, so tabbing over will allow you to seamlessly edit the parameters for the tags.
Along with automatically generating documentation, DoxyDoc allows autocompletion of some common Doxygen snippets as listing
all of the supported ones would be extremely big. You can get
a list of them by pressing @
and a list will pop up automatically.
A couple things from DocBlockr are lacking though, which you can find in the TODO below.
Issues and Limitations
C++ is notoriously hard to parse, so it'll be insane to say that this so-called parser is perfect as it is far from it. Occasional bugs are sure to pop up every so often, which is why I made this to be as simple as possible. Since the “parser” is essentially a bunch of regex under the hood, some abnormalities are bound to pop up because I chose to take part in two problems rather than one.
Limitations are mostly involving template parameters and some complex functions. I also haven't tried function pointers in function arguments, so that will most likely be faulty as well. You are free to open up an issue in the issue tracker if you believe the bug is too severe or it ruins your flow. You're also welcome to submit a patch yourself to fix the functionality. :)
Todo
- Allow configuration of options. Some examples:
- Ability to insert @author tags in the snippets
- Indentation choice
- Support other types of comments such as /// and //!
- Variable documentation