Source code

Revision control

Copy as Markdown

Other Tools

This chapter describes the functions for retrieving and setting errors
and the error codes set by NSPR.
- `Error Type <#Error_Type>`__
- `Error Functions <#Error_Functions>`__
- `Error Codes <#Error_Codes>`__
For information on naming conventions for NSPR types, functions, and
macros, see `NSPR Naming
Conventions <Introduction_to_NSPR#NSPR_Naming_Conventions>`__.
.. _Error_Type:
Error Type
----------
- :ref:`PRErrorCode`
.. _Error_Functions:
Error Functions
---------------
- :ref:`PR_SetError`
- :ref:`PR_SetErrorText`
- :ref:`PR_GetError`
- :ref:`PR_GetOSError`
- :ref:`PR_GetErrorTextLength`
- :ref:`PR_GetErrorText`
.. _Error_Codes:
Error Codes
-----------
Error codes defined in ``prerror.h``:
``PR_OUT_OF_MEMORY_ERROR``
Insufficient memory to perform request.
``PR_BAD_DESCRIPTOR_ERROR``
The file descriptor used as an argument in the preceding function is
invalid.
``PR_WOULD_BLOCK_ERROR``
The operation would have blocked, which conflicts with the semantics
that have been established.
``PR_ACCESS_FAULT_ERROR``
One of the arguments of the preceding function specified an invalid
memory address.
``PR_INVALID_METHOD_ERROR``
The preceding function is invalid for the type of file descriptor
used.
``PR_ILLEGAL_ACCESS_ERROR``
One of the arguments of the preceding function specified an invalid
memory address.
``PR_UNKNOWN_ERROR``
Some unknown error has occurred.
``PR_PENDING_INTERRUPT_ERROR``
The operation terminated because another thread has interrupted it
with :ref:`PR_Interrupt`.
``PR_NOT_IMPLEMENTED_ERROR``
The preceding function has not been implemented.
``PR_IO_ERROR``
The preceding I/O function encountered some sort of an error, perhaps
an invalid device.
``PR_IO_TIMEOUT_ERROR``
The I/O operation has not completed in the time specified for the
preceding function.
``PR_IO_PENDING_ERROR``
An I/O operation has been attempted on a file descriptor that is
currently busy with another operation.
``PR_DIRECTORY_OPEN_ERROR``
The directory could not be opened.
``PR_INVALID_ARGUMENT_ERROR``
One or more of the arguments to the function is invalid.
``PR_ADDRESS_NOT_AVAILABLE_ERROR``
The network address (:ref:`PRNetAddr`) is not available (probably in
use).
``PR_ADDRESS_NOT_SUPPORTED_ERROR``
The type of network address specified is not supported.
``PR_IS_CONNECTED_ERROR``
An attempt to connect on an already connected network file
descriptor.
``PR_BAD_ADDRESS_ERROR``
The network address specified is invalid (as reported by the
network).
``PR_ADDRESS_IN_USE_ERROR``
Network address specified (:ref:`PRNetAddr`) is in use.
``PR_CONNECT_REFUSED_ERROR``
The peer has refused to allow the connection to be established.
``PR_NETWORK_UNREACHABLE_ERROR``
The network address specifies a host that is unreachable (perhaps
temporary).
``PR_CONNECT_TIMEOUT_ERROR``
The connection attempt did not complete in a reasonable period of
time.
``PR_NOT_CONNECTED_ERROR``
The preceding function attempted to use connected semantics on a
network file descriptor that was not connected.
``PR_LOAD_LIBRARY_ERROR``
Failure to load a dynamic library.
``PR_UNLOAD_LIBRARY_ERROR``
Failure to unload a dynamic library.
``PR_FIND_SYMBOL_ERROR``
Symbol could not be found in the specified library.
``PR_INSUFFICIENT_RESOURCES_ERROR``
There are insufficient system resources to process the request.
``PR_DIRECTORY_LOOKUP_ERROR``
A directory lookup on a network address has failed.
``PR_TPD_RANGE_ERROR``
Attempt to access a thread-private data index that is out of range of
any index that has been allocated to the process.
``PR_PROC_DESC_TABLE_FULL_ERROR``
The process' table for holding open file descriptors is full.
``PR_SYS_DESC_TABLE_FULL_ERROR``
The system's table for holding open file descriptors has been
exceeded.
``PR_NOT_SOCKET_ERROR``
An attempt to use a non-network file descriptor on a network-only
operation.
``PR_NOT_TCP_SOCKET_ERROR``
Attempt to perform a TCP specific function on a non-TCP file
descriptor.
``PR_SOCKET_ADDRESS_IS_BOUND_ERRO``
Attempt to bind an address to a TCP file descriptor that is already
bound.
``PR_NO_ACCESS_RIGHTS_ERROR``
Calling thread does not have privilege to perform the operation
requested.
``PR_OPERATION_NOT_SUPPORTED_ERRO``
The requested operation is not supported by the platform.
``PR_PROTOCOL_NOT_SUPPORTED_ERROR``
The host operating system does not support the protocol requested.
``PR_REMOTE_FILE_ERROR``
Access to the remote file has been severed.
``PR_BUFFER_OVERFLOW_ERROR``
The value retrieved is too large to be stored in the buffer provided.
``PR_CONNECT_RESET_ERROR``
The (TCP) connection has been reset by the peer.
``PR_RANGE_ERROR``
Unused.
``PR_DEADLOCK_ERROR``
Performing the requested operation would have caused a deadlock. The
deadlock was avoided.
``PR_FILE_IS_LOCKED_ERROR``
An attempt to acquire a lock on a file has failed because the file is
already locked.
``PR_FILE_TOO_BIG_ERROR``
Completing the write or seek operation would have resulted in a file
larger than the system could handle.
``PR_NO_DEVICE_SPACE_ERROR``
The device for storing the file is full.
``PR_PIPE_ERROR``
Unused.
``PR_NO_SEEK_DEVICE_ERROR``
Unused.
``PR_IS_DIRECTORY_ERROR``
Attempt to perform a normal file operation on a directory.
``PR_LOOP_ERROR``
Symbolic link loop.
``PR_NAME_TOO_LONG_ERROR``
Filename is longer than allowed by the host operating system.
``PR_FILE_NOT_FOUND_ERROR``
The requested file was not found.
``PR_NOT_DIRECTORY_ERROR``
Attempt to perform directory specific operations on a normal file.
``PR_READ_ONLY_FILESYSTEM_ERROR``
Attempt to write to a read-only file system.
``PR_DIRECTORY_NOT_EMPTY_ERROR``
Attempt to delete a directory that is not empty.
``PR_FILESYSTEM_MOUNTED_ERROR``
Attempt to delete or rename a file object while the file system is
busy.
``PR_NOT_SAME_DEVICE_ERROR``
Request to rename a file to a file system on another device.
``PR_DIRECTORY_CORRUPTED_ERROR``
The directory object in the file system is corrupted.
``PR_FILE_EXISTS_ERROR``
Attempt to create or rename a file when the new name is already being
used.
``PR_MAX_DIRECTORY_ENTRIES_ERROR``
Attempt to add new filename to directory would exceed the limit
allowed.
``PR_INVALID_DEVICE_STATE_ERROR``
The device was in an invalid state to complete the desired operation.
``PR_DEVICE_IS_LOCKED_ERROR``
The device needed to perform the desired request is locked.
``PR_NO_MORE_FILES_ERROR``
There are no more entries in the directory.
``PR_END_OF_FILE_ERROR``
Unexpectedly encountered end of file (Mac OS only).
``PR_FILE_SEEK_ERROR``
An unexpected seek error (Mac OS only).
``PR_FILE_IS_BUSY_ERROR``
The file is busy and the operation cannot be performed.
``PR_IN_PROGRESS_ERROR``
The operation is still in progress (probably a nonblocking connect).
``PR_ALREADY_INITIATED_ERROR``
The (retried) operation has already been initiated (probably a
nonblocking connect).
``PR_GROUP_EMPTY_ERROR``
The wait group is empty.
``PR_INVALID_STATE_ERROR``
The attempted operation is on an object that was in an improper state
to perform the request.
``PR_MAX_ERROR``
Placeholder for the end of the list.