1998-02-13 13:46:18 +00:00
|
|
|
#include <dongle.h>
|
1994-11-11 18:04:29 +00:00
|
|
|
#include <execp.h>
|
1998-02-24 10:37:28 +00:00
|
|
|
#include <os_dep.h>
|
1995-03-22 09:07:04 +00:00
|
|
|
#include <prefix.h>
|
1998-12-10 16:25:48 +00:00
|
|
|
#include <recarray.h>
|
1997-06-06 09:00:01 +00:00
|
|
|
|
1996-02-05 19:00:53 +00:00
|
|
|
// @doc EXTERNAL
|
|
|
|
|
1995-05-26 10:16:03 +00:00
|
|
|
// @mfunc Esegue il processo
|
1996-02-05 19:00:53 +00:00
|
|
|
//
|
|
|
|
// @rdesc Ritorna il codice di uscita del processo (-1 in caso di errore).
|
1996-06-17 09:07:22 +00:00
|
|
|
word TExternal_app::run(
|
1997-10-30 16:14:49 +00:00
|
|
|
bool async, // @parm Per eseguire il processo in parallelo
|
1998-03-05 13:54:51 +00:00
|
|
|
byte utente, // @parm Permette di inserire il nome dell'utente nella riga di comando
|
1997-10-30 16:14:49 +00:00
|
|
|
bool iconize, // @parm Iconizza il programma chiamante
|
|
|
|
bool show) // @parm Mostra o nascondi il programma chiamato
|
1995-05-26 10:16:03 +00:00
|
|
|
|
|
|
|
// @comm Se <p asyn> e' FALSE aspetta che termini il processo in esecuzione prima di iniziare il nuovo
|
1994-09-22 07:48:15 +00:00
|
|
|
|
|
|
|
{
|
1997-12-17 15:10:38 +00:00
|
|
|
TFilename path(_path);
|
1997-08-18 14:11:37 +00:00
|
|
|
|
1997-12-17 15:10:38 +00:00
|
|
|
TFilename comm_name(_path);
|
1998-03-13 10:25:37 +00:00
|
|
|
const int p = comm_name.find(' ');
|
|
|
|
if (p >= 0)
|
1997-12-17 15:10:38 +00:00
|
|
|
comm_name.cut(p);
|
|
|
|
|
|
|
|
TString name(comm_name.name());
|
1997-08-18 14:11:37 +00:00
|
|
|
if (utente == TRUE) // utente puo' essere 0 = No, 1 = Si, 3 = Forzatura
|
|
|
|
{
|
|
|
|
bool our_app = name.len() > 2;
|
|
|
|
if (our_app && atoi(name) < 70)
|
|
|
|
{
|
|
|
|
our_app = isalpha(name[0]) && isalpha(name[1]) && isdigit(name[2]);
|
|
|
|
}
|
|
|
|
if (!our_app)
|
|
|
|
utente = FALSE;
|
|
|
|
}
|
|
|
|
|
1995-03-22 09:07:04 +00:00
|
|
|
if (utente)
|
1995-03-27 14:36:11 +00:00
|
|
|
path << " /u" << user();
|
1994-11-30 09:04:03 +00:00
|
|
|
|
1994-09-22 07:48:15 +00:00
|
|
|
_exitcode = 0;
|
|
|
|
|
|
|
|
// save cwd
|
1995-03-22 09:07:04 +00:00
|
|
|
xvt_fsys_save_dir();
|
1994-09-22 07:48:15 +00:00
|
|
|
|
1997-12-17 15:10:38 +00:00
|
|
|
const TFilename dir(comm_name.path());
|
1997-06-06 09:00:01 +00:00
|
|
|
if (dir.not_empty())
|
|
|
|
{
|
|
|
|
DIRECTORY d;
|
|
|
|
|
|
|
|
if (xvt_fsys_convert_str_to_dir((char *) (const char *) dir, &d))
|
|
|
|
xvt_fsys_set_dir(&d);
|
|
|
|
}
|
1997-08-18 14:11:37 +00:00
|
|
|
|
1998-03-30 13:39:21 +00:00
|
|
|
if (!async)
|
1998-10-01 13:52:27 +00:00
|
|
|
safely_close_closeable_isamfiles();
|
1998-03-30 13:39:21 +00:00
|
|
|
|
1998-02-24 10:37:28 +00:00
|
|
|
if (dongle().local())
|
|
|
|
dongle().logout();
|
1994-09-22 07:48:15 +00:00
|
|
|
|
1998-02-24 10:37:28 +00:00
|
|
|
iconize &= !async && show;
|
|
|
|
_exitcode = os_execute(path, !async, iconize, show);
|
1994-09-22 07:48:15 +00:00
|
|
|
|
|
|
|
// restore cwd
|
1995-03-22 09:07:04 +00:00
|
|
|
xvt_fsys_restore_dir();
|
1994-09-22 07:48:15 +00:00
|
|
|
|
1996-05-31 13:05:55 +00:00
|
|
|
// Ignora volutamente il return code da HL_LOGIN(). Se va bene riprende il posto
|
|
|
|
// altrimenti fa lo stesso. Infatti puo' capitare con una chiave di rete, che
|
|
|
|
// nel lasso di tempo trascorso dalla HL_LOGOUT() dell'applicazione chiamata,
|
|
|
|
// a questa HL_LOGIN() [approssimativamente qualche decimo di secondo], qualche altro
|
|
|
|
// programma si inserisca, occupando magari anche l'ultimo posto disponibile.
|
|
|
|
// Quindi se si verificasse tale sfigatissima condizione, sicuramente
|
|
|
|
// non ci saranno piu' posti liberi nell'HL_server: il programma comunque non
|
|
|
|
// puo' interrompersi a meta'; ecco perche il valore di ritorno di HL_LOGIN viene
|
|
|
|
// ignorato.
|
1998-02-13 13:46:18 +00:00
|
|
|
if (dongle().local())
|
|
|
|
dongle().login();
|
1998-02-24 10:37:28 +00:00
|
|
|
|
1994-09-22 07:48:15 +00:00
|
|
|
return _exitcode;
|
|
|
|
}
|
|
|
|
|
1998-12-10 16:25:48 +00:00
|
|
|
bool TExternal_app::can_run() const
|
|
|
|
{
|
|
|
|
TRecord_cache users(LF_USER);
|
|
|
|
TToken_string perm(4096, '\n'), row(80);
|
|
|
|
for (TString16 u = user();
|
|
|
|
u.not_empty() && !users.already_loaded(u);
|
|
|
|
u = users.get(u, "GROUPNAME"))
|
|
|
|
{
|
|
|
|
perm = users.get(u, "PERMISSION");
|
|
|
|
if (!perm.blank())
|
|
|
|
{
|
|
|
|
FOR_EACH_TOKEN(perm, tok)
|
|
|
|
{
|
|
|
|
row = tok;
|
|
|
|
if (_path == row.get(0)) // Il nome corrisponde
|
|
|
|
{
|
|
|
|
if (*row.get(1) == 'N')
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
1994-09-22 07:48:15 +00:00
|
|
|
TExternal_app::TExternal_app(const char* p)
|
1998-03-13 10:25:37 +00:00
|
|
|
: _path(p), _exitcode(0)
|
1994-09-22 07:48:15 +00:00
|
|
|
{
|
|
|
|
}
|
1997-09-19 08:47:46 +00:00
|
|
|
|