|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| | Warnings generated by -Wdocumentation-unknown-command did only have a
start location, not a full source range. This resulted in only the
"carret" being show in messages, and IDEs highlighting only the single
initial character.
llvm-svn: 285056 | 
| | 
| 
| 
| 
| 
| 
| 
| | fixes.
Differential revision: http://reviews.llvm.org/D17060
llvm-svn: 260414 | 
| | 
| 
| 
| 
| 
| | with "**/"
llvm-svn: 235057 | 
| | 
| 
| 
| 
| 
| | const from some other StringRefs since its implicitly const already.
llvm-svn: 216825 | 
| | 
| 
| 
| 
| 
| | Code in headers shouldn't be conditional on the build configuration.
llvm-svn: 196656 | 
| | 
| 
| 
| 
| 
| 
| 
| | token.
This would crash if the token is used in another diagnostic. PR18051.
llvm-svn: 196048 | 
| | 
| 
| 
| | llvm-svn: 189119 | 
| | 
| 
| 
| 
| 
| | warn in pedantic mode.
llvm-svn: 181523 | 
| | 
| 
| 
| 
| 
| 
| 
| | 'commands' will not go through typo fixit logic,
preserving the old behavior (no typo, no diagnostics).
// rdar://12381408
llvm-svn: 181521 | 
| | 
| 
| 
| | llvm-svn: 181464 | 
| | 
| 
| 
| 
| 
| 
| 
| | documentation commands. Patch was reviewed, along with
great suggestions for improvement, by Doug. 
// rdar://12381408
llvm-svn: 181458 | 
| | 
| 
| 
| 
| 
| 
| | tags off by default for now. Move diagnostic code
to DiagnosticCommentKinds.td. // rdar://12381408
llvm-svn: 181081 | 
| | 
| 
| 
| 
| 
| | commands. // rdar://12381408
llvm-svn: 181071 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * 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 | 
| | 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 174835 | 
| | 
| 
| 
| 
| 
| 
| | This also gives us 0.2% speedup on '-fsyntax-only -Wdocumentation' time for
a testcase that consists of all Clang headers.
llvm-svn: 174810 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This reimplements r173850 with a better approach:
(1) use a TableGen-generated matcher instead of doing a linear search;
(2) avoid allocations for new strings by converting code points to string
    iterals with TableGen.
llvm-svn: 173931 | 
| | 
| 
| 
| 
| 
| | This is required to use them in TableGen.
llvm-svn: 173924 | 
| | 
| 
| 
| 
| 
| | my last patch.
llvm-svn: 173856 | 
| | 
| 
| 
| 
| 
| 
| | references to their UTIF-8 encoding. Reviewed offline by Doug.
// rdar://12392215
llvm-svn: 173850 | 
| | 
| 
| 
| | llvm-svn: 172924 | 
| | 
| 
| 
| 
| 
| | This gives an about 1.8% improvement on Clang bootstrap with -Wdocumentation
llvm-svn: 171262 | 
| | 
| 
| 
| 
| 
| | since no Doxygen command starts with a digit.
llvm-svn: 163909 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 162986 | 
| | 
| 
| 
| 
| 
| | TableGen-generated string matcher.
llvm-svn: 162969 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | name.  This should reduce the amount of warning false positives about bad HTML
in comments when the comment author intended to put a reference to a template.
This change will also enable us parse the comment as intended in these cases.
Fixes part 1 of PR13374.
llvm-svn: 162407 | 
| | 
| 
| 
| | llvm-svn: 161548 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | hex: ) during comment parsing.
Now internal representation of plain text in comment AST does not contain
character references, but the characters themselves.
llvm-svn: 160891 | 
| | 
| 
| 
| 
| 
| | line of whitespace.
llvm-svn: 160464 | 
| | 
| 
| 
| 
| 
| | start tags' and 'HTML close tags' to 'HTML end tags' according to HTML spec.
llvm-svn: 160153 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | diagnostics implemented -- see testcases.
I created a new TableGen file for comment diagnostics,
DiagnosticCommentKinds.td, because comment diagnostics don't logically
fit into AST diagnostics file.  But I don't feel strongly about it.
This also implements support for self-closing HTML tags in comment
lexer and parser (for example, <br />).
In order to issue precise diagnostics CommentSema needs to know the
declaration the comment is attached to.  There is no easy way to find a decl by 
comment, so we match comments and decls in lockstep: after parsing one
declgroup we check if we have any new, not yet attached comments.  If we do --
then we do the usual comment-finding process.
It is interesting that this automatically handles trailing comments.
We pick up not only comments that precede the declaration, but also
comments that *follow* the declaration -- thanks to the lookahead in
the lexer: after parsing the declgroup we've consumed the semicolon
and looked ahead through comments.
Added -Wdocumentation-html flag for semantic HTML errors to allow the user to 
disable only HTML warnings (but not HTML parse errors, which we emit as
warnings in -Wdocumentation).
llvm-svn: 160078 | 
| | 
| 
| 
| | llvm-svn: 159963 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | very simple semantic analysis that just builds the AST; minor changes for lexer
to pick up source locations I didn't think about before.
Comments AST is modelled along the ideas of HTML AST: block and inline content.
* Block content is a paragraph or a command that has a paragraph as an argument
  or verbatim command.
* Inline content is placed within some block.  Inline content includes plain
  text, inline commands and HTML as tag soup.
llvm-svn: 159790 | 
| | 
| 
| 
| 
| 
| | character stream when we saw a '<' that is not a start of an HTML tag.
llvm-svn: 159303 | 
| | 
| 
| 
| 
| 
| | have only one semantic string value attached to it), at a cost of adding an additional token.
llvm-svn: 159270 | 
| | 
| 
| 
| 
| 
| | We already have a pointer to the beginning of the token, so use it to extract the text instead.
llvm-svn: 159269 | 
|  | llvm-svn: 159223 |