|
PTLib
Version 2.18.8
|
Class for a process that is a dynamically loaded library. More...
#include <pprocess.h>


Public Member Functions | |
| virtual void | Main () |
| < Dummy Main() as libraries do not have one. More... | |
Construction | |
| PLibraryProcess (const char *manuf="", const char *name="", unsigned majorVersionNum=1, unsigned minorVersionNum=0, CodeStatus statusCode=ReleaseCode, unsigned buildNum=1, bool suppressStartup=false) | |
| Create a new process instance. More... | |
Public Member Functions inherited from PProcess | |
| void | PreInitialise (int argc, char **argv) |
Internal initialisation function called directly from InternalMain(). More... | |
| virtual int | InternalMain (void *arg=NULL) |
| Main function for process, called from real main after initialisation. More... | |
| virtual bool | IsServiceProcess () const |
| bool | SignalTimerChange () |
| ~PProcess () | |
| Comparison | Compare (const PObject &obj) const |
| Compare two process instances. More... | |
| virtual void | PrintOn (ostream &strm) const |
| This will print out performance indicators for the process. More... | |
| virtual void | Terminate () |
| Terminate the process. More... | |
| PProcess (const char *manuf="", const char *name="", unsigned majorVersion=1, unsigned minorVersion=0, CodeStatus status=ReleaseCode, unsigned patchVersion=1, bool library=false, bool suppressStartup=false, unsigned oemVersion=0) | |
| Create a new process instance. More... | |
| void | Startup () |
| Start up all items registered with PProcessStartupFactory. More... | |
| bool | GetAllThreadIdentifiers (std::vector< PThreadIdentifier > &identifiers) |
| Return the operating system thread identifiers of all threads. More... | |
| PThread * | GetThread (PThreadIdentifier threadId) const |
| Return the thread for the operating system thread identifier. More... | |
| virtual void | OnThreadStart (PThread &thread) |
| Callback for when a thread is started by the PTLib system. More... | |
| virtual void | OnThreadEnded (PThread &thread) |
| Callback for when a thread is ended if wqas started in the PTLib system. More... | |
| virtual bool | OnInterrupt (bool terminating) |
| Callback for when a ^C (SIGINT), hangup (SIGHUP) or termination request (SIGTERM) is received by process. More... | |
| void | SetTerminationValue (int value) |
| Set the termination value for the process. More... | |
| int | GetTerminationValue () const |
| Get the termination value for the process. More... | |
| PArgList & | GetArguments () |
| Get the programme arguments. More... | |
| virtual const PString & | GetManufacturer () const |
| Get the name of the manufacturer of the software. More... | |
| virtual const PString & | GetName () const |
| Get the name of the process. More... | |
| virtual PString | GetVersion (PBoolean full=true) const |
| Get the version of the software. More... | |
| const PFilePath & | GetFile () const |
| Get the processes executable image file path. More... | |
| PProcessIdentifier | GetProcessID () const |
| Get the platform dependent process identifier for the process. More... | |
| bool | IsMultipleInstance () const |
| Indicate if this is the second, or more, instance of this executable. More... | |
| PTime | GetStartTime () const |
| Return the time at which the program was started. More... | |
| void | GetMemoryUsage (MemoryUsage &usage) const |
| Get process memory suage. More... | |
| PPROFILE_EXCLUDE (bool GetProcessTimes(Times ×) const ) | |
| PPROFILE_EXCLUDE (static bool GetSystemTimes(Times ×)) | |
| PString | GetUserName () const |
| Get the effective user name of the owner of the process, eg "root" etc. More... | |
| PBoolean | SetUserName (const PString &username, PBoolean permanent=false) |
| Set the effective owner of the process. More... | |
| PDirectory | GetHomeDirectory () const |
| Get the "home" directory for the logged in user. More... | |
| PString | GetGroupName () const |
| Get the effective group name of the owner of the process, eg "root" etc. More... | |
| PBoolean | SetGroupName (const PString &groupname, PBoolean permanent=false) |
| Set the effective group of the process. More... | |
| int | GetMaxHandles () const |
| Get the maximum file handle value for the process. More... | |
| PBoolean | SetMaxHandles (int newLimit) |
| Set the maximum number of file handles for the process. More... | |
| virtual PString | GetConfigurationFile () |
| Get the default file to use in PConfig instances. More... | |
| void | SetConfigurationPath (const PString &path) |
| Set the default file or set of directories to search for use in PConfig. More... | |
| virtual void | AddRunTimeSignalHandlers (const int *signals=NULL) |
| Add all the C run-time signal handlers. More... | |
| virtual void | RemoveRunTimeSignalHandlers () |
| Remove all the C run-time signal handlers. More... | |
| virtual void | AsynchronousRunTimeSignal (int signal, PProcessIdentifier source) |
| Asynchronous C run-time signal handler, direct callback from OS. More... | |
| virtual void | HandleRunTimeSignal (const RunTimeSignalInfo &signalInfo) |
| Synchronous C run-time signal handler, this is executed in the housekeeper thread. More... | |
| virtual void | HandleRunTimeSignal (int signal) |
Public Member Functions inherited from PThread | |
| bool | IsAutoDelete () const |
| int | PXBlockOnChildTerminate (int pid, const PTimeInterval &timeout) |
| int | PXBlockOnIO (int handle, int type, const PTimeInterval &timeout) |
| void | PXAbortBlock () const |
| void | PrintOn (ostream &strm) const |
| Standard stream print function. More... | |
| P_DECLARE_TRACED_ENUM (Priority, LowestPriority, LowPriority, NormalPriority, HighPriority, HighestPriority) | |
| Codes for thread priorities. More... | |
| PThread (PINDEX stack, AutoDeleteFlag deletion=AutoDeleteThread, Priority priorityLevel=NormalPriority, const PString &threadName=PString::Empty()) | |
| Create a new thread instance. More... | |
| ~PThread () | |
Destroy the thread, this simply calls the Terminate() function with all its restrictions and penalties. More... | |
| virtual void | Restart () |
| Restart a terminated thread using the same stack priority etc that was current when the thread terminated. More... | |
| virtual PBoolean | IsTerminated () const |
| Determine if the thread has been terminated or ran to completion. More... | |
| void | WaitForTermination () const |
| Block and wait for the thread to terminate. More... | |
| PBoolean | WaitForTermination (const PTimeInterval &maxWait) const |
| Block and wait for the thread to terminate. More... | |
| virtual void | Suspend (PBoolean susp=true) |
| Suspend or resume the thread. More... | |
| virtual void | Resume () |
Resume thread execution, this is identical to Suspend(false). More... | |
| virtual PBoolean | IsSuspended () const |
| Determine if the thread is currently suspended. More... | |
| virtual void | SetPriority (Priority priorityLevel) |
| Set the priority of the thread relative to other threads in the current process. More... | |
| virtual Priority | GetPriority () const |
| Get the current priority of the thread in the current process. More... | |
| virtual void | SetAutoDelete (AutoDeleteFlag deletion=AutoDeleteThread) |
| Set the flag indicating thread object is to be automatically deleted when the thread ends. More... | |
| void | SetNoAutoDelete () |
| Reet the flag indicating thread object is to be automatically deleted when the thread ends. More... | |
| virtual PString | GetThreadName () const |
| Get the name of the thread. More... | |
| virtual void | SetThreadName (const PString &name) |
| Change the name of the thread. More... | |
| PPROFILE_EXCLUDE (PThreadIdentifier GetThreadId() const ) | |
| PPROFILE_EXCLUDE (static PThreadIdentifier GetCurrentThreadId()) | |
| PPROFILE_EXCLUDE (PUniqueThreadIdentifier GetUniqueIdentifier() const ) | |
| PPROFILE_EXCLUDE (static PUniqueThreadIdentifier GetCurrentUniqueIdentifier()) | |
| PPROFILE_EXCLUDE (static PINDEX GetTotalCount()) | |
| PPROFILE_EXCLUDE (bool GetTimes(Times ×)) | |
| PPROFILE_EXCLUDE (static bool GetTimes(PThreadIdentifier id, Times ×)) | |
| PPROFILE_EXCLUDE (static void GetTimes(std::vector< Times > ×)) | |
Public Member Functions inherited from PObject | |
| __inline unsigned | GetTraceContextIdentifier () const |
| Get PTRACE context identifier. More... | |
| __inline void | SetTraceContextIdentifier (unsigned id) |
| __inline void | SetTraceContextIdentifier (const PObject &obj) |
| __inline void | SetTraceContextIdentifier (const PObject *obj) |
| __inline void | CopyTraceContextIdentifier (PObject &obj) const |
| __inline void | CopyTraceContextIdentifier (PObject *obj) const |
| virtual | ~PObject () |
| __inline const char * | GetClass () const |
| __inline bool | IsClass (const char *name) const |
| __inline const PObject * | PTraceObjectInstance () const |
| virtual PObject * | Clone () const |
| Create a copy of the class on the heap. More... | |
| template<class CLS > | |
| CLS * | CloneAs () const |
| As for Clone() but converts to specified type. More... | |
| virtual PINDEX | HashFunction () const |
This function yields a hash value required by the PDictionary class. More... | |
| virtual Comparison | CompareObjectMemoryDirect (const PObject &obj) const |
| Determine the byte wise comparison of two objects. More... | |
| bool | operator== (const PObject &obj) const |
| Compare the two objects. More... | |
| bool | operator!= (const PObject &obj) const |
| Compare the two objects. More... | |
| bool | operator< (const PObject &obj) const |
| Compare the two objects. More... | |
| bool | operator> (const PObject &obj) const |
| Compare the two objects. More... | |
| bool | operator<= (const PObject &obj) const |
| Compare the two objects. More... | |
| bool | operator>= (const PObject &obj) const |
| Compare the two objects. More... | |
| virtual void | ReadFrom (istream &strm) |
| Input the contents of the object from the stream. More... | |
Additional Inherited Members | |
Public Types inherited from PProcess | |
| enum | CodeStatus { AlphaCode, BetaCode, ReleaseCode, HotfixCode } |
| Release status for the program. More... | |
Public Types inherited from PThread | |
| enum | AutoDeleteFlag { AutoDeleteThread, NoAutoDeleteThread } |
| Codes for thread autodelete flag. More... | |
Public Types inherited from PObject | |
| enum | Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 } |
Result of the comparison operation performed by the Compare() function. More... | |
Static Public Member Functions inherited from PProcess | |
| static PString | GetOSClass () |
| Get the class of the operating system the process is running on, eg "unix". More... | |
| static PString | GetOSName () |
| Get the name of the operating system the process is running on, eg "Linux". More... | |
| static PString | GetOSHardware () |
| Get the hardware the process is running on, eg "sparc". More... | |
| static PString | GetOSVersion () |
| Get the version of the operating system the process is running on, eg "2.0.33". More... | |
| static bool | IsOSVersion (unsigned major, unsigned minor=0, unsigned build=0) |
| See if operating system is later than the version specified. More... | |
| static PDirectory | GetOSConfigDir () |
| Get the configuration directory of the operating system the process is running on, eg "/etc" for Unix, "c:\windows" for Win95 or "c:\winnt\system32\drivers\etc" for NT. More... | |
| static PString | GetLibVersion () |
| Get the version of the PTLib library the process is running on, eg "2.5beta3". More... | |
| static PProcess & | Current () |
| Get the current processes object instance. More... | |
| static PBoolean | IsInitialised () |
| Determine if the current processes object instance has been initialised. More... | |
| static PProcessIdentifier | GetCurrentProcessID () |
| Get the platform dependent process identifier for the currentprocess. More... | |
| static const char * | GetRunTimeSignalName (int signal) |
| Get the name of the signal. More... | |
Static Public Member Functions inherited from PThread | |
| static bool | WaitAndDelete (PThread *&thread, const PTimeInterval &maxWait=10000, PMutex *mutex=NULL, bool lock=true) |
| Wait for thread termination and delete object. More... | |
| static void | Sleep (const PTimeInterval &delay) |
| Suspend the current thread for the specified amount of time. More... | |
| static PString | GetThreadName (PThreadIdentifier id) |
| Get the name of the thread. More... | |
| static PString | GetCurrentThreadName () |
| Get the current threads name. More... | |
| static PString | GetIdentifiersAsString (PThreadIdentifier tid, PUniqueThreadIdentifier uid) |
| Convert to thread identifers as a string. More... | |
| static void | GetTimes (std::list< Times > ×) |
| static void | GetTimes (std::set< Times > ×) |
| static int | GetPercentageCPU (Times &previousTimes, const PTimeInterval &period=PTimeInterval(0, 1), PThreadIdentifier id=PNullThreadIdentifier) |
| Calculate the percentage CPU used over a period of time. More... | |
| static unsigned | GetNumProcessors () |
| Get number of processors, or processor cores, this machine has available. More... | |
| static PThread * | Current () |
| Get the currently running thread object instance. More... | |
| static void | Yield () |
| Yield to another thread without blocking. More... | |
| static PThread * | Create (const PNotifier ¬ifier, INT parameter=0, AutoDeleteFlag deletion=AutoDeleteThread, Priority priorityLevel=NormalPriority, const PString &threadName=PString::Empty(), PINDEX stackSize=0) |
| Create a simple thread executing the specified notifier. More... | |
| static PThread * | Create (const PNotifier ¬ifier, const PString &threadName) |
Static Public Member Functions inherited from PObject | |
| static __inline void | CopyTraceContextIdentifier (PObject &to, const PObject &from) |
| static __inline void | CopyTraceContextIdentifier (PObject &to, const PObject *from) |
| static __inline void | CopyTraceContextIdentifier (PObject *to, const PObject &from) |
| static __inline void | CopyTraceContextIdentifier (PObject *to, const PObject *from) |
| static __inline const char * | Class () |
| static __inline const PObject * | PTraceObjectInstance (const char *) |
| static __inline const PObject * | PTraceObjectInstance (const PObject *obj) |
| template<typename T > | |
| static Comparison | Compare2 (T v1, T v2) |
| Compare two types, returning Comparison type. More... | |
| static Comparison | InternalCompareObjectMemoryDirect (const PObject *obj1, const PObject *obj2, PINDEX size) |
| Internal function caled from CompareObjectMemoryDirect() More... | |
Protected Types inherited from PProcess | |
| typedef std::map < PThreadIdentifier, PThread * > | ThreadMap |
| typedef std::list< PSharedPtr < PExternalThread > > | ThreadList |
Protected Types inherited from PThread | |
| enum | Type { e_IsAutoDelete, e_IsManualDelete, e_IsProcess, e_IsExternal } |
Protected Member Functions inherited from PProcess | |
| void | PlatformConstruct () |
| void | PlatformDestruct () |
| void | InternalThreadStarted (PThread *thread) |
| void | InternalThreadEnded (PThread *thread) |
| void | HouseKeeping () |
| void | InternalPostRunTimeSignal (int signal, PProcessIdentifier source) |
| void | InternalHandleRunTimeSignal (const RunTimeSignalInfo &signalInfo) |
| PDICTIONARY (PXFdDict, POrdinalKey, PThread) | |
Protected Member Functions inherited from PObject | |
| PObject () | |
| Constructor for PObject, made protected so cannot ever create one on its own. More... | |
Static Protected Member Functions inherited from PProcess | |
| static PRunTimeSignalHandler | PlatformSetRunTimeSignalHandler (int signal) |
| static void | PlatformResetRunTimeSignalHandler (int signal, PRunTimeSignalHandler previous) |
Protected Attributes inherited from PProcess | |
| bool | m_library |
| int | m_terminationValue |
| PString | m_manufacturer |
| PString | m_productName |
| VersionInfo | m_version |
| PFilePath | m_executableFile |
| PStringArray | m_configurationPaths |
| PArgList | m_arguments |
| int | m_maxHandles |
| PTime | m_programStartTime |
| atomic< bool > | m_shuttingDown |
| PCriticalSection | m_threadMutex |
| ThreadMap | m_activeThreads |
| ThreadList | m_externalThreads |
| PSyncQueue< PThread * > | m_autoDeleteThreads |
| atomic< bool > | m_keepingHouse |
| PThread * | m_houseKeeper |
| PSyncPoint | m_signalHouseKeeper |
| PProcessIdentifier | m_processID |
| std::vector < PRunTimeSignalHandler > | m_previousRunTimeSignalHandlers |
| std::vector< RunTimeSignalInfo > | m_RunTimeSignalsQueueBuffer |
| size_t | m_RunTimeSignalsQueueIn |
| size_t | m_RunTimeSignalsQueueOut |
| PCriticalSection | m_RunTimeSignalsQueueMutex |
Protected Attributes inherited from PThread | |
| enum PThread::Type | m_type |
| PINDEX | m_originalStackSize |
| PString | m_threadName |
| PCriticalSection | m_threadNameMutex |
| PThreadIdentifier | m_threadId |
| PUniqueThreadIdentifier | m_uniqueId |
Protected Attributes inherited from PObject | |
| unsigned | m_traceContextIdentifier |
Static Protected Attributes inherited from PProcess | |
| static POrdinalToString::Initialiser const | InternalSigNames [] |
Class for a process that is a dynamically loaded library.
|
inline |
Create a new process instance.
| manuf | Name of manufacturer |
| name | Name of product |
| majorVersionNum | Major version number of the product |
| minorVersionNum | Minor version number of the product |
| statusCode | Development status of the product |
| buildNum | Build number of the product |
| suppressStartup | Do not execute Startup() |
|
inlinevirtual |