
`getdelim` and `getline` may free, allocate, or re-allocate the input buffer, ensuring its size is enough to hold the incoming line, the delimiter, and the null terminator. `*lineptr` must be a valid argument to `free`, which means it can be either 1. `NULL`, in which case these functions perform an allocation equivalent to a call to `malloc` even on failure. 2. A pointer returned by the `malloc` family of functions. Other pointers are UB (`alloca`, a pointer to a static, to a stack variable, etc.)
36 lines
1.0 KiB
Objective-C
36 lines
1.0 KiB
Objective-C
// Like the compiler, the static analyzer treats some functions differently if
|
|
// they come from a system header -- for example, it is assumed that system
|
|
// functions do not arbitrarily free() their parameters, and that some bugs
|
|
// found in system headers cannot be fixed by the user and should be
|
|
// suppressed.
|
|
#pragma clang system_header
|
|
|
|
typedef __typeof(sizeof(int)) size_t;
|
|
void *malloc(size_t);
|
|
void *calloc(size_t, size_t);
|
|
void free(void *);
|
|
void *alloca(size_t);
|
|
|
|
|
|
#if __OBJC__
|
|
|
|
#import "system-header-simulator-objc.h"
|
|
|
|
@interface Wrapper : NSData
|
|
- (id)initWithBytesNoCopy:(void *)bytes length:(NSUInteger)len;
|
|
@end
|
|
|
|
@implementation Wrapper
|
|
- (id)initWithBytesNoCopy:(void *)bytes length:(NSUInteger)len {
|
|
return [self initWithBytesNoCopy:bytes length:len freeWhenDone:1]; // no-warning
|
|
}
|
|
@end
|
|
|
|
@interface CustomData : NSData
|
|
+ (id)somethingNoCopy:(char *)bytes;
|
|
+ (id)somethingNoCopy:(void *)bytes length:(NSUInteger)length freeWhenDone:(BOOL)freeBuffer;
|
|
+ (id)something:(char *)bytes freeWhenDone:(BOOL)freeBuffer;
|
|
@end
|
|
|
|
#endif
|