library: libCore #include "TUnixSystem.h" |
TUnixSystem
class description - header file - source file - inheritance tree (.pdf)
protected:
virtual char* DynamicPathName(const char* lib, Bool_t quiet = kFALSE)
static void* FindDynLib(const char* lib)
virtual const char* GetLinkedLibraries()
static int ReadUtmpFile()
static void* SearchUtmpEntry(int nentries, const char* tty)
static Func_t UnixDynFindSymbol(const char* lib, const char* entry)
static void UnixDynListLibs(const char* lib = "")
static void UnixDynListSymbols(const char* lib, const char* re = "")
static int UnixDynLoad(const char* lib)
static void UnixDynUnload(const char* lib)
static int UnixFilestat(const char* path, FileStat_t& buf)
static int UnixFSstat(const char* path, Long_t* id, Long_t* bsize, Long_t* blocks, Long_t* bfree)
static const char* UnixGetdirentry(void* dir)
static const char* UnixHomedirectory(const char* user = "0")
static void UnixIgnoreSignal(ESignals sig, Bool_t ignore)
static int UnixMakedir(const char* name)
static Long_t UnixNow()
static void* UnixOpendir(const char* name)
static int UnixRecv(int sock, void* buf, int len, int flag)
static void UnixResetSignal(ESignals sig)
static void UnixResetSignals()
static int UnixSelect(Int_t nfds, TFdSet* readready, TFdSet* writeready, Long_t timeout)
static int UnixSend(int sock, const void* buf, int len, int flag)
static int UnixSetitimer(Long_t ms)
static void UnixSigAlarmInterruptsSyscalls(Bool_t set)
static void UnixSignal(ESignals sig, void* h)
static const char* UnixSigname(ESignals sig)
static int UnixTcpConnect(const char* hostname, int port, int tcpwindowsize)
static int UnixTcpService(int port, Bool_t reuse, int backlog, int tcpwindowsize)
static int UnixUnixConnect(int port)
static int UnixUnixService(int port, int backlog)
static int UnixWaitchild()
public:
TUnixSystem()
TUnixSystem(const TUnixSystem&)
virtual ~TUnixSystem()
virtual void Abort(int code = 0)
virtual int AcceptConnection(int sock)
virtual Bool_t AccessPathName(const char* path, EAccessMode mode = kFileExists)
virtual void AddFileHandler(TFileHandler* fh)
virtual void AddSignalHandler(TSignalHandler* sh)
virtual void AddTimer(TTimer* ti)
virtual int AnnounceTcpService(int port, Bool_t reuse, int backlog, int tcpwindowsize = -1)
virtual int AnnounceUnixService(int port, int backlog)
virtual Bool_t ChangeDirectory(const char* path)
void CheckChilds()
Bool_t CheckDescriptors()
Bool_t CheckSignals(Bool_t sync)
virtual int Chmod(const char* file, UInt_t mode)
static TClass* Class()
virtual void CloseConnection(int sock, Bool_t force = kFALSE)
virtual void Closelog()
virtual int ClosePipe(FILE* pipe)
int ConnectService(const char* server, int port, int tcpwindowsize)
virtual int CopyFile(const char* from, const char* to, Bool_t overwrite = kFALSE)
virtual void DispatchOneEvent(Bool_t pendingOnly = kFALSE)
void DispatchSignals(ESignals sig)
Bool_t DispatchTimers(Bool_t mode)
virtual Func_t DynFindSymbol(const char* module, const char* entry)
virtual int Exec(const char* shellcmd)
virtual void Exit(int code, Bool_t mode = kTRUE)
virtual Bool_t ExpandPathName(TString& patbuf)
virtual char* ExpandPathName(const char* path)
virtual const char* FindFile(const char* search, TString& file, EAccessMode mode = kFileExists)
virtual void FreeDirectory(void* dirp)
virtual const char* GetDirEntry(void* dirp)
virtual const char* GetDynamicPath()
virtual Int_t GetEffectiveGid()
virtual Int_t GetEffectiveUid()
virtual const char* Getenv(const char* name)
virtual const char* GetError()
virtual Int_t GetFPEMask()
virtual int GetFsInfo(const char* path, Long_t* id, Long_t* bsize, Long_t* blocks, Long_t* bfree)
virtual Int_t GetGid(const char* group = "0")
virtual UserGroup_t* GetGroupInfo(Int_t gid)
virtual UserGroup_t* GetGroupInfo(const char* group = "0")
virtual TInetAddress GetHostByName(const char* server)
virtual int GetPathInfo(const char* path, FileStat_t& buf)
virtual TInetAddress GetPeerName(int sock)
virtual int GetPid()
virtual int GetServiceByName(const char* service)
virtual char* GetServiceByPort(int port)
virtual TInetAddress GetSockName(int sock)
virtual int GetSockOpt(int sock, int option, int* val)
virtual Int_t GetUid(const char* user = "0")
virtual UserGroup_t* GetUserInfo(Int_t uid)
virtual UserGroup_t* GetUserInfo(const char* user = "0")
virtual const char* HomeDirectory(const char* userName = "0")
virtual const char* HostName()
virtual void IgnoreSignal(ESignals sig, Bool_t ignore = kTRUE)
virtual Bool_t Init()
virtual TClass* IsA() const
virtual int Link(const char* from, const char* to)
virtual void ListLibraries(const char* regexp = "")
virtual void ListSymbols(const char* module, const char* re = "")
virtual int Load(const char* module, const char* entry = "", Bool_t system = kFALSE)
virtual int MakeDirectory(const char* name)
virtual TTime Now()
virtual int OpenConnection(const char* server, int port, int tcpwindowsize = -1)
virtual void* OpenDirectory(const char* name)
virtual void Openlog(const char* name, Int_t options, ELogFacility facility)
virtual FILE* OpenPipe(const char* shellcmd, const char* mode)
virtual const char* PrependPathName(const char* dir, TString& name)
virtual int RecvBuf(int sock, void* buffer, int length)
virtual int RecvRaw(int sock, void* buffer, int length, int flag)
virtual Int_t RedirectOutput(const char* name, const char* mode = "a")
virtual TFileHandler* RemoveFileHandler(TFileHandler* fh)
virtual TSignalHandler* RemoveSignalHandler(TSignalHandler* sh)
virtual TTimer* RemoveTimer(TTimer* ti)
virtual int Rename(const char* from, const char* to)
virtual void ResetSignal(ESignals sig, Bool_t reset = kTRUE)
virtual void ResetTimer(TTimer* ti)
virtual Int_t Select(TList* active, Long_t timeout)
virtual Int_t Select(TFileHandler* fh, Long_t timeout)
virtual int SendBuf(int sock, const void* buffer, int length)
virtual int SendRaw(int sock, const void* buffer, int length, int flag)
virtual void SetDisplay()
virtual void SetDynamicPath(const char* lib)
virtual void Setenv(const char* name, const char* value)
virtual Int_t SetFPEMask(Int_t mask = kDefaultMask)
virtual void SetProgname(const char* name)
virtual int SetSockOpt(int sock, int option, int val)
virtual void ShowMembers(TMemberInspector& insp, char* parent)
virtual void SigAlarmInterruptsSyscalls(Bool_t set)
virtual void Sleep(UInt_t milliSec)
virtual void StackTrace()
virtual void Streamer(TBuffer& b)
void StreamerNVirtual(TBuffer& b)
virtual int Symlink(const char* from, const char* to)
virtual void Syslog(ELogLevel level, const char* mess)
virtual const char* TempDirectory() const
virtual FILE* TempFileName(TString& base, const char* dir = "0")
virtual int Umask(Int_t mask)
virtual int Unlink(const char* name)
virtual void Unload(const char* module)
virtual int Utime(const char* file, Long_t modtime, Long_t actime)
virtual const char* WorkingDirectory()
void SetDisplay()
Set DISPLAY environment variable based on utmp entry. Only for UNIX.
const char * GetError()
Return system error string.
const char * HostName()
Return the system's host name.
void AddFileHandler(TFileHandler *h)
Add a file handler to the list of system file handlers. Only adds
the handler if it is not already in the list of file handlers.
void AddSignalHandler(TSignalHandler *h)
Add a signal handler to list of system signal handlers. Only adds
the handler if it is not already in the list of signal handlers.
void ResetSignal(ESignals sig, Bool_t reset)
If reset is true reset the signal handler for the specified signal
to the default handler, else restore previous behaviour.
void IgnoreSignal(ESignals sig, Bool_t ignore)
If ignore is true ignore the specified signal, else restore previous
behaviour.
void SigAlarmInterruptsSyscalls(Bool_t set)
When the argument is true the SIGALRM signal handler is set so that
interrupted syscalls will not be restarted by the kernel. This is
typically used in case one wants to put a timeout on an I/O operation.
By default interrupted syscalls will always be restarted (for all
signals). This can be controlled for each a-synchronous TTimer via
the method TTimer::SetInterruptSyscalls().
Int_t GetFPEMask()
Return the bitmap of conditions that trigger a floating point exception.
Int_t SetFPEMask(Int_t mask)
Set which conditions trigger a floating point exception.
Return the previous set of conditions.
int MakeDirectory(const char *name)
Make a Unix file system directory. Returns 0 in case of success and
-1 if the directory could not be created.
void * OpenDirectory(const char *name)
Open a Unix file system directory. Returns 0 if directory does not exist.
void FreeDirectory(void *dirp)
Close a Unix file system directory.
const char * GetDirEntry(void *dirp)
Get next Unix file system directory entry. Returns 0 if no more entries.
const char * HomeDirectory(const char *userName)
Return the user's home directory.
const char * TempDirectory()
Return a user configured or systemwide directory to create
temporary files in.
FILE * TempFileName(TString &base, const char *dir)
Create a secure temporary file by appending a unique
6 letter string to base. The file will be created in
a standard (system) directory or in the directory
provided in dir. The full filename is returned in base
and a filepointer is returned for safely writing to the file
(this avoids certain security problems). Returns 0 in case
of error.
Bool_t AccessPathName(const char *path, EAccessMode mode)
Returns FALSE if one can access a file using the specified access mode.
Mode is the same as for the Unix access(2) function.
Attention, bizarre convention of return value!!
int CopyFile(const char *f, const char *t, Bool_t overwrite)
Copy a file. If overwrite is true and file already exists the
file will be overwritten. Returns 0 when successful, -1 in case
of failure, -2 in case the file already exists and overwrite was false.
int Rename(const char *f, const char *t)
Rename a file. Returns 0 when successful, -1 in case of failure.
int GetPathInfo(const char *path, FileStat_t &buf)
Get info about a file. Info is returned in the form of a FileStat_t
structure (see TSystem.h).
The function returns 0 in case of success and 1 if the file could
not be stat'ed.
int GetFsInfo(const char *path, Long_t *id, Long_t *bsize, Long_t *blocks, Long_t *bfree)
Get info about a file system: id, bsize, bfree, blocks.
Id is file system type (machine dependend, see statfs())
Bsize is block size of file system
Blocks is total number of blocks in file system
Bfree is number of free blocks in file system
The function returns 0 in case of success and 1 if the file system could
not be stat'ed.
int Link(const char *from, const char *to)
Create a link from file1 to file2. Returns 0 when successful,
-1 in case of failure.
int Symlink(const char *from, const char *to)
Create a symlink from file1 to file2. Returns 0 when succesfull,
-1 in case of failure.
int Unlink(const char *name)
Unlink, i.e. remove, a file or directory. Returns 0 when succesfull,
-1 in case of failure.
Bool_t ExpandPathName(TString &path)
Expand a pathname getting rid of special shell characters like ~.$, etc.
For Unix/Win32 compatibility use $(XXX) instead of $XXX when using
environment variables in a pathname. If compatibility is not an issue
you can use on Unix directly $XXX.
Bool_t ExpandPathName(TString &patbuf0)
Expand a pathname getting rid of special shell characters like ~.$, etc.
For Unix/Win32 compatibility use $(XXX) instead of $XXX when using
environment variables in a pathname. If compatibility is not an issue
you can use on Unix directly $XXX.
int Chmod(const char *file, UInt_t mode)
Set the file permission bits. Returns -1 in case or error, 0 otherwise.
int Umask(Int_t mask)
Set the process file creation mode mask.
int Utime(const char *file, Long_t modtime, Long_t actime)
Set a files modification and access times. If actime = 0 it will be
set to the modtime. Returns 0 on success and -1 in case of error.
const char * FindFile(const char *search, TString& wfil, EAccessMode mode)
Find location of file "wfil" in a search path.
The search path is specified as a : separated list of directories.
Return value is pointing to wfile for compatibility with
Which(const char*,const char*,EAccessMode) version
Int_t GetUid(const char *user)
Returns the user's id. If user = 0, returns current user's id.
Int_t GetEffectiveUid()
Returns the effective user id. The effective id corresponds to the
set id bit on the file being executed.
Int_t GetGid(const char *group)
Returns the group's id. If group = 0, returns current user's group.
Int_t GetEffectiveGid()
Returns the effective group id. The effective group id corresponds
to the set id bit on the file being executed.
UserGroup_t * GetUserInfo(const char *user)
Returns all user info in the UserGroup_t structure. If user = 0, returns
current user's id info. The returned structure must be deleted by the
user. In case of error 0 is returned.
UserGroup_t * GetGroupInfo(Int_t gid)
Returns all group info in the UserGroup_t structure. The only active
fields in the UserGroup_t structure for this call are:
fGid and fGroup
The returned structure must be deleted by the user. In case of
error 0 is returned.
UserGroup_t * GetGroupInfo(const char *group)
Returns all group info in the UserGroup_t structure. The only active
fields in the UserGroup_t structure for this call are:
fGid and fGroup
If group = 0, returns current user's group. The returned structure
must be deleted by the user. In case of error 0 is returned.
void Setenv(const char *name, const char *value)
Set environment variable. The string passed will be owned by
the environment and can not be reused till a "name" is set
again. The solution below will lose the space for the string
in that case, but if this functions is not called thousands
of times that should not be a problem.
const char * Getenv(const char *name)
Get environment variable.
FILE * OpenPipe(const char *command, const char *mode)
Open a pipe.
void Openlog(const char *name, Int_t options, ELogFacility facility)
Open connection to system log daemon. For the use of the options and
facility see the Unix openlog man page.
void Syslog(ELogLevel level, const char *mess)
Send mess to syslog daemon. Level is the logging level and mess the
message that will be written on the log.
void Closelog()
Close connection to system log daemon.
Int_t RedirectOutput(const char *file, const char *mode)
Redirect standard output (stdout, stderr) to the specified file.
If the file argument is 0 the output is set again to stderr, stdout.
The second argument specifies whether the output should be added to the
file ("a", default) or the file be truncated before ("w").
Returns 0 on success, -1 in case of error.
int Load(const char *module, const char *entry, Bool_t system)
Load a shared library. Returns 0 on successful loading, 1 in
case lib was already loaded and -1 in case lib does not exist
or in case of error.
void ListSymbols(const char *module, const char *regexp)
List symbols in a shared library.
void ListLibraries(const char *regexp)
List all loaded shared libraries.
const char * GetLinkedLibraries()
Get list of shared libraries loaded at the start of the executable.
Returns 0 in case list cannot be obtained or in case of error.
int ConnectService(const char *servername, int port, int tcpwindowsize)
Connect to service servicename on server servername.
int OpenConnection(const char *server, int port, int tcpwindowsize)
Open a connection to a service on a server. Returns -1 in case
connection cannot be opened.
Use tcpwindowsize to specify the size of the receive buffer, it has
to be specified here to make sure the window scale option is set (for
tcpwindowsize > 65KB and for platforms supporting window scaling).
Is called via the TSocket constructor.
int AnnounceTcpService(int port, Bool_t reuse, int backlog, int tcpwindowsize)
Announce TCP/IP service.
Open a socket, bind to it and start listening for TCP/IP connections
on the port. If reuse is true reuse the address, backlog specifies
how many sockets can be waiting to be accepted.
Use tcpwindowsize to specify the size of the receive buffer, it has
to be specified here to make sure the window scale option is set (for
tcpwindowsize > 65KB and for platforms supporting window scaling).
Returns socket fd or -1 if socket() failed, -2 if bind() failed
or -3 if listen() failed.
int AcceptConnection(int sock)
Accept a connection. In case of an error return -1. In case
non-blocking I/O is enabled and no connections are available
return -2.
int RecvBuf(int sock, void *buf, int length)
Receive a buffer headed by a length indicator. Lenght is the size of
the buffer. Returns the number of bytes received in buf or -1 in
case of error.
int SendBuf(int sock, const void *buf, int length)
Send a buffer headed by a length indicator. Returns length of sent buffer
or -1 in case of error.
int RecvRaw(int sock, void *buf, int length, int opt)
Receive exactly length bytes into buffer. Use opt to receive out-of-band
data or to have a peek at what is in the buffer (see TSocket). Buffer
must be able to store at least length bytes. Returns the number of
bytes received (can be 0 if other side of connection was closed) or -1
in case of error, -2 in case of MSG_OOB and errno == EWOULDBLOCK, -3
in case of MSG_OOB and errno == EINVAL and -4 in case of kNoBlock and
errno == EWOULDBLOCK. Returns -5 if pipe broken or reset by peer
(EPIPE || ECONNRESET).
int SendRaw(int sock, const void *buf, int length, int opt)
Send exactly length bytes from buffer. Use opt to send out-of-band
data (see TSocket). Returns the number of bytes sent or -1 in case of
error. Returns -4 in case of kNoBlock and errno == EWOULDBLOCK.
Returns -5 if pipe broken or reset by peer (EPIPE || ECONNRESET).
int SetSockOpt(int sock, int opt, int val)
Set socket option.
int GetSockOpt(int sock, int opt, int *val)
Get socket option.
void UnixSignal(ESignals sig, SigHandler_t handler)
Set a signal handler for a signal.
void UnixIgnoreSignal(ESignals sig, Bool_t ignore)
If ignore is true ignore the specified signal, else restore previous
behaviour.
void UnixSigAlarmInterruptsSyscalls(Bool_t set)
When the argument is true the SIGALRM signal handler is set so that
interrupted syscalls will not be restarted by the kernel. This is
typically used in case one wants to put a timeout on an I/O operation.
By default interrupted syscalls will always be restarted (for all
signals). This can be controlled for each a-synchronous TTimer via
the method TTimer::SetInterruptSyscalls().
const char * UnixSigname(ESignals sig)
Return the signal name associated with a signal.
void UnixResetSignal(ESignals sig)
Restore old signal handler for specified signal.
Long_t UnixNow()
Get current time in milliseconds since 0:00 Jan 1 1995.
int UnixSelect(Int_t nfds, TFdSet *readready, TFdSet *writeready, Long_t timeout)
Wait for events on the file descriptors specified in the readready and
writeready masks or for timeout (in milliseconds) to occur.
int UnixMakedir(const char *dir)
Make a Unix file system directory. Returns 0 in case of success and
-1 if the directory could not be created (either already exists or
illegal path name).
const char * UnixGetdirentry(void *dirp1)
Returns the next directory entry.
int UnixFilestat(const char *fpath, FileStat_t &buf)
Get info about a file. Info is returned in the form of a FileStat_t
structure (see TSystem.h).
The function returns 0 in case of success and 1 if the file could
not be stat'ed.
int UnixFSstat(const char *path, Long_t *id, Long_t *bsize, Long_t *blocks, Long_t *bfree)
Get info about a file system: id, bsize, bfree, blocks.
Id is file system type (machine dependend, see statfs())
Bsize is block size of file system
Blocks is total number of blocks in file system
Bfree is number of free blocks in file system
The function returns 0 in case of success and 1 if the file system could
not be stat'ed.
int UnixTcpConnect(const char *hostname, int port, int tcpwindowsize)
Open a TCP/IP connection to server and connect to a service (i.e. port).
Use tcpwindowsize to specify the size of the receive buffer, it has
to be specified here to make sure the window scale option is set (for
tcpwindowsize > 65KB and for platforms supporting window scaling).
Is called via the TSocket constructor.
int UnixTcpService(int port, Bool_t reuse, int backlog, int tcpwindowsize)
Open a socket, bind to it and start listening for TCP/IP connections
on the port. If reuse is true reuse the address, backlog specifies
how many sockets can be waiting to be accepted. If port is 0 a port
scan will be done to find a free port. This option is mutual exlusive
with the reuse option.
Use tcpwindowsize to specify the size of the receive buffer, it has
to be specified here to make sure the window scale option is set (for
tcpwindowsize > 65KB and for platforms supporting window scaling).
Returns socket fd or -1 if socket() failed, -2 if bind() failed
or -3 if listen() failed.
int UnixUnixService(int port, int backlog)
Open a socket, bind to it and start listening for Unix domain connections
to it. Returns socket fd or -1.
int UnixRecv(int sock, void *buffer, int length, int flag)
Receive exactly length bytes into buffer. Returns number of bytes
received. Returns -1 in case of error, -2 in case of MSG_OOB
and errno == EWOULDBLOCK, -3 in case of MSG_OOB and errno == EINVAL
and -4 in case of kNoBlock and errno == EWOULDBLOCK.
Returns -5 if pipe broken or reset by peer (EPIPE || ECONNRESET).
int UnixSend(int sock, const void *buffer, int length, int flag)
Send exactly length bytes from buffer. Returns -1 in case of error,
otherwise number of sent bytes. Returns -4 in case of kNoBlock and
errno == EWOULDBLOCK. Returns -5 if pipe broken or reset by peer
(EPIPE || ECONNRESET).
const char * GetDynamicPath()
Return the dynamic path (used to find shared libraries).
void SetDynamicPath(const char *path)
Set the dynamic path to a new value.
If the value of 'path' is zero, the dynamic path is reset to its
default value.
char * DynamicPathName(const char *lib, Bool_t quiet)
Returns the path of a shared library (searches for library in the
shared library search path). If no file name extension is provided
it first tries .so, .sl, .dl and then .a (for AIX). The returned string
must be deleted.
void * FindDynLib(const char *lib)
Returns the handle to a loaded shared library. Returns 0 when library
not loaded.
int UnixDynLoad(const char *lib)
Load a shared library. Returns 0 on successful loading, 1 in
case lib was already loaded and -1 in case lib does not exist
or in case of error.
Func_t UnixDynFindSymbol(const char *lib, const char *entry)
Finds and returns a function pointer to a symbol in the shared library.
Returns 0 when symbol not found.
void UnixDynListSymbols(const char *lib, const char *regexp)
List symbols in a shared library. One can use wildcards to list only
the interesting symbols.
void * SearchUtmpEntry(int n, const char *tty)
Look for utmp entry which is connected to terminal tty.
Author: Fons Rademakers 15/09/95
Last update: root/unix:$Name: $:$Id: TUnixSystem.cxx,v 1.154 2006/07/04 17:36:37 brun Exp $
Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
ROOT page - Class index - Class Hierarchy - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.