Software:Netscape Portable Runtime

From HandWiki
Short description: C programming language library
Netscape Portable Runtime
Developer(s)Mozilla Foundation / Mozilla Corporation
Stable release4.29 (September 18, 2020; 3 years ago (2020-09-18)[1]) [±]
Written inC
Operating systemCross-platform
TypeSoftware library
LicenseMPL
Websitefirefox-source-docs.mozilla.org/nspr/index.html

The Netscape Portable Runtime, or NSPR, is a cross-platform abstraction layer library for the C programming language. It provides a uniform API for various operating system functions.[2]

History

NSPR was originally designed to provide a base for the Java virtual machine in Netscape 5. Over time it was extended to allow support for additional functionality used for Netscape's server and client software.[3] NSPR continues to be used today by Firefox as well as many of Oracle and Red Hat's server products.[2]

Features

Threads

NSPR provides a thread API. It uses the OS's threading capabilities where possible. It also provides support for sharing memory between threads, as well as creating and using thread pools. Locks, atomics, semaphores, and both cached and uncached monitors are provided.[4]

I/O

NSPR provides functions for working with files, directories, anonymous pipes and network sockets.[4]

Network addresses

NSPR defines an IP-centric network address object. Functions are provided to translate ASCII strings (DNS names) into NSPR's network address structures, regardless of whether the addressing technology uses IPv4 or IPv6.[3][4]

Time

NSPR makes timing facilities available in two forms: interval timing and calendar functions.

Interval timers are based on a free running 32-bit resolution timer. Their epoch and interval can be set as needed.

Calendar times are represented using 64-bit signed Unix time. NSPR provides functions for manipulating and converting timestamps.[3][4]

Memory management

NSPR provides API to perform the basic malloc, calloc, realloc and free functions. Depending on the platform, the functions may be implemented almost entirely in the NSPR runtime or simply shims that call immediately into the host operating system's offerings.[3][4]

Linking

Support for linking (shared library loading and unloading) forms part of NSPR's feature set. In most cases this is simply a smoothing over of the facilities offered by the various platform providers.[3][4]

Data structures

NSPR provides implementations of a circular linked list and a hash table.[4]

See also

References

External links