|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to reflect the new license.
We understand that people may be surprised that we're moving the header
entirely to discuss the new license. We checked this carefully with the
Foundation's lawyer and we believe this is the correct approach.
Essentially, all code in the project is now made available by the LLVM
project under our new license, so you will see that the license headers
include that license only. Some of our contributors have contributed
code under our old license, and accordingly, we have retained a copy of
our old license notice in the top-level files in each project and
repository.
llvm-svn: 351636 | 
| | 
| 
| 
| 
| 
| | sed -Ei 's/[[:space:]]+$//' include/**/*.{def,h,td} lib/**/*.{cpp,h}
llvm-svn: 338291 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | loc
Prior to this commit -Wdocumentation crashed when checking the @returns command
for declarations whose function/block pointer type included an attribute like
_Nullable.
rdar://31818195
llvm-svn: 301400 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that have a function/block pointer type
This commit improves the -Wdocumentation warning by making sure that @param and
@returns commands won't trigger warnings when used for fields, variables,
or properties whose type is a function/block pointer type. The
function/block pointer type must be specified directly with the declaration,
and when a typedef is used the warning is still emitted.
In the future we might also want to handle the std::function type as well.
rdar://24978538
llvm-svn: 300981 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Emit proper diagnostics when -Wdocumentation is used with constructs such as:
  template<typename T>
  using fn = int(T aaa, int ccc);
Previously clang wouldn't recognize the function and complain with
'comment that is not attached to a function declaration'.
Differential Revision: https://reviews.llvm.org/D23860
rdar://problem/27300695
llvm-svn: 279754 | 
| | 
| 
| 
| 
| 
| | This is in prepatation for @param TypeAliasTemplate support.
llvm-svn: 279691 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Give appropriate warnings with -Wdocumentation for @param comments
that refer to function aliases defined with 'using'. Very similar
to typedef's behavior. This does not add support for
TypeAliasTemplateDecl yet.
Differential Revision: https://reviews.llvm.org/D23783
rdar://problem/27300695
llvm-svn: 279662 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary: Removed unused headers, replaced some headers with forward class declarations
Patch by: Eugene <claprix@yandex.ru>
Differential Revision: https://reviews.llvm.org/D20100
llvm-svn: 275882 | 
| | 
| 
| 
| 
| 
| | No functional change is intended, just a small refactoring.
llvm-svn: 273647 | 
| | 
| 
| 
| 
| 
| | and mentioning the type. This works now that we have a conversion from ArrayRef<T*> to ArrayRef<const T*>.
llvm-svn: 216824 | 
| | 
| 
| 
| | llvm-svn: 208517 | 
| | 
| 
| 
| 
| 
| 
| 
| | Follow up to r200082.
Spotted by Dmitri
llvm-svn: 200105 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | A return type is the declared or deduced part of the function type specified in
the declaration.
A result type is the (potentially adjusted) type of the value of an expression
that calls the function.
Rule of thumb:
  * Declarations have return types and parameters.
  * Expressions have result types and arguments.
llvm-svn: 200082 | 
| | 
| 
| 
| 
| 
| 
| | that we consider a function for the purposes of checking \param and \returns,
look through reference types.
llvm-svn: 197530 | 
| | 
| 
| 
| 
| 
| | boost::function and similar function-like objects
llvm-svn: 197528 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
In general, this type node can be used to represent any type adjustment
that occurs implicitly without losing type sugar.  The immediate use of
this is to adjust the calling conventions of member function pointer
types without breaking template instantiation.
Fixes PR17996.
Reviewers: rsmith
Differential Revision: http://llvm-reviews.chandlerc.com/D2332
llvm-svn: 196451 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | trunk clang is a bit more aggressive about emitting unused-declaration
warnings, so adjust some AST code to match.  Specifically, use
LLVM_ATTRIBUTE_UNUSED for declarations which are never supposed to be
referenced, and turn references to declarations which are supposed to be
referenced into odr-uses.
llvm-svn: 190443 | 
| | 
| 
| 
| | llvm-svn: 189115 | 
| | 
| 
| 
| 
| 
| 
| | use can cause crash. No test is available. It is uncovered
by code browsing.  // rdar://14348205
llvm-svn: 185732 | 
| | 
| 
| 
| 
| 
| 
| 
| | Original patch by Fariborz Jahanian; extended by me.
Fixes rdar://14124644
llvm-svn: 184688 | 
| | 
| 
| 
| 
| 
| 
| 
| | constructor from None
Patch by Robert Wilhelm.
llvm-svn: 181139 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The TypeLoc hierarchy used the llvm::cast machinery to perform undefined
behavior by casting pointers/references to TypeLoc objects to derived types
and then using the derived copy constructors (or even returning pointers to
derived types that actually point to the original TypeLoc object).
Some context is in this thread:
http://lists.cs.uiuc.edu/pipermail/llvmdev/2012-December/056804.html
Though it's spread over a few months which can be hard to read in the mail
archive.
llvm-svn: 175462 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | http://llvm-reviews.chandlerc.com/D269
"Added dumping of declaration comments in ASTDumper. This required moving the
comment dumping code from CommentDumper so that the indentation is correct."
Patch by Philip Craig!
llvm-svn: 172409 | 
| | 
| 
| 
| | llvm-svn: 166287 | 
| | 
| 
| 
| 
| 
| 
| | for current(rewritten) comment and getParamNameAsWritten
to access param name coming with \param marker.
llvm-svn: 166231 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | XML comment for declarations which pretty-prints
declaration. I had to XFAIL one test annotate-comments.cpp.
This test is currently unmaintainable as written.
Dmitri G., can you see what we can do about this test.
We should change this test such that adding a new tag does not wreck
havoc to the test.
llvm-svn: 166130 | 
| | 
| 
| 
| 
| 
| | of their own.
llvm-svn: 165972 | 
| | 
| 
| 
| 
| 
| 
| | template when comment is comming from overridden declaration. 
// rdar://12378793
llvm-svn: 165953 | 
| | 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| | 'function-like' type that can be annotated with \param.
Thanks to Eli Friedman for noticing!
llvm-svn: 163985 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| | use \param and \returns in documentation.
Fixes PR13533.
llvm-svn: 162507 | 
| | 
| 
| 
| 
| 
| | Comment XML: add a root node kind for enums.
llvm-svn: 161442 | 
| | 
| 
| 
| | llvm-svn: 161435 | 
| | 
| 
| 
| | llvm-svn: 161352 | 
| | 
| 
| 
| 
| 
| | ObjC methods.
llvm-svn: 161324 | 
| | 
| 
| 
| 
| 
| | the function returns void.
llvm-svn: 161261 | 
| | 
| 
| 
| 
| 
| | switch.  Thanks Sean Silva for suggestion!
llvm-svn: 161225 | 
| | 
| 
| 
| 
| 
| | separate flags.
llvm-svn: 161217 | 
| | 
| 
| 
| 
| 
| | templates.
llvm-svn: 161215 | 
| | 
| 
| 
| 
| 
| | already extracting most of this, but discarding at the end of semantic analysis.
llvm-svn: 161140 | 
| | 
| 
| 
| 
| 
| 
| | TextComment node was considered whitespace even if it contained other child
nodes.
llvm-svn: 160474 | 
| | 
| 
| 
| | llvm-svn: 160452 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | despite __attribute__(__used__).  As explained by Argyrios,
> .a archive files do some stripping of their own and they remove .o files that
> contain functions that are not referenced by any other .o file.
The fix is to use these functions from another .o file.
Thanks, Argyrios!
llvm-svn: 160437 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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: 159860 | 
|  | 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 |