// eDebug("%d args", cnt-2);
char **argv = new char*[cnt]; // min two args... path and terminating 0
- argv[0] = new char[ plen ];
+// eDebug("%d args", cnt);
+ argv[0] = new char[ plen+1 ];
+// eDebug("new argv[0] %d bytes (%s)", plen+1, path.c_str());
strcpy( argv[0], path.c_str() );
argv[cnt-1] = 0; // set terminating null
tmp.erase(tmp.length()-1, 1);
bracketClosed=false;
}
-// eDebug("new argv[%d] %d bytes", tmp.length()+1);
+// eDebug("new argv[%d] %d bytes (%s)", cnt, tmp.length()+1, tmp.c_str());
argv[cnt] = new char[ tmp.length()+1 ];
// eDebug("idx=%d, arg = %s", idx, tmp.c_str() );
strcpy( argv[cnt++], tmp.c_str() );
cmds.erase(cmds.length()-1, 1);
}
// store the last arg
-// eDebug("new argv[%d] %d bytes", cmds.length());
+// eDebug("new argv[%d] %d bytes (%s)", cnt, cmds.length()+1, cmds.c_str());
argv[cnt] = new char[ cmds.length()+1 ];
strcpy( argv[cnt], cmds.c_str() );
}
if ( pid == -1 )
return -3;
- eDebug("pipe in = %d, out = %d, err = %d", fd[0], fd[1], fd[2]);
+// eDebug("pipe in = %d, out = %d, err = %d", fd[0], fd[1], fd[2]);
in = new eSocketNotifier(eApp, fd[0], POLLIN|POLLPRI|POLLHUP );
out = new eSocketNotifier(eApp, fd[1], POLLOUT, false);
void eConsoleAppContainer::kill()
{
- if ( killstate != -1 )
+ if ( killstate != -1 && pid != -1 )
{
eDebug("user kill(SIGKILL) console App");
killstate=-1;
void eConsoleAppContainer::sendCtrlC()
{
- if ( killstate != -1 )
+ if ( killstate != -1 && pid != -1 )
{
eDebug("user send SIGINT(Ctrl-C) to console App");
::kill(pid, SIGINT);
outbuf.pop();
delete [] d.data;
}
+ pid = -1;
}
void eConsoleAppContainer::readyRead(int what)