2002-03-13 09:58:43 +00:00
|
|
|
|
/* GSPrivate
|
|
|
|
|
Copyright (C) 2001,2002 Free Software Foundation, Inc.
|
2001-11-10 17:31:39 +00:00
|
|
|
|
|
|
|
|
|
Written by: Richard Frith-Macdonald <rfm@gnu.org>
|
|
|
|
|
|
|
|
|
|
This file is part of the GNUstep Base Library.
|
|
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
|
modify it under the terms of the GNU Library General Public
|
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
|
version 2 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
Library General Public License for more details.
|
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
|
|
|
License along with this library; if not, write to the Free
|
2006-03-08 11:28:59 +00:00
|
|
|
|
Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
|
|
|
MA 02111 USA.
|
2001-11-10 17:31:39 +00:00
|
|
|
|
*/
|
|
|
|
|
|
2006-10-18 15:36:52 +00:00
|
|
|
|
#ifndef _GSPrivate_h_
|
|
|
|
|
#define _GSPrivate_h_
|
|
|
|
|
|
|
|
|
|
@class NSNotification;
|
|
|
|
|
|
|
|
|
|
#if (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3))
|
|
|
|
|
#define GS_ATTRIB_PRIVATE __attribute__ ((visibility("internal")))
|
|
|
|
|
#else
|
|
|
|
|
#define GS_ATTRIB_PRIVATE
|
|
|
|
|
#endif
|
2001-11-10 17:31:39 +00:00
|
|
|
|
|
2006-03-10 10:46:37 +00:00
|
|
|
|
/* Absolute Gregorian date for NSDate reference date Jan 01 2001
|
|
|
|
|
*
|
|
|
|
|
* N = 1; // day of month
|
|
|
|
|
* N = N + 0; // days in prior months for year
|
|
|
|
|
* N = N + // days this year
|
|
|
|
|
* + 365 * (year - 1) // days in previous years ignoring leap days
|
|
|
|
|
* + (year - 1)/4 // Julian leap days before this year...
|
|
|
|
|
* - (year - 1)/100 // ...minus prior century years...
|
|
|
|
|
* + (year - 1)/400 // ...plus prior years divisible by 400
|
|
|
|
|
*/
|
|
|
|
|
#define GREGORIAN_REFERENCE 730486
|
|
|
|
|
|
|
|
|
|
|
2003-10-16 20:41:50 +00:00
|
|
|
|
#include "GNUstepBase/GSObjCRuntime.h"
|
2006-10-09 14:00:01 +00:00
|
|
|
|
#include "Foundation/NSString.h"
|
2001-11-10 17:31:39 +00:00
|
|
|
|
|
2004-09-07 14:27:14 +00:00
|
|
|
|
/**
|
|
|
|
|
* Macro to manage memory for chunks of code that need to work with
|
|
|
|
|
* arrays of items. Use this to start the block of code using
|
|
|
|
|
* the array and GS_ENDITEMBUF() to end it. The idea is to ensure that small
|
|
|
|
|
* arrays are allocated on the stack (for speed), but large arrays are
|
|
|
|
|
* allocated from the heap (to avoid stack overflow).
|
|
|
|
|
*/
|
|
|
|
|
#define GS_BEGINITEMBUF(P, S, T) { \
|
|
|
|
|
T _ibuf[(S) <= GS_MAX_OBJECTS_FROM_STACK ? (S) : 0]; \
|
|
|
|
|
T *_base = ((S) <= GS_MAX_OBJECTS_FROM_STACK) ? _ibuf \
|
|
|
|
|
: (T*)NSZoneMalloc(NSDefaultMallocZone(), (S) * sizeof(T)); \
|
|
|
|
|
T *(P) = _base;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Macro to manage memory for chunks of code that need to work with
|
|
|
|
|
* arrays of items. Use GS_BEGINITEMBUF() to start the block of code using
|
|
|
|
|
* the array and this macro to end it.
|
|
|
|
|
*/
|
|
|
|
|
#define GS_ENDITEMBUF() \
|
|
|
|
|
if (_base != _ibuf) \
|
|
|
|
|
NSZoneFree(NSDefaultMallocZone(), _base); \
|
|
|
|
|
}
|
|
|
|
|
|
2003-10-16 20:41:50 +00:00
|
|
|
|
/**
|
|
|
|
|
* Macro to manage memory for chunks of code that need to work with
|
|
|
|
|
* arrays of objects. Use this to start the block of code using
|
|
|
|
|
* the array and GS_ENDIDBUF() to end it. The idea is to ensure that small
|
2003-10-14 09:00:42 +00:00
|
|
|
|
* arrays are allocated on the stack (for speed), but large arrays are
|
|
|
|
|
* allocated from the heap (to avoid stack overflow).
|
|
|
|
|
*/
|
2004-09-07 14:27:14 +00:00
|
|
|
|
#define GS_BEGINIDBUF(P, S) GS_BEGINITEMBUF(P, S, id)
|
2003-10-16 20:41:50 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Macro to manage memory for chunks of code that need to work with
|
|
|
|
|
* arrays of objects. Use GS_BEGINIDBUF() to start the block of code using
|
|
|
|
|
* the array and this macro to end it.
|
|
|
|
|
*/
|
2004-09-07 14:27:14 +00:00
|
|
|
|
#define GS_ENDIDBUF() GS_ENDITEMBUF()
|
2003-10-14 09:00:42 +00:00
|
|
|
|
|
2003-11-06 21:11:39 +00:00
|
|
|
|
/**
|
|
|
|
|
* Macro to consistently replace public accessable
|
|
|
|
|
* constant strings with dynamically allocated versions.
|
2003-12-23 17:22:06 +00:00
|
|
|
|
* This method assumes an initialized NSStringClass symbol
|
2003-11-06 21:11:39 +00:00
|
|
|
|
* which contains the Class object of NSString. <br>
|
2003-12-23 17:22:06 +00:00
|
|
|
|
* Most public accessible strings are used in collection classes
|
|
|
|
|
* like NSDictionary, and therefore tend to receive -isEqual:
|
2003-11-06 21:11:39 +00:00
|
|
|
|
* messages (and therefore -hash) rather often. Statically
|
2003-12-23 17:22:06 +00:00
|
|
|
|
* allocated strings must calculate their hash values while
|
2003-11-06 21:11:39 +00:00
|
|
|
|
* dynamically allocated strings can store them. This optimization
|
2003-12-23 17:22:06 +00:00
|
|
|
|
* is by far more effective than using NSString * const.
|
|
|
|
|
* The drawback is that the memory management cannot enforce these values
|
2003-11-06 21:11:39 +00:00
|
|
|
|
* to remain unaltered as it would for variables declared NSString * const.
|
|
|
|
|
* Yet the optimization of the stored hash value is currently deemed
|
|
|
|
|
* more important.
|
|
|
|
|
*/
|
|
|
|
|
#define GS_REPLACE_CONSTANT_STRING(ID) \
|
|
|
|
|
ID = [[NSStringClass alloc] initWithCString: [ID cString]]
|
|
|
|
|
/* Using cString here is OK here
|
|
|
|
|
because NXConstantString returns a pointer
|
|
|
|
|
to it's internal pointer. */
|
|
|
|
|
|
2006-05-30 11:19:44 +00:00
|
|
|
|
/*
|
|
|
|
|
* Type to hold either UTF-16 (unichar) or 8-bit encodings,
|
|
|
|
|
* while satisfying alignment constraints.
|
|
|
|
|
*/
|
|
|
|
|
typedef union {
|
|
|
|
|
unichar *u; // 16-bit unicode characters.
|
|
|
|
|
unsigned char *c; // 8-bit characters.
|
|
|
|
|
} GSCharPtr;
|
|
|
|
|
|
2001-11-10 17:31:39 +00:00
|
|
|
|
/*
|
2002-03-13 09:58:43 +00:00
|
|
|
|
* Private concrete string classes.
|
|
|
|
|
* NB. All these concrete string classes MUST have the same initial ivar
|
|
|
|
|
* layout so that we can swap between them as necessary.
|
|
|
|
|
* The initial layout must also match that of NXConstantString (which is
|
|
|
|
|
* determined by the compiler) - an initial pointer to the string data
|
|
|
|
|
* followed by the string length (number of characters).
|
|
|
|
|
*/
|
|
|
|
|
@interface GSString : NSString
|
|
|
|
|
{
|
2006-05-30 11:19:44 +00:00
|
|
|
|
GSCharPtr _contents;
|
2002-03-13 09:58:43 +00:00
|
|
|
|
unsigned int _count;
|
|
|
|
|
struct {
|
|
|
|
|
unsigned int wide: 1; // 16-bit characters in string?
|
2003-11-05 02:11:49 +00:00
|
|
|
|
unsigned int free: 1; // Set if the instance owns the
|
|
|
|
|
// _contents buffer
|
2002-03-13 09:58:43 +00:00
|
|
|
|
unsigned int unused: 2;
|
|
|
|
|
unsigned int hash: 28;
|
|
|
|
|
} _flags;
|
|
|
|
|
}
|
|
|
|
|
@end
|
|
|
|
|
|
2004-05-14 10:52:30 +00:00
|
|
|
|
/*
|
|
|
|
|
* GSMutableString - concrete mutable string, capable of changing its storage
|
|
|
|
|
* from holding 8-bit to 16-bit character set.
|
|
|
|
|
*/
|
|
|
|
|
@interface GSMutableString : NSMutableString
|
|
|
|
|
{
|
|
|
|
|
union {
|
|
|
|
|
unichar *u;
|
|
|
|
|
unsigned char *c;
|
|
|
|
|
} _contents;
|
|
|
|
|
unsigned int _count;
|
|
|
|
|
struct {
|
|
|
|
|
unsigned int wide: 1;
|
|
|
|
|
unsigned int free: 1;
|
|
|
|
|
unsigned int unused: 2;
|
|
|
|
|
unsigned int hash: 28;
|
|
|
|
|
} _flags;
|
|
|
|
|
NSZone *_zone;
|
|
|
|
|
unsigned int _capacity;
|
|
|
|
|
}
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Typedef for access to internals of concrete string objects.
|
|
|
|
|
*/
|
|
|
|
|
typedef struct {
|
|
|
|
|
@defs(GSMutableString)
|
|
|
|
|
} GSStr_t;
|
|
|
|
|
typedef GSStr_t *GSStr;
|
|
|
|
|
|
|
|
|
|
/*
|
2006-10-09 14:00:01 +00:00
|
|
|
|
* Function to append to GSStr
|
2004-05-14 10:52:30 +00:00
|
|
|
|
*/
|
|
|
|
|
extern void GSStrAppendUnichars(GSStr s, const unichar *u, unsigned l);
|
2006-10-09 14:00:01 +00:00
|
|
|
|
/*
|
|
|
|
|
* Make the content of this string into unicode if it is not in
|
|
|
|
|
* the external defaults C string encoding.
|
|
|
|
|
*/
|
|
|
|
|
void GSStrExternalize(GSStr s);
|
|
|
|
|
|
2004-05-14 10:52:30 +00:00
|
|
|
|
|
2002-03-13 09:58:43 +00:00
|
|
|
|
/*
|
|
|
|
|
* Enumeration for MacOS-X compatibility user defaults settings.
|
2001-11-10 17:31:39 +00:00
|
|
|
|
* For efficiency, we save defaults information which is used by the
|
|
|
|
|
* base library.
|
|
|
|
|
*/
|
|
|
|
|
typedef enum {
|
|
|
|
|
GSMacOSXCompatible, // General behavior flag.
|
|
|
|
|
GSOldStyleGeometry, // Control geometry string output.
|
|
|
|
|
GSLogSyslog, // Force logging to go to syslog.
|
2005-02-22 14:06:28 +00:00
|
|
|
|
GSLogThread, // Include thread ID in log message.
|
2001-11-10 17:31:39 +00:00
|
|
|
|
NSWriteOldStylePropertyLists, // Control PList output.
|
|
|
|
|
GSUserDefaultMaxFlag // End marker.
|
|
|
|
|
} GSUserDefaultFlagType;
|
|
|
|
|
|
2004-01-25 18:39:20 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* This class exists simply as a mechanism for encapsulating arrays
|
|
|
|
|
* encoded using [NSKeyedArchiver-encodeArrayOfObjCType:count:at:]
|
|
|
|
|
*/
|
|
|
|
|
@interface _NSKeyedCoderOldStyleArray : NSObject <NSCoding>
|
|
|
|
|
{
|
|
|
|
|
char _t[2];
|
|
|
|
|
unsigned _c;
|
|
|
|
|
unsigned _s;
|
|
|
|
|
const void *_a;
|
|
|
|
|
NSData *_d; // Only valid after initWithCoder:
|
|
|
|
|
}
|
|
|
|
|
- (const void*) bytes;
|
|
|
|
|
- (unsigned) count;
|
|
|
|
|
- (void) encodeWithCoder: (NSCoder*)aCoder;
|
|
|
|
|
- (id) initWithCoder: (NSCoder*)aCoder;
|
|
|
|
|
- (id) initWithObjCType: (const char*)t count: (int)c at: (const void*)a;
|
|
|
|
|
- (unsigned) size;
|
|
|
|
|
- (const char*) type;
|
|
|
|
|
@end
|
|
|
|
|
|
2006-02-23 15:45:43 +00:00
|
|
|
|
/*
|
|
|
|
|
* Functions used by the NSRunLoop and friends for processing
|
2006-10-19 13:51:19 +00:00
|
|
|
|
* queued notifications and task completion events.
|
2006-02-23 15:45:43 +00:00
|
|
|
|
*/
|
2006-10-19 13:51:19 +00:00
|
|
|
|
BOOL GSPrivateCheckTasks(void) GS_ATTRIB_PRIVATE;
|
|
|
|
|
void GSPrivateNotifyASAP(void) GS_ATTRIB_PRIVATE;
|
|
|
|
|
void GSPrivateNotifyIdle(void) GS_ATTRIB_PRIVATE;
|
|
|
|
|
BOOL GSPrivateNotifyMore(void) GS_ATTRIB_PRIVATE;
|
2006-02-23 15:45:43 +00:00
|
|
|
|
|
2006-10-09 14:00:01 +00:00
|
|
|
|
/* This class exists to encapsulate various otherwise unrelated functions
|
|
|
|
|
* so that we expose a single global symbol (the class) whose name marks it
|
|
|
|
|
* very clearly as for private/internal use only. Avoiding the exposure
|
|
|
|
|
* (and hence possible accidental use) of symbols for each function ...
|
|
|
|
|
* The formal implementation of the class is a near empty implementation
|
2006-10-16 09:30:18 +00:00
|
|
|
|
* (in Additions/GSPrivate.m), with most methods being provided by other
|
2006-10-09 14:00:01 +00:00
|
|
|
|
* categories in the files wishing to expose some functionality for use
|
|
|
|
|
* by other parts of the base library.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
@interface GSPrivate : NSObject
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2006-10-09 14:00:01 +00:00
|
|
|
|
/* Return the text describing the last system error to have occurred.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (NSString*) error;
|
|
|
|
|
- (NSString*) error: (long)number;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
@end
|
|
|
|
|
|
2006-10-18 15:36:52 +00:00
|
|
|
|
extern GSPrivate *_GSPrivate;
|
|
|
|
|
|
|
|
|
|
@interface GSPrivate (ProcessInfo)
|
2006-10-09 14:00:01 +00:00
|
|
|
|
/* Used by NSException uncaught exception handler - must not call any
|
|
|
|
|
* methods/functions which might cause a recursive exception.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (const char*) argZero;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
|
|
|
|
|
/* get a flag from an environment variable - return def if not defined.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (BOOL) environmentFlag: (const char *)name defaultValue: (BOOL)def;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
@end
|
|
|
|
|
|
2006-10-18 15:36:52 +00:00
|
|
|
|
@interface GSPrivate (Unicode)
|
2006-10-09 14:00:01 +00:00
|
|
|
|
/* get the available string encodings (nul terminated array)
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (NSStringEncoding*) availableEncodings;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
|
|
|
|
|
/* get the default C-string encoding.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (NSStringEncoding) defaultCStringEncoding;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
|
|
|
|
|
/* get the name of a string encoding as an NSString.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (NSString*) encodingName: (NSStringEncoding)encoding;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
|
|
|
|
|
/* determine whether data in a particular encoding can
|
|
|
|
|
* generally be represented as 8-bit characters including ascii.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (BOOL) isByteEncoding: (NSStringEncoding)encoding;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
|
|
|
|
|
/* determine whether encoding is currently supported.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (BOOL) isEncodingSupported: (NSStringEncoding)encoding;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
2006-10-18 15:36:52 +00:00
|
|
|
|
@interface GSPrivate (UserDefaults)
|
2006-10-09 14:00:01 +00:00
|
|
|
|
/*
|
|
|
|
|
* Get one of several potentially useful flags.
|
|
|
|
|
*/
|
2006-10-18 15:36:52 +00:00
|
|
|
|
- (BOOL) userDefaultsFlag: (GSUserDefaultFlagType)type;
|
2006-10-09 14:00:01 +00:00
|
|
|
|
@end
|
|
|
|
|
|
2006-10-18 15:36:52 +00:00
|
|
|
|
/* Get default locale quickly (usually from cache).
|
|
|
|
|
* External apps would cache the locale themselves.
|
|
|
|
|
*/
|
|
|
|
|
NSDictionary *
|
|
|
|
|
GSPrivateDefaultLocale() GS_ATTRIB_PRIVATE;
|
|
|
|
|
|
|
|
|
|
#endif /* _GSPrivate_h_ */
|
2002-03-13 09:58:43 +00:00
|
|
|
|
|