mirror of
https://github.com/tuxbox-fork-migrations/recycled-ni-neutrino.git
synced 2025-08-28 07:51:11 +02:00
Add global helpers my_system() and my_popen()
Origin commit data
------------------
Branch: ni/coolstream
Commit: b92660259c
Author: FlatTV <FlatTV@gmx.de>
Date: 2012-08-30 (Thu, 30 Aug 2012)
------------------
No further description and justification available within origin commit message!
------------------
This commit was generated by Migit
This commit is contained in:
@@ -54,6 +54,8 @@
|
|||||||
#include <global.h>
|
#include <global.h>
|
||||||
#include <neutrino.h>
|
#include <neutrino.h>
|
||||||
|
|
||||||
|
#include <system/helpers.h>
|
||||||
|
|
||||||
#include <zapit/client/zapittools.h>
|
#include <zapit/client/zapittools.h>
|
||||||
|
|
||||||
#include "plugins.h"
|
#include "plugins.h"
|
||||||
@@ -375,7 +377,7 @@ void CPlugins::startScriptPlugin(int number)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
pid_t pid = 0;
|
pid_t pid = 0;
|
||||||
FILE *f = popen2(pid,script,"r");
|
FILE *f = my_popen(pid,script,"r");
|
||||||
if (f != NULL)
|
if (f != NULL)
|
||||||
{
|
{
|
||||||
char *output=NULL;
|
char *output=NULL;
|
||||||
@@ -396,7 +398,6 @@ void CPlugins::startScriptPlugin(int number)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int mysystem(const char * cmd,const char * arg1,const char * arg2);
|
|
||||||
void CPlugins::startPlugin(int number,int /*param*/)
|
void CPlugins::startPlugin(int number,int /*param*/)
|
||||||
{
|
{
|
||||||
// always delete old output
|
// always delete old output
|
||||||
@@ -643,7 +644,7 @@ void CPlugins::startPlugin(int number,int /*param*/)
|
|||||||
g_RCInput->stopInput();
|
g_RCInput->stopInput();
|
||||||
//frameBuffer->setMode(720, 576, 8 * sizeof(fb_pixel_t));
|
//frameBuffer->setMode(720, 576, 8 * sizeof(fb_pixel_t));
|
||||||
printf("Starting %s\n", plugin_list[number].pluginfile.c_str());
|
printf("Starting %s\n", plugin_list[number].pluginfile.c_str());
|
||||||
mysystem(plugin_list[number].pluginfile.c_str(), NULL, NULL);
|
my_system(plugin_list[number].pluginfile.c_str(), NULL, NULL);
|
||||||
//frameBuffer->setMode(720, 576, 8 * sizeof(fb_pixel_t));
|
//frameBuffer->setMode(720, 576, 8 * sizeof(fb_pixel_t));
|
||||||
frameBuffer->paintBackground();
|
frameBuffer->paintBackground();
|
||||||
g_RCInput->restartInput();
|
g_RCInput->restartInput();
|
||||||
|
@@ -24,7 +24,14 @@ endif
|
|||||||
noinst_LIBRARIES = libneutrino_system.a
|
noinst_LIBRARIES = libneutrino_system.a
|
||||||
|
|
||||||
libneutrino_system_a_SOURCES = \
|
libneutrino_system_a_SOURCES = \
|
||||||
localize.cpp setting_helpers.cpp debug.cpp \
|
configure_network.cpp \
|
||||||
ping.c flashtool.cpp httptool.cpp \
|
debug.cpp \
|
||||||
settings.cpp lastchannel.cpp \
|
flashtool.cpp \
|
||||||
configure_network.cpp fsmounter.cpp
|
fsmounter.cpp \
|
||||||
|
httptool.cpp \
|
||||||
|
lastchannel.cpp \
|
||||||
|
localize.cpp \
|
||||||
|
helpers.cpp \
|
||||||
|
ping.c \
|
||||||
|
settings.cpp \
|
||||||
|
setting_helpers.cpp
|
||||||
|
@@ -216,32 +216,6 @@ void CNetworkConfig::commitConfig(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int mysystem(const char * cmd, const char * arg1, const char * arg2)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
pid_t pid;
|
|
||||||
int maxfd = getdtablesize();// sysconf(_SC_OPEN_MAX);
|
|
||||||
switch (pid = vfork())
|
|
||||||
{
|
|
||||||
case -1: /* can't fork */
|
|
||||||
perror("vfork");
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
case 0: /* child process */
|
|
||||||
for(i = 3; i < maxfd; i++)
|
|
||||||
close(i);
|
|
||||||
if(execlp(cmd, cmd, arg1, arg2, NULL))
|
|
||||||
{
|
|
||||||
perror("exec");
|
|
||||||
}
|
|
||||||
exit(0);
|
|
||||||
default: /* parent returns to calling process */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
waitpid(pid, 0, 0);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CNetworkConfig::startNetwork(void)
|
void CNetworkConfig::startNetwork(void)
|
||||||
{
|
{
|
||||||
std::string cmd = "/sbin/ifup " + ifname;
|
std::string cmd = "/sbin/ifup " + ifname;
|
||||||
|
115
src/system/helpers.cpp
Normal file
115
src/system/helpers.cpp
Normal file
@@ -0,0 +1,115 @@
|
|||||||
|
/*
|
||||||
|
Neutrino-GUI - DBoxII-Project
|
||||||
|
|
||||||
|
Copyright (C) 2001 Steffen Hehn 'McClean'
|
||||||
|
Homepage: http://dbox.cyberphoria.org/
|
||||||
|
|
||||||
|
Kommentar:
|
||||||
|
|
||||||
|
Diese GUI wurde von Grund auf neu programmiert und sollte nun vom
|
||||||
|
Aufbau und auch den Ausbaumoeglichkeiten gut aussehen. Neutrino basiert
|
||||||
|
auf der Client-Server Idee, diese GUI ist also von der direkten DBox-
|
||||||
|
Steuerung getrennt. Diese wird dann von Daemons uebernommen.
|
||||||
|
|
||||||
|
|
||||||
|
License: GPL
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include <config.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <sys/wait.h>
|
||||||
|
|
||||||
|
#include <system/helpers.h>
|
||||||
|
|
||||||
|
int my_system(const char * cmd, const char * arg1, const char * arg2)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
pid_t pid;
|
||||||
|
int maxfd = getdtablesize();// sysconf(_SC_OPEN_MAX);
|
||||||
|
switch (pid = vfork())
|
||||||
|
{
|
||||||
|
case -1: /* can't vfork */
|
||||||
|
perror("vfork");
|
||||||
|
return -1;
|
||||||
|
case 0: /* child process */
|
||||||
|
for(i = 3; i < maxfd; i++)
|
||||||
|
close(i);
|
||||||
|
if(execlp(cmd, cmd, arg1, arg2, NULL))
|
||||||
|
{
|
||||||
|
perror("exec");
|
||||||
|
}
|
||||||
|
exit(0);
|
||||||
|
default: /* parent returns to calling process */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
waitpid(pid, 0, 0);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
FILE* my_popen( pid_t& pid, const char *cmdstring, const char *type)
|
||||||
|
{
|
||||||
|
int pfd[2] ={-1,-1};
|
||||||
|
FILE *fp = NULL;
|
||||||
|
|
||||||
|
/* only allow "r" or "w" */
|
||||||
|
if ((type[0] != 'r' && type[0] != 'w') || type[1] != 0) {
|
||||||
|
errno = EINVAL; /* required by POSIX */
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pipe(pfd) < 0)
|
||||||
|
return(NULL); /* errno set by pipe() */
|
||||||
|
|
||||||
|
if ((pid = vfork()) < 0) {
|
||||||
|
return(NULL); /* errno set by vfork() */
|
||||||
|
} else if (pid == 0) { /* child */
|
||||||
|
if (*type == 'r') {
|
||||||
|
close(pfd[0]);
|
||||||
|
if (pfd[1] != STDOUT_FILENO) {
|
||||||
|
dup2(pfd[1], STDOUT_FILENO);
|
||||||
|
close(pfd[1]);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
close(pfd[1]);
|
||||||
|
if (pfd[0] != STDIN_FILENO) {
|
||||||
|
dup2(pfd[0], STDIN_FILENO);
|
||||||
|
close(pfd[0]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
execl("/bin/sh", "sh", "-c", cmdstring, (char *)0);
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* parent continues... */
|
||||||
|
if (*type == 'r') {
|
||||||
|
close(pfd[1]);
|
||||||
|
if ((fp = fdopen(pfd[0], type)) == NULL)
|
||||||
|
return(NULL);
|
||||||
|
} else {
|
||||||
|
close(pfd[0]);
|
||||||
|
if ((fp = fdopen(pfd[1], type)) == NULL)
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
return(fp);
|
||||||
|
}
|
39
src/system/helpers.h
Normal file
39
src/system/helpers.h
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
|
||||||
|
#ifndef __system_helpers__
|
||||||
|
#define __system_helpers__
|
||||||
|
|
||||||
|
/*
|
||||||
|
Neutrino-GUI - DBoxII-Project
|
||||||
|
|
||||||
|
Copyright (C) 2001 Steffen Hehn 'McClean'
|
||||||
|
Homepage: http://dbox.cyberphoria.org/
|
||||||
|
|
||||||
|
Kommentar:
|
||||||
|
|
||||||
|
Diese GUI wurde von Grund auf neu programmiert und sollte nun vom
|
||||||
|
Aufbau und auch den Ausbaumoeglichkeiten gut aussehen. Neutrino basiert
|
||||||
|
auf der Client-Server Idee, diese GUI ist also von der direkten DBox-
|
||||||
|
Steuerung getrennt. Diese wird dann von Daemons uebernommen.
|
||||||
|
|
||||||
|
|
||||||
|
License: GPL
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int my_system(const char * cmd, const char * arg1, const char * arg2);
|
||||||
|
FILE* my_popen( pid_t& pid, const char *cmdstring, const char *type);
|
||||||
|
|
||||||
|
#endif
|
Reference in New Issue
Block a user