|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| | top-level HeaderDoc tags @functiongroup and
@methodgroup to doc. tags recognized.
// rdar://12379114 
llvm-svn: 177358 | 
| | 
| 
| 
| 
| 
| | improvements per Dmtiri's comments. // rdar://12379114
llvm-svn: 176739 | 
| | 
| 
| 
| 
| 
| 
| 
| | commands; top level tags such as @interface and
their 2nd level tags such as @coclass, etc.
// rdar://12379114
llvm-svn: 176667 | 
| | 
| 
| 
| 
| 
| | several diagnostics into one. // rdar://13094352
llvm-svn: 176560 | 
| | 
| 
| 
| 
| 
| | // rdar://13094352
llvm-svn: 176529 | 
| | 
| 
| 
| 
| 
| | // rdar://13094352.
llvm-svn: 176525 | 
| | 
| 
| 
| | llvm-svn: 176510 | 
| | 
| 
| 
| 
| 
| 
| | checkings and few other refactoring/cleanup.
// rdar://13094352.
llvm-svn: 176509 | 
| | 
| 
| 
| 
| 
| 
| | an @function comment is not followed by a function decl.
// rdar://13094352
llvm-svn: 176468 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * Use the term 'command marker', because the semantics of 'backslash' and 'at'
  commands are the same.  (Talking about 'at commands' makes them look like a
  special entity.)
* Sink the flag down into bitfields, reducing the size of AST nodes.
* Change the flag into an enum for clarity.  Boolean function parameters are
  not very clear.
* Add unittests for new tok::at_command tokens.
llvm-svn: 176461 | 
| | 
| 
| 
| 
| 
| | // rdar://13066276
llvm-svn: 176448 | 
| | 
| 
| 
| 
| 
| | to original command in diagnostic. // rdar://13066276
llvm-svn: 176444 | 
| | 
| 
| 
| 
| 
| | command source fidelity. // rdar://13066276
llvm-svn: 176401 | 
| | 
| 
| 
| 
| 
| 
| | in AST for source fidelity and use it in diagnostics 
to refer to the original format. // rdar://13066276
llvm-svn: 176387 | 
| | 
| 
| 
| 
| 
| 
| | think of them as having return values that may be computed. Don't
warn when using @return in their comment. // rdar://13189938
llvm-svn: 176147 | 
| | 
| 
| 
| 
| 
| 
| 
| | \headerfile command and representing it in an xml
document. Patch reviewed by Dmitri Gribenko.
// rdar://12397511
llvm-svn: 174109 | 
| | 
| 
| 
| 
| 
| | brought into 'clang' namespace by clang/Basic/LLVM.h
llvm-svn: 172323 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | uncovered.
This required manually correcting all of the incorrect main-module
headers I could find, and running the new llvm/utils/sort_includes.py
script over the files.
I also manually added quite a few missing headers that were uncovered by
shuffling the order or moving headers up to be main-module-headers.
llvm-svn: 169237 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | pull in all the generated Attr code.
Required to pull some functions out of line, but this shouldn't have a perf impact.
No functionality change.
llvm-svn: 169092 | 
| | 
| 
| 
| 
| 
| 
| | for current(rewritten) comment and getParamNameAsWritten
to access param name coming with \param marker.
llvm-svn: 166231 | 
| | 
| 
| 
| 
| 
| 
| | has none of its own. Factor in Doug's comments.
// rdar://12378793
llvm-svn: 165771 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | methods looking for documentation on a particular base
class inherited by any method that overrides the base class.
In case of redeclaration, as when objc method is defined
in the implementation, it also looks up for documentation
in class/class extension being redeclared.
llvm-svn: 165643 | 
| | 
| 
| 
| 
| 
| 
| | use it to suggest appropriate macro for __attribute__((deprecated)) in
-Wdocumentation-deprecated-sync.
llvm-svn: 164892 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | deprecation attribute ('deprecated', 'availability' or 'unavailable').
This warning is under a separate flag, -Wdocumentation-deprecated-sync, so it
can be turned off easily while leaving other -Wdocumentation warnings on.
llvm-svn: 164467 | 
| | 
| 
| 
| 
| 
| 
| | should be fine to use it without further explanations in the attached
paragraph, so the warning about empty paragraph was turned off for it.
llvm-svn: 163836 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | analysis registers a command, it becomes a "known" command for the lexer, since
it has an ID.  Having this freedom of choice to register a command is a good
thing since BriefParser does not need this.
But the parser should still invoke the correct semantic analysis method
(actOnUnknownCommand) in this case.
llvm-svn: 163646 | 
| | 
| 
| 
| | llvm-svn: 163546 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Now we have a list of all commands.  This is a good thing in itself, but it
also enables us to easily implement typo correction for command names.
With this change we have objects that contain information about each command,
so it makes sense to resolve command name just once during lexing (currently we
store command names as strings and do a linear search every time some property
value is needed).  Thus comment token and AST nodes were changed to contain a
command ID -- index into a tables of builtin and registered commands.  Unknown
commands are registered during parsing and thus are also uniformly assigned an
ID.  Using an ID instead of a StringRef is also a nice memory optimization
since ID is a small integer that fits into a common bitfield in Comment class.
This change implies that to get any information about a command (even a command
name) we need a CommandTraits object to resolve the command ID to CommandInfo*.
Currently a fresh temporary CommandTraits object is created whenever it is
needed since it does not have any state.  But with this change it has state --
new commands can be registered, so a CommandTraits object was added to
ASTContext.
Also, in libclang CXComment has to be expanded to include a CXTranslationUnit
so that all functions working on comment AST nodes can get a CommandTraits
object.  This breaks binary compatibility of CXComment APIs.
Now clang_FullComment_getAsXML(CXTranslationUnit TU, CXComment CXC) doesn't
need TU parameter anymore, so it was removed.  This is a source-incompatible
change for this C API.
llvm-svn: 163540 | 
| | 
| 
| 
| 
| 
| | TableGen-generated string matcher.
llvm-svn: 162969 | 
| | 
| 
| 
| 
| 
| 
| 
| | with parameter that is documented.
Fixes PR13670, <rdar://problem/12155840>.
llvm-svn: 162570 | 
| | 
| 
| 
| | llvm-svn: 161548 | 
| | 
| 
| 
| | llvm-svn: 161352 | 
| | 
| 
| 
| | llvm-svn: 161331 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Doxygen manual claims that multiple \brief or \returns commands will be merged
together, but actual behavior is different (second \brief command becomes a
part of a discussion, second \returns becomes a "Returns: blah" paragraph on
its own).  Anyway, it seems to be a bad idea to use multiple \brief or \returns
commands in a single command.
llvm-svn: 161325 | 
| | 
| 
| 
| 
| 
| | ObjC methods.
llvm-svn: 161324 | 
| | 
| 
| 
| 
| 
| | the function returns void.
llvm-svn: 161261 | 
| | 
| 
| 
| 
| 
| | separate flags.
llvm-svn: 161217 | 
| | 
| 
| 
| | llvm-svn: 161141 | 
| | 
| 
| 
| 
| 
| | already extracting most of this, but discarding at the end of semantic analysis.
llvm-svn: 161140 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The only caveat is renumbering CXCommentKind enum for aesthetic reasons -- this
breaks libclang binary compatibility, but should not be a problem since API is
so new.
This also fixes PR13372 as a side-effect.
llvm-svn: 161087 | 
| | 
| 
| 
| | llvm-svn: 160901 | 
| | 
| 
| 
| 
| 
| | arguments.  Just an optimization, no functional change.
llvm-svn: 160896 | 
| | 
| 
| 
| 
| 
| | parameter names.
llvm-svn: 160696 | 
| | 
| 
| 
| | llvm-svn: 160689 | 
| | 
| 
| 
| | llvm-svn: 160634 | 
| | 
| 
| 
| 
| 
| 
| 
| | rendering mode for clients that don't want to interpret Doxygen commands.
Also add a libclang API to query this information.
llvm-svn: 160633 | 
| | 
| 
| 
| | llvm-svn: 160481 | 
| | 
| 
| 
| | llvm-svn: 160414 | 
| | 
| 
| 
| 
| 
| | line with Statement AST nodes.
llvm-svn: 160182 | 
| | 
| 
| 
| 
| 
| | start tags' and 'HTML close tags' to 'HTML end tags' according to HTML spec.
llvm-svn: 160153 |