2002-02-27 09:59:52 +00:00
|
|
|
// -*- C++ -*-
|
|
|
|
/**
|
Rename files in src/support, step one.
src/support/package.h src/support/Package.h Package
src/support/package.C.in src/support/Package.C.in Package
src/support/path.h src/support/Path.h Path
src/support/fs_extras.h src/support/fs_extras.h NOCLASSES
src/support/RandomAccessList.h src/support/RandomAccessList.h RandomAccessList
src/support/lyxmanip.h src/support/lyxmanip.h NOCLASSES
src/support/rename.C src/support/rename.cpp NOCLASSES
src/support/abort.C src/support/abort.cpp NOCLASSES
src/support/lyxlib.h src/support/lyxlib.h NOCLASSES
src/support/ExceptionMessage.h src/support/ExceptionMessage.h ExceptionMessage
src/support/copy.C src/support/copy.cpp NOCLASSES
src/support/limited_stack.h src/support/limited_stack.h limited_stack
src/support/filefilterlist.C src/support/FileFilterList.cpp ['FileFilterList', 'Filter']
src/support/cow_ptr.h src/support/cow_ptr.h cow_ptr
src/support/os_unix.C src/support/os_unix.cpp NOCLASSES
src/support/socktools.h src/support/socktools.h NOCLASSES
src/support/forkedcontr.h src/support/ForkedcallsController.h ForkedcallsController
src/support/os.h src/support/os.h NOCLASSES
src/support/FileMonitor.h src/support/FileMonitor.h FileMonitor
src/support/copied_ptr.h src/support/copied_ptr.h copied_ptr
src/support/translator.h src/support/Translator.h Translator
src/support/filetools.C src/support/filetools.cpp NOCLASSES
src/support/unlink.C src/support/unlink.cpp NOCLASSES
src/support/os_win32.C src/support/os_win32.cpp GetFolderPath
src/support/lstrings.C src/support/lstrings.cpp NOCLASSES
src/support/qstring_helpers.C src/support/qstring_helpers.cpp NOCLASSES
src/support/getcwd.C src/support/getcwd.cpp NOCLASSES
src/support/systemcall.C src/support/Systemcall.cpp Systemcall
src/support/lyxalgo.h src/support/lyxalgo.h NOCLASSES
src/support/filefilterlist.h src/support/FileFilterList.h ['FileFilterList', 'Filter']
src/support/unicode.C src/support/unicode.cpp IconvProcessor
src/support/userinfo.C src/support/userinfo.cpp NOCLASSES
src/support/lyxtime.C src/support/lyxtime.cpp NOCLASSES
src/support/kill.C src/support/kill.cpp NOCLASSES
src/support/docstring.C src/support/docstring.cpp to_local8bit_failure
src/support/os_cygwin.C src/support/os_cygwin.cpp NOCLASSES
src/support/lyxsum.C src/support/lyxsum.cpp NOCLASSES
src/support/environment.C src/support/environment.cpp NOCLASSES
src/support/filetools.h src/support/filetools.h NOCLASSES
src/support/textutils.C src/support/textutils.cpp NOCLASSES
src/support/mkdir.C src/support/mkdir.cpp NOCLASSES
src/support/forkedcall.C src/support/Forkedcall.cpp ['ForkedProcess', 'Forkedcall']
src/support/tempname.C src/support/tempname.cpp NOCLASSES
src/support/os_win32.h src/support/os_win32.h GetFolderPath
src/support/types.h src/support/types.h NOCLASSES
src/support/lstrings.h src/support/lstrings.h NOCLASSES
src/support/forkedcallqueue.C src/support/ForkedCallQueue.cpp ForkedCallQueue
src/support/qstring_helpers.h src/support/qstring_helpers.h NOCLASSES
src/support/convert.C src/support/convert.cpp NOCLASSES
src/support/filename.C src/support/FileName.cpp ['FileName', 'DocFileName']
src/support/tests/convert.C src/support/tests/convert.cpp NOCLASSES
src/support/tests/filetools.C src/support/tests/filetools.cpp NOCLASSES
src/support/tests/lstrings.C src/support/tests/lstrings.cpp NOCLASSES
src/support/tests/boost.C src/support/tests/boost.cpp NOCLASSES
src/support/docstream.C src/support/docstream.cpp ['iconv_codecvt_facet_exception', 'idocfstream', 'odocfstream']
src/support/std_istream.h src/support/std_istream.h NOCLASSES
src/support/systemcall.h src/support/Systemcall.h Systemcall
src/support/chdir.C src/support/chdir.cpp NOCLASSES
src/support/std_ostream.h src/support/std_ostream.h NOCLASSES
src/support/unicode.h src/support/unicode.h IconvProcessor
src/support/path.C src/support/Path.cpp Path
src/support/fs_extras.C src/support/fs_extras.cpp NOCLASSES
src/support/userinfo.h src/support/userinfo.h NOCLASSES
src/support/lyxtime.h src/support/lyxtime.h NOCLASSES
src/support/docstring.h src/support/docstring.h to_local8bit_failure
src/support/debugstream.h src/support/debugstream.h basic_debugstream
src/support/environment.h src/support/environment.h NOCLASSES
src/support/textutils.h src/support/textutils.h NOCLASSES
src/support/forkedcall.h src/support/Forkedcall.h ['ForkedProcess', 'Forkedcall']
src/support/socktools.C src/support/socktools.cpp NOCLASSES
src/support/forkedcallqueue.h src/support/ForkedCallQueue.h ForkedCallQueue
src/support/forkedcontr.C src/support/ForkedcallsController.cpp ForkedcallsController
src/support/os.C src/support/os.cpp NOCLASSES
src/support/convert.h src/support/convert.h NOCLASSES
src/support/filename.h src/support/FileName.h ['FileName', 'DocFileName']
src/support/docstream.h src/support/docstream.h ['iconv_codecvt_facet_exception', 'idocfstream', 'odocfstream']
src/support/FileMonitor.C src/support/FileMonitor.cpp FileMonitor
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@18024 a592a061-630c-0410-9148-cb99ea01b6c8
2007-04-26 05:12:52 +00:00
|
|
|
* \file Forkedcall.h
|
2002-09-25 10:03:41 +00:00
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* Licence details can be found in the file COPYING.
|
2002-02-27 09:59:52 +00:00
|
|
|
*
|
|
|
|
* \author Asger Alstrup
|
|
|
|
*
|
|
|
|
* Interface cleaned up by
|
2002-09-25 10:03:41 +00:00
|
|
|
* \author Angus Leeming
|
|
|
|
*
|
2003-08-23 00:17:00 +00:00
|
|
|
* Full author contact details are available in file CREDITS.
|
2002-02-27 09:59:52 +00:00
|
|
|
*
|
|
|
|
* An instance of Class Forkedcall represents a single child process.
|
|
|
|
*
|
|
|
|
* Class Forkedcall uses fork() and execvp() to lauch the child process.
|
|
|
|
*
|
|
|
|
* Once launched, control is returned immediately to the parent process
|
|
|
|
* but a Signal can be emitted upon completion of the child.
|
|
|
|
*
|
|
|
|
* The child process is not killed when the Forkedcall instance goes out of
|
|
|
|
* scope, but it can be killed by an explicit invocation of the kill() member
|
|
|
|
* function.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef FORKEDCALL_H
|
|
|
|
#define FORKEDCALL_H
|
|
|
|
|
2002-05-22 01:16:37 +00:00
|
|
|
#include <boost/shared_ptr.hpp>
|
2004-09-26 14:19:47 +00:00
|
|
|
#include <boost/signal.hpp>
|
2002-02-27 09:59:52 +00:00
|
|
|
|
2005-04-26 10:30:24 +00:00
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
|
|
# include <sys/types.h>
|
|
|
|
#endif
|
2002-02-27 09:59:52 +00:00
|
|
|
|
2005-04-20 17:35:47 +00:00
|
|
|
|
2003-06-30 23:56:22 +00:00
|
|
|
namespace lyx {
|
|
|
|
namespace support {
|
|
|
|
|
2002-10-31 12:42:26 +00:00
|
|
|
class ForkedProcess {
|
2002-02-27 09:59:52 +00:00
|
|
|
public:
|
|
|
|
///
|
|
|
|
enum Starttype {
|
|
|
|
///
|
|
|
|
Wait,
|
|
|
|
///
|
|
|
|
DontWait
|
|
|
|
};
|
2002-03-21 17:09:55 +00:00
|
|
|
|
2002-02-27 09:59:52 +00:00
|
|
|
///
|
2002-10-31 12:42:26 +00:00
|
|
|
ForkedProcess();
|
|
|
|
///
|
|
|
|
virtual ~ForkedProcess() {}
|
|
|
|
///
|
2004-03-23 14:39:41 +00:00
|
|
|
virtual boost::shared_ptr<ForkedProcess> clone() const = 0;
|
2002-02-27 09:59:52 +00:00
|
|
|
|
|
|
|
/** A SignalType signal is can be emitted once the forked process
|
|
|
|
* has finished. It passes:
|
|
|
|
* the PID of the child and;
|
|
|
|
* the return value from the child.
|
|
|
|
*
|
|
|
|
* We use a signal rather than simply a callback function so that
|
|
|
|
* we can return easily to C++ methods, rather than just globally
|
|
|
|
* accessible functions.
|
|
|
|
*/
|
2004-09-26 14:19:47 +00:00
|
|
|
typedef boost::signal<void(pid_t, int)> SignalType;
|
2002-02-27 09:59:52 +00:00
|
|
|
|
|
|
|
/** The signal is connected in the calling routine to the desired
|
|
|
|
* slot. We pass a shared_ptr rather than a reference to the signal
|
|
|
|
* because it is eminently possible for the instance of the calling
|
|
|
|
* class (and hence the signal) to be destructed before the forked
|
|
|
|
* call is complete.
|
|
|
|
*
|
|
|
|
* It doesn't matter if the slot disappears, SigC takes care of that.
|
|
|
|
*/
|
|
|
|
typedef boost::shared_ptr<SignalType> SignalTypePtr;
|
|
|
|
|
|
|
|
/** Invoking the following methods makes sense only if the command
|
|
|
|
* is running asynchronously!
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** gets the PID of the child process.
|
|
|
|
* Used by the timer.
|
|
|
|
*/
|
|
|
|
pid_t pid() const { return pid_; }
|
2002-03-21 17:09:55 +00:00
|
|
|
|
2002-02-27 09:59:52 +00:00
|
|
|
/** Emit the signal.
|
|
|
|
* Used by the timer.
|
|
|
|
*/
|
|
|
|
void emitSignal();
|
|
|
|
|
|
|
|
/** Set the return value of the child process.
|
|
|
|
* Used by the timer.
|
|
|
|
*/
|
|
|
|
void setRetValue(int r) { retval_ = r; }
|
|
|
|
|
2002-10-31 12:42:26 +00:00
|
|
|
/// Returns the identifying command (for display in the GUI perhaps).
|
2003-10-06 15:43:21 +00:00
|
|
|
std::string const & command() const { return command_; }
|
2002-10-31 12:42:26 +00:00
|
|
|
|
2003-02-17 18:40:04 +00:00
|
|
|
/// is the process running ?
|
|
|
|
bool running() const;
|
|
|
|
|
2002-02-27 09:59:52 +00:00
|
|
|
/** Kill child prematurely.
|
|
|
|
* First, a SIGHUP is sent to the child.
|
|
|
|
* If that does not end the child process within "tolerance"
|
|
|
|
* seconds, the SIGKILL signal is sent to the child.
|
|
|
|
* When the child is dead, the callback is called.
|
|
|
|
*/
|
|
|
|
void kill(int tolerance = 5);
|
|
|
|
|
2002-10-31 12:42:26 +00:00
|
|
|
protected:
|
2004-03-26 23:55:33 +00:00
|
|
|
/** Spawn the child process.
|
2002-10-31 12:42:26 +00:00
|
|
|
* Returns returncode from child.
|
|
|
|
*/
|
2004-03-26 23:55:33 +00:00
|
|
|
int run(Starttype type);
|
2002-10-31 12:42:26 +00:00
|
|
|
|
2002-02-27 09:59:52 +00:00
|
|
|
/// Callback function
|
|
|
|
SignalTypePtr signal_;
|
|
|
|
|
2002-10-31 12:42:26 +00:00
|
|
|
/// identifying command (for display in the GUI perhaps).
|
2003-10-06 15:43:21 +00:00
|
|
|
std::string command_;
|
2002-02-27 09:59:52 +00:00
|
|
|
|
|
|
|
/// Process ID of child
|
|
|
|
pid_t pid_;
|
|
|
|
|
|
|
|
/// Return value from child
|
|
|
|
int retval_;
|
2002-10-31 12:42:26 +00:00
|
|
|
private:
|
|
|
|
/// generate child in background
|
|
|
|
virtual int generateChild() = 0;
|
2002-02-27 09:59:52 +00:00
|
|
|
|
|
|
|
/// Wait for child process to finish. Updates returncode from child.
|
|
|
|
int waitForChild();
|
|
|
|
};
|
|
|
|
|
2002-10-31 12:42:26 +00:00
|
|
|
|
|
|
|
class Forkedcall : public ForkedProcess {
|
|
|
|
public:
|
|
|
|
///
|
2004-03-23 14:39:41 +00:00
|
|
|
virtual boost::shared_ptr<ForkedProcess> clone() const {
|
|
|
|
return boost::shared_ptr<ForkedProcess>(new Forkedcall(*this));
|
2002-10-31 12:42:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Start the child process.
|
|
|
|
*
|
|
|
|
* The command "what" is passed to execvp() for execution.
|
|
|
|
*
|
|
|
|
* There are two startscript commands available. They differ in that
|
|
|
|
* the second receives a signal that is executed on completion of
|
|
|
|
* the command. This makes sense only for a command executed
|
|
|
|
* in the background, ie DontWait.
|
|
|
|
*
|
|
|
|
* The other startscript command can be executed either blocking
|
|
|
|
* or non-blocking, but no signal will be emitted on finishing.
|
|
|
|
*/
|
2003-10-06 15:43:21 +00:00
|
|
|
int startscript(Starttype, std::string const & what);
|
2002-10-31 12:42:26 +00:00
|
|
|
|
|
|
|
///
|
2003-10-06 15:43:21 +00:00
|
|
|
int startscript(std::string const & what, SignalTypePtr);
|
2002-10-31 12:42:26 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
///
|
|
|
|
virtual int generateChild();
|
|
|
|
};
|
|
|
|
|
2003-06-30 23:56:22 +00:00
|
|
|
} // namespace support
|
|
|
|
} // namespace lyx
|
|
|
|
|
2002-02-27 09:59:52 +00:00
|
|
|
#endif // FORKEDCALL_H
|