Beefy Boxes and Bandwidth Generously Provided by pair Networks
Do you know where your variables are?

System, exec different behaviour with spaces

by sacambs (Initiate)
on Jan 12, 2012 at 09:53 UTC ( #947507=perlquestion: print w/replies, xml ) Need Help??
sacambs has asked for the wisdom of the Perl Monks concerning the following question:

I'm seeing some odd behaviour when running an exec command on an executable whose path contains spaces, for some reason part of the command name seems to be passed as an argument to the program. Oddly this doesn't happen if I use system instead of exec. The docs for exec suggest that since I'm passing an argument list there should be no shell interpretation, so I can't figure out why this would be happening.

>perl -e "exec 'c:\Program Files\Java\jdk1.5.0_22\bin\java.exe','-vers +ion'" D:\Subversion\FastQC\bin>Exception in thread "main" java.lang.NoClassD +efFoundError: Files\Java\jdk1/5/0_22\bin\java/exe >perl -e "system 'c:\Program Files\Java\jdk1.5.0_22\bin\java.exe','-ve +rsion'" java version "1.5.0_22" Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_22-b03) Java HotSpot(TM) 64-Bit Server VM (build 1.5.0_22-b03, mixed mode)
The java error from the exec shows that the correct binary is being called, but that its first argument is everything after the space in the program path. What do I need to do to the exec command so that the only argument the called program sees is the one I explicitly passed it?

Replies are listed 'Best First'.
Re: System, exec different behaviour with spaces
by Anonymous Monk on Jan 12, 2012 at 10:08 UTC

      Thanks for the pointers - I'm somewhat clearer about where the problem comes from, even if the fix is somewhat convoluted (I need to support multiple platforms). What I still don't get is why the behaviour is OK when using system, but not exec. I'd have thought that in terms of their argument passing the two would have been equivalent.

        What I still don't get is why the behaviour is OK when using system, but not exec.

        Perhaps you didn't notice, but that is what I asked :)

        Though, at this point, i don't really care what the answer is :)

Re: System, exec different behaviour with spaces
by ikegami (Pope) on Jan 13, 2012 at 07:09 UTC

    You can work around this weirdness by using the following:

    perl -e"$prog = 'C:\Program Files\Java\jdk1.6.0_15\bin\java.exe'; exec + { $prog } 'java', '-version'"

    It doesn't work if you use the full path after the curlies.

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: perlquestion [id://947507]
Approved by moritz
[1nickt]: I have been an apostate in the Apple orchard for almost 15 years. But Dells are still high quality it seems, unlike Macs these days.
[1nickt]: And you can still configure the system at will, on the "Small Business" site.
[Corion]: 1nickt: I bought a 2015 XPS 13, which is a very nice and shiney (and somewhat overpriced) machine, but I think it's still better priced than an Apple machine. Now it just has to hold up 10 years like the old one did ;)
[1nickt]: Ah, you got Linus' fave? With Ubuntu? 4k display?
[1nickt]: ( The 17" monster I just bought is for my wife, who doesn;t leave the house with it...)

How do I use this? | Other CB clients
Other Users?
Others pondering the Monastery: (9)
As of 2017-03-27 13:06 GMT
Find Nodes?
    Voting Booth?
    Should Pluto Get Its Planethood Back?

    Results (320 votes). Check out past polls.