Public Types | |
Public Types | |
enum | PanicReasons { Panic_NoTransService, Panic_NoDefTranscoder, Panic_CantFindLib, Panic_UnknownMsgDomain, Panic_CantLoadMsgDomain, Panic_SynchronizationErr, Panic_SystemInit, PanicReasons_Count } |
Static Public Methods | |
Initialization amd Panic methods | |
void | Initialize () |
void | Terminate () |
void | panic (const PanicReasons reason) |
File Methods | |
unsigned int | curFilePos (FileHandle theFile) |
void | closeFile (FileHandle theFile) |
unsigned int | fileSize (FileHandle theFile) |
FileHandle | openFile (const char *const fileName) |
FileHandle | openFile (const XMLCh *const fileName) |
FileHandle | openStdInHandle () |
unsigned int | readFileBuffer (FileHandle theFile, const unsigned int toRead, XMLByte *const toFill) |
void | resetFile (FileHandle theFile) |
File System Methods | |
XMLCh * | getFullPath (const XMLCh *const srcPath) |
bool | isRelative (const XMLCh *const toCheck) |
XMLCh * | weavePaths (const XMLCh *const basePath, const XMLCh *const relativePath) |
XMLCh * | buildLocalPath (const XMLCh *const cacheDirPath, const XMLCh *const hostName, const XMLCh *const filePath) |
bool | findFile (const XMLCh *const filePath) |
unsigned int | createDirectory (const XMLCh *const basePath, const XMLCh *const pathName) |
bool | URLCacheGetEnv (const char *urlEntityCaching) |
XMLCh * | URLCacheDirGetEnv (const char *urlEntityCacheDir) |
Timing Methods | |
unsigned long | getCurrentMillis () |
Mutex Methods | |
void | closeMutex (void *const mtxHandle) |
void | lockMutex (void *const mtxHandle) |
void * | makeMutex () |
void | unlockMutex (void *const mtxHandle) |
External Message Support | |
XMLMsgLoader * | loadMsgSet (const XMLCh *const msgDomain) |
Miscellaneous synchronization methods | |
void * | compareAndSwap (void **toFill, const void *const newValue, const void *const toCompare) |
Atomic Increment and Decrement | |
int | atomicIncrement (int &location) |
int | atomicDecrement (int &location) |
NEL Character Handling | |
void | recognizeNEL (bool state) |
bool | isNELRecognized () |
Static Public Attributes | |
Public Static Data | |
XMLNetAccessor * | fgNetAccessor = 0 |
XMLTransService * | fgTransService = 0 |
This class contains methods that must be implemented in a platform specific manner. The actual implementations of these methods are available in the per-platform files indide src/util/Platforms
.
|
Decrements a single word variable atomically. This must be implemented by the per-platform driver. The atomicDecrement subroutine increments one word in a single atomic operation. This operation is useful when a counter variable is shared between several threads or processes. When updating such a counter variable, it is important to make sure that the fetch, update, and store operations occur atomically (are not interruptible).
|
|
Increments a single word variable atomically. This must be implemented by the per-platform driver. The atomicIncrement subroutine increments one word in a single atomic operation. This operation is useful when a counter variable is shared between several threads or processes. When updating such a counter variable, it is important to make sure that the fetch, update, and store operations occur atomically (are not interruptible).
|
|
Utility to join 3 paths This must be implementd by the per-platform driver and should weave disk cachedir path, the host name and the file path from the URL. It is an error to have a null disk cachedir path or a null file path.
|
|
Closes the file handle This must be implemented by the per-platform driver, which should use local file services to close the passed file handle, and to destroy the passed file handle and any allocated data or system resources it contains.
|
|
Closes a mutex handle Each per-platform driver must implement this. Only it knows what the actual content of the passed mutex handle is.
|
|
Conditionally updates or returns a single word variable atomically This must be implemented by the per-platform driver. The compareAndSwap subroutine performs an atomic operation which compares the contents of a single word variable with a stored old value. If the values are equal, a new value is stored in the single word variable and TRUE is returned; otherwise, the old value is set to the current value of the single word variable and FALSE is returned. The compareAndSwap subroutine is useful when a word value must be updated only if it has not been changed since it was last read. Note: The word containing the single word variable must be aligned on a full word boundary.
|
|
Create directory for caching the entity files
|
|
Get the current file position This must be implemented by the per-platform driver, which should use local file services to deterine the current position within the passed file. Since the file API provided here only reads, if the host platform supports separate read/write positions, only the read position is of any interest, and hence should be the one returned.
|
|
Returns the file size This must be implemented by the per-platform driver, which should use local file services to determine the current size of the file represented by the passed handle.
|
|
Checks the existance of a file or directory The input to this function should be fully qualified path
|
|
Gets the system time in milliseconds This must be implemented by the per-platform driver, which should use local services to return the current value of a running millisecond timer. Note that the value returned is only as accurate as the millisecond time of the underyling host system.
|
|
Gets the full path from a relative path This must be implemented by the per-platform driver. It should complete a relative path using the 'current directory', or whatever the local equivalent of a current directory is. If the passed source path is actually fully qualified, then a straight copy of it will be returned.
|
|
Perform per-process parser initialization Initialization must be called first in any client code. |
|
Return the value of fgNEL flag. |
|
Determines if a path is relative or absolute This must be implemented by the per-platform driver, which should determine whether the passed path is relative or not. The concept of relative and absolute might be... well relative on different platforms. But, as long as the determination is made consistently and in coordination with the weavePaths() method, it should work for any platform.
|
|
Loads the message set from among the available domains The returned object must be dynamically allocated and the caller becomes responsible for cleaning it up.
|
|
Locks a mutex handle Each per-platform driver must implement this. Only it knows what the actual content of the passed mutex handle is.
|
|
Make a new mutex Each per-platform driver must implement this. Only it knows what the actual content of the passed mutex handle is. The returned handle pointer will be eventually passed to closeMutex() which is also implemented by the platform driver. |
|
Opens a named file This must be implemented by the per-platform driver, which should use local file services to open the passed file. If it fails, a null handle pointer should be returned.
|
|
Opens the file This must be implemented by the per-platform driver, which should use local file services to open passed file. If it fails, a null handle pointer should be returned.
|
|
Opens the standard input as a file This must be implemented by the per-platform driver, which should use local file services to open a handle to the standard input. It should be a copy of the standard input handle, since it will be closed later!
|
|
The panic mechanism. If, during initialization, we cannot even get far enough along to get transcoding up or get message loading working, we call this method. Each platform can implement it however they want. This method is expected to display something meaningful and end the process. The enum indicates why its being called, to allow the per-platform code to display or log something more specific if desired.
|
|
Reads the file buffer This must be implemented by the per-platform driver, which should use local file services to read up to 'toRead' bytes of data from the passed file, and return those bytes in the 'toFill' buffer. It is not an error not to read the requested number of bytes. When the end of file is reached, zero should be returned.
|
|
This function enables the recognition of NEL char as whitespace chars which is disabled by default. It is only called once per process. Once it is set, any subsequent calls will result in exception being thrown. Note: Turning this option on will make the parser non complicant. |
|
Resets the file handle This must be implemented by the per-platform driver which will use local file services to reset the file position to the start of the the file.
|
|
Perform per-process parser termination The termination call is currently optional, to aid those dynamically loading the parser to clean up before exit, or to avoid spurious reports from leak detectors. |
|
Unlocks a mutex Each per-platform driver must implement this. Only it knows what the actual content of the passed mutex handle is. Note that, since the underlying system synchronization services are used, Xerces cannot guarantee that lock/unlock operaitons are correctly enforced on a per-thread basis or that incorrect nesting of lock/unlock operations will be caught.
|
|
Utility to join two paths This must be implemented by the per-platform driver, and should weave the relative path part together with the base part and return a new path that represents this combination. If the relative part turns out to be fully qualified, it will be returned as is. If it is not, then it will be woven onto the passed base path, by removing one path component for each leading "../" (or whatever is the equivalent in the local system) in the relative path.
|
|
The network accessor This is provided by the per-platform driver, so each platform can choose what actual implementation it wants to use. The object must be dynamically allocated. Note that you may optionally, if your platform driver does not install a network accessor, set it manually from your client code after calling Initialize(). This works because this object is not required during initialization, and only comes into play during actual XML parsing. |
|
The transcoding service.
This is provided by the per platform driver, so each platform can choose what implemenation it wants to use. When the platform independent initialization code needs to get a transcoding service object, it will call |