2012-08-24 08:05:30 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -fblocks -Wno-objc-root-class -Wdocumentation -Wdocumentation-pedantic -verify %s
|
2012-07-12 05:38:39 +08:00
|
|
|
|
|
|
|
@class NSString;
|
|
|
|
|
2012-07-13 09:06:46 +08:00
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@interface Test1
|
2012-07-12 05:38:39 +08:00
|
|
|
// expected-warning@+2 {{empty paragraph passed to '\brief' command}}
|
|
|
|
/**
|
2012-08-07 01:08:27 +08:00
|
|
|
* \brief\author Aaa
|
2012-07-12 05:38:39 +08:00
|
|
|
* \param aaa Aaa
|
|
|
|
* \param bbb Bbb
|
|
|
|
*/
|
|
|
|
+ (NSString *)test1:(NSString *)aaa suffix:(NSString *)bbb;
|
|
|
|
|
|
|
|
// expected-warning@+2 {{parameter 'aab' not found in the function declaration}} expected-note@+2 {{did you mean 'aaa'?}}
|
|
|
|
/**
|
|
|
|
* \param aab Aaa
|
|
|
|
*/
|
|
|
|
+ (NSString *)test2:(NSString *)aaa;
|
2012-07-13 09:06:46 +08:00
|
|
|
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@property int test3; // a property: ObjCPropertyDecl
|
|
|
|
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@property int test4; // a property: ObjCPropertyDecl
|
2012-07-12 05:38:39 +08:00
|
|
|
@end
|
|
|
|
|
2012-07-13 09:06:46 +08:00
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@interface Test1()
|
|
|
|
@end
|
|
|
|
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@implementation Test1 // a class implementation : ObjCImplementationDecl
|
|
|
|
+ (NSString *)test1:(NSString *)aaa suffix:(NSString *)bbb {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ (NSString *)test2:(NSString *)aaa {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
@synthesize test3; // a property implementation: ObjCPropertyImplDecl
|
|
|
|
@dynamic test4; // a property implementation: ObjCPropertyImplDecl
|
|
|
|
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
NSString *_test5;
|
|
|
|
@end
|
|
|
|
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@interface Test1(Test1Category) // a category: ObjCCategoryDecl
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
+ (NSString *)test3:(NSString *)aaa;
|
|
|
|
@end
|
|
|
|
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@implementation Test1(Test1Category) // a category implementation: ObjCCategoryImplDecl
|
|
|
|
+ (NSString *)test3:(NSString *)aaa {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
@end
|
|
|
|
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@protocol TestProto1 // a protocol: ObjCProtocolDecl
|
|
|
|
@end
|
|
|
|
|
|
|
|
int a;
|
|
|
|
|
|
|
|
// expected-warning@+1 {{empty paragraph passed to '\brief' command}}
|
2012-08-07 01:08:27 +08:00
|
|
|
/// \brief\author Aaa
|
2012-07-13 09:06:46 +08:00
|
|
|
@interface Test4
|
|
|
|
@end
|
|
|
|
|
|
|
|
int b;
|
|
|
|
|
2012-08-07 00:29:26 +08:00
|
|
|
@interface TestReturns1
|
|
|
|
/// \returns Aaa
|
|
|
|
- (int)test1:(NSString *)aaa;
|
|
|
|
|
|
|
|
// expected-warning@+1 {{'\returns' command used in a comment that is attached to a method returning void}}
|
|
|
|
/// \returns Aaa
|
|
|
|
- (void)test2:(NSString *)aaa;
|
|
|
|
@end
|
|
|
|
|
2012-08-25 01:45:39 +08:00
|
|
|
// expected-warning@+2 {{parameter 'bbb' not found in the function declaration}} expected-note@+2 {{did you mean 'ccc'?}}
|
2012-08-24 08:05:30 +08:00
|
|
|
/// \param aaa Meow.
|
|
|
|
/// \param bbb Bbb.
|
|
|
|
/// \returns aaa.
|
2012-08-25 01:45:39 +08:00
|
|
|
typedef int (^test_param1)(int aaa, int ccc);
|
2012-08-24 08:05:30 +08:00
|
|
|
|
2013-03-06 03:40:47 +08:00
|
|
|
// rdar://13094352
|
2013-03-07 01:55:30 +08:00
|
|
|
// expected-warning@+2 {{'@method' command should be used in a comment attached to an Objective-C method declaration}}
|
2013-03-06 03:40:47 +08:00
|
|
|
@interface I
|
|
|
|
/*! @method Base64EncodeEx
|
|
|
|
*/
|
|
|
|
typedef id ID;
|
|
|
|
- (unsigned) Base64EncodeEx : (ID)Arg;
|
|
|
|
@end
|
2013-03-08 07:33:11 +08:00
|
|
|
|
|
|
|
// rdar://12379114
|
|
|
|
// expected-warning@+5 {{'@interface' command should not be used in a comment attached to a non-interface declaration}}
|
|
|
|
// expected-warning@+5 {{'@classdesign' command should not be used in a comment attached to a non-container declaration}}
|
|
|
|
// expected-warning@+5 {{'@coclass' command should not be used in a comment attached to a non-container declaration}}
|
|
|
|
@interface NSObject @end
|
|
|
|
/*!
|
|
|
|
@interface IOCommandGate
|
|
|
|
@classdesign Multiple paragraphs go here.
|
|
|
|
@coclass myCoClass
|
|
|
|
*/
|
|
|
|
|
|
|
|
typedef id OBJ;
|
|
|
|
@interface IOCommandGate : NSObject {
|
|
|
|
OBJ iv;
|
|
|
|
}
|
|
|
|
@end
|
|
|
|
|
2013-03-19 07:45:52 +08:00
|
|
|
// rdar://12379114
|
|
|
|
// expected-warning@+4 {{'@methodgroup' command should be used in a comment attached to an Objective-C method declaration}}
|
|
|
|
// expected-warning@+6 {{'@method' command should be used in a comment attached to an Objective-C method declaratio}}
|
|
|
|
@interface rdar12379114
|
|
|
|
/*!
|
|
|
|
@methodgroup Creating a request
|
|
|
|
*/
|
|
|
|
/*!
|
|
|
|
@method initWithTimeout is the 2nd method
|
|
|
|
*/
|
|
|
|
typedef unsigned int NSTimeInterval;
|
|
|
|
- (id)initWithTimeout:(NSTimeInterval)timeout;
|
|
|
|
@end
|
|
|
|
|
2013-03-08 07:33:11 +08:00
|
|
|
// expected-warning@+2 {{'@protocol' command should not be used in a comment attached to a non-protocol declaration}}
|
|
|
|
/*!
|
|
|
|
@protocol PROTO
|
|
|
|
*/
|
|
|
|
struct S;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@interface NSArray This is an array
|
|
|
|
*/
|
|
|
|
@class NSArray;
|
|
|
|
@interface NSArray @end
|
|
|
|
|
2013-05-04 07:15:20 +08:00
|
|
|
// expected-warning@+3 {{unknown command tag name}}
|
2013-03-08 07:33:11 +08:00
|
|
|
/*!
|
|
|
|
@interface NSMutableArray
|
|
|
|
@super NSArray
|
|
|
|
*/
|
|
|
|
@interface NSMutableArray : NSArray @end
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@protocol MyProto
|
|
|
|
*/
|
|
|
|
@protocol MyProto @end
|
|
|
|
|
|
|
|
// expected-warning@+2 {{'@protocol' command should not be used in a comment attached to a non-protocol declaration}}
|
|
|
|
/*!
|
|
|
|
@protocol MyProto
|
|
|
|
*/
|
|
|
|
@interface INTF <MyProto> @end
|
|
|
|
|
|
|
|
// expected-warning@+2 {{'@struct' command should not be used in a comment attached to a non-struct declaration}}
|
|
|
|
/*!
|
|
|
|
@struct S1 THIS IS IT
|
|
|
|
*/
|
|
|
|
@interface S1 @end
|
2013-05-10 01:18:52 +08:00
|
|
|
|
|
|
|
// expected-warning@+1 {{unknown command tag name}}
|
|
|
|
/// \t bbb IS_DOXYGEN_END
|
|
|
|
int FooBar();
|
2013-05-14 01:27:00 +08:00
|
|
|
|
|
|
|
// rdar://13836387
|
|
|
|
/** \brief Module handling the incoming notifications from the system.
|
|
|
|
*
|
|
|
|
* This includes:
|
|
|
|
* - Network Reachability
|
|
|
|
* - Power State
|
|
|
|
* - Low Disk
|
|
|
|
*/
|
|
|
|
@interface BRC : NSObject
|
|
|
|
- (void)removeReach:(NSObject*)observer;
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation BRC : NSObject
|
|
|
|
- (void)removeReach:(NSObject*)observer // expected-note {{previous declaration is here}}
|
|
|
|
{
|
|
|
|
}
|
|
|
|
- (void)removeReach:(NSObject*)observer // expected-error {{duplicate declaration of method 'removeReach:'}}
|
|
|
|
{
|
|
|
|
}
|
|
|
|
@end
|
2013-05-21 07:40:39 +08:00
|
|
|
|
|
|
|
// rdar://13927330
|
|
|
|
/// @class Asset <- '@class' may be used in a comment attached to a an interface declaration
|
|
|
|
@interface Asset : NSObject
|
|
|
|
@end
|
|
|
|
|
2013-05-31 02:53:21 +08:00
|
|
|
// rdar://14024851 Check that this does not enter an infinite loop
|
|
|
|
@interface rdar14024851
|
|
|
|
-(void)meth; // expected-note {{declared here}}
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation rdar14024851 // expected-warning {{method definition for 'meth' not found}} expected-note {{previous definition}}
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation rdar14024851 // expected-error {{reimplementation}}
|
|
|
|
/// \brief comment
|
|
|
|
-(void)meth {}
|
|
|
|
@end
|
2013-06-24 12:41:32 +08:00
|
|
|
|
|
|
|
// rdar://14124644
|
|
|
|
@interface test_vararg1
|
|
|
|
/// @param[in] arg somthing
|
|
|
|
/// @param[in] ... This is vararg
|
|
|
|
- (void) VarArgMeth : (id)arg, ...;
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation test_vararg1
|
|
|
|
/// @param[in] arg somthing
|
|
|
|
/// @param[in] ... This is vararg
|
|
|
|
- (void) VarArgMeth : (id)arg, ... {}
|
|
|
|
@end
|
|
|
|
|
2017-04-21 22:17:49 +08:00
|
|
|
/**
|
|
|
|
* blockPointerVariable
|
|
|
|
*
|
|
|
|
* @param i is integer.
|
|
|
|
* @returns integer.
|
|
|
|
*/
|
|
|
|
int (^blockPointerVariable)(int i);
|
|
|
|
|
|
|
|
struct HasFields {
|
|
|
|
/**
|
|
|
|
* blockPointerField
|
|
|
|
*
|
|
|
|
* \param i is integer.
|
|
|
|
* \returns integer.
|
|
|
|
*/
|
|
|
|
int (^blockPointerFields)(int i);
|
|
|
|
};
|
|
|
|
|
|
|
|
// expected-warning@+5 {{'\returns' command used in a comment that is attached to a function returning void}}
|
|
|
|
/**
|
|
|
|
* functionPointerVariable
|
|
|
|
*
|
|
|
|
* \param p not here.
|
|
|
|
* \returns integer.
|
|
|
|
*/
|
2017-04-26 20:46:27 +08:00
|
|
|
void (^_Nullable blockPointerVariableThatLeadsNowhere)();
|
2017-04-21 22:17:49 +08:00
|
|
|
|
|
|
|
@interface CheckFunctionBlockPointerVars {
|
|
|
|
/**
|
|
|
|
* functionPointerIVar
|
|
|
|
*
|
|
|
|
* @param i is integer.
|
|
|
|
* @returns integer.
|
|
|
|
*/
|
|
|
|
int (*functionPointerIVar)(int i);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* blockPointerIVar
|
|
|
|
*
|
|
|
|
* \param i is integer.
|
|
|
|
* \returns integer.
|
|
|
|
*/
|
|
|
|
int (^blockPointerIVar)(int i);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* functionPointerProperty
|
|
|
|
*
|
|
|
|
* @param i is integer.
|
|
|
|
* @returns integer.
|
|
|
|
*/
|
|
|
|
@property int (*functionPointerProperty)(int i);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* blockPointerProperty
|
|
|
|
*
|
|
|
|
* \param i is integer.
|
|
|
|
* \returns integer.
|
|
|
|
*/
|
|
|
|
@property int (^blockPointerProperty)(int i);
|
|
|
|
|
2017-04-26 21:09:28 +08:00
|
|
|
/**
|
|
|
|
* blockReturnsNothing
|
|
|
|
*
|
|
|
|
* \returns Nothing, but can allow this as this pattern is used to document the
|
|
|
|
* value that the property getter returns.
|
|
|
|
*/
|
|
|
|
@property void (^blockReturnsNothing)();
|
|
|
|
|
2017-04-21 22:17:49 +08:00
|
|
|
@end
|
2017-10-07 04:51:04 +08:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Block typedef with variadic params.
|
|
|
|
*
|
|
|
|
* @param a
|
|
|
|
* works
|
|
|
|
*
|
|
|
|
* @param ...
|
|
|
|
* now should work too.
|
|
|
|
*/
|
|
|
|
typedef void (^VariadicBlockType)(int a, ...);
|