aboutsummaryrefslogtreecommitdiffstats
path: root/util.c
diff options
context:
space:
mode:
authoroga2008-04-15 21:20:56 +0000
committeroga2008-04-15 21:20:56 +0000
commit47b2f8d7fe9a817bb3b288ac7e047b08ab825e61 (patch)
treeb7835d22846b2c11a4e3247c6c7c38ed7ae3276e /util.c
parent4fe7a3740f967c868f91aa05868300e95af24727 (diff)
downloadcwm-47b2f8d7fe9a817bb3b288ac7e047b08ab825e61.tar.gz
make the argument parser for commands accept quoted strings, while i'm
there make u_spawn use exec_wm (renamed to u_exec) for it's execution to remove duplicated code. This means constructs like this work in .cwmrc: bind CM-t "ssh -Y 192.168.1.2 \"xterm -e top\"" or alternatively: bind CM-t "ssh -Y 192.168.1.2 'xterm -e top'" "in it goes" okan@.
Diffstat (limited to 'util.c')
-rw-r--r--util.c42
1 files changed, 26 insertions, 16 deletions
diff --git a/util.c b/util.c
index 4b10d72..c4ceff7 100644
--- a/util.c
+++ b/util.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $Id: util.c,v 1.7 2008/04/15 20:26:50 oga Exp $
+ * $Id: util.c,v 1.8 2008/04/15 21:20:56 oga Exp $
*/
#include "headers.h"
@@ -26,19 +26,10 @@
int
u_spawn(char *argstr)
{
- char *args[MAXARGLEN], **ap;
- char **end = &args[MAXARGLEN - 1];
-
switch (fork()) {
case 0:
- ap = args;
- while (ap < end && (*ap = strsep(&argstr, " \t")) != NULL)
- ap++;
-
- *ap = NULL;
- setsid();
- execvp(args[0], args);
- err(1, args[0]);
+ u_exec(argstr);
+ err(1, "%s", argstr);
break;
case -1:
warn("fork");
@@ -51,16 +42,35 @@ u_spawn(char *argstr)
}
void
-exec_wm(char *argstr)
+u_exec(char *argstr)
{
char *args[MAXARGLEN], **ap = args;
char **end = &args[MAXARGLEN - 1];
+ char *tmp;
- while (ap < end && (*ap = strsep(&argstr, " \t")) != NULL)
- ap++;
+ while (ap < end && (*ap = strsep(&argstr, " \t")) != NULL) {
+ if(**ap == '\0')
+ continue;
+ ap++;
+ if (argstr != NULL) {
+ /* deal with quoted strings */
+ switch(argstr[0]) {
+ case '"':
+ case '\'':
+ if ((tmp = strchr(argstr + 1, argstr[0]))
+ != NULL) {
+ *(tmp++) = '\0';
+ *(ap++) = ++argstr;
+ argstr = tmp;
+ }
+ break;
+ default:
+ break;
+ }
+ }
+ }
*ap = NULL;
setsid();
execvp(args[0], args);
- warn(args[0]);
}