473,320 Members | 1,572 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,320 software developers and data experts.

Need a cross-platform way to execute binary

Hello, everyb.

Does anybody know simple cross-platform method of probing if
executable binary is available and launching it.
Problem no.1: test if executable file is available
I'll take windows platform as the most relevant in this case.
os.access() doesn't handle env PATHEXT and can't detect if a given
path would be executable or not. Here "executable" means file that
could be be launched by system() (if there are any other ways - I'd be
happy to know them)

Suppose I have "ufo2exe" executable two directories up.
>>os.access("../../ufo2map.exe", os.X_OK)
True

However...
>>os.access("../../ufo2map", os.X_OK)
False

But...
>>os.system("..\..\ufo2map")
---- ufo2map 1.0 ----
0
Problem no.2: launch executable file
The same windows platform again. All python commands are using forward
slashes for paths, but system doesn't handle this situation (it could
at least try to convert immediate forward slashes to backwards)

os.access() thinks this file is executable, but os.system() fails ...
>>os.access("../../ufo2map.exe", os.X_OK)
True
>>os.system("../../ufo2map.exe")
'..' is not recognized as an internal or external command,
operable program or batch file.
1

the contrary - access() fails to tell this path can be launched, but
file Is executable, ...
>>os.access("..\..\ufo2map", os.X_OK)
False
>>os.system("..\..\ufo2map")
---- ufo2map 1.0 ----
0
Is there any workaround in Python or I have to stick with platforms-
specific quirks?
I'm using Python 2.4.2

Thanks!.

--
--t.

Feb 10 '07 #1
3 2067
En Sat, 10 Feb 2007 06:03:40 -0300, techtonik <te*******@gmail.com>
escribió:
Hello, everyb.

Does anybody know simple cross-platform method of probing if
executable binary is available and launching it.
Problem no.1: test if executable file is available
I'll take windows platform as the most relevant in this case.
os.access() doesn't handle env PATHEXT and can't detect if a given
path would be executable or not. Here "executable" means file that
could be be launched by system() (if there are any other ways - I'd be
happy to know them)

Suppose I have "ufo2exe" executable two directories up.
>>>os.access("../../ufo2map.exe", os.X_OK)
True

However...
>>>os.access("../../ufo2map", os.X_OK)
False
That's right - such file does not exist. On Windows, in general, X_OK is
the same as F_OK: for any existing file, whatever name or extension,
returns True. Permissions are managed thru ACL and this simple function
does NOT consider them.
>
But...
>>>os.system("..\..\ufo2map")
---- ufo2map 1.0 ----
0
(Beware of single \ on normal strings!)
Use win32api.FindExecutable; should return the full path to ufo2map.exe.
"foo.txt" would return notepad.exe (or whatever you have associated to
text files). That is exactly what would be launched by os.system("foo.txt")
Problem no.2: launch executable file
The same windows platform again. All python commands are using forward
slashes for paths, but system doesn't handle this situation (it could
at least try to convert immediate forward slashes to backwards)
Use os.path.normpath on the filename. (If you got it from FindExecutable
above, that would not be needed)
os.access() thinks this file is executable, but os.system() fails ...
>>>os.access("../../ufo2map.exe", os.X_OK)
True
>>>os.system("../../ufo2map.exe")
'..' is not recognized as an internal or external command,
operable program or batch file.
1

the contrary - access() fails to tell this path can be launched, but
file Is executable, ...
>>>os.access("..\..\ufo2map", os.X_OK)
False
Same as above - such file does not exist.
>>>os.system("..\..\ufo2map")
---- ufo2map 1.0 ----
0
Is there any workaround in Python or I have to stick with platforms-
specific quirks?
I'm using Python 2.4.2
I think you will have to treat each platform differently. Just for
starting, the concept of "executable" is not the same across platforms.
But you could make some generic functions (with different implementations
on different platforms).

--
Gabriel Genellina

Feb 10 '07 #2
On Feb 10, 12:03 pm, "Gabriel Genellina" <gagsl...@yahoo.com.ar>
wrote:
Does anybody know simple cross-platform method of probing if
executable binary is available and launching it.
Problem no.1: test if executable file is available
I'll take windows platform as the most relevant in this case.
os.access() doesn't handle env PATHEXT and can't detect if a given
path would be executable or not. Here "executable" means file that
could be be launched by system() (if there are any other ways - I'd be
happy to know them)
Suppose I have "ufo2exe" executable two directories up.
>>os.access("../../ufo2map.exe", os.X_OK)
True
However...
>>os.access("../../ufo2map", os.X_OK)
False

That's right - such file does not exist. On Windows, in general, X_OK is
the same as F_OK: for any existing file, whatever name or extension,
returns True. Permissions are managed thru ACL and this simple function
does NOT consider them.
It shouldn't matter if the file exists or not. Quoting http://
docs.python.org/lib/os-file-dir.html:
"
X_OK
Value to include in the mode parameter of access() to determine
if path can be executed.
"

See - there is no "file" notation as only "path" is tested and "path"
is pretty executable. I think this should be clarified in os.access()
documentation to make the whole business less confusing if not
implemented in interpreter itself. After all the purpose of cross-
platform language is to free developer from writing platform-specific
code.
>
But...
>>os.system("..\..\ufo2map")
---- ufo2map 1.0 ----
0

(Beware of single \ on normal strings!)
Use win32api.FindExecutable; should return the full path to ufo2map.exe.
"foo.txt" would return notepad.exe (or whatever you have associated to
text files). That is exactly what would be launched by os.system("foo.txt")
Why isn't it possible to integrate the functionality in os.access() -
IIUC Python interpreter still uses Windows API itself on this
platform.
Problem no.2: launch executable file
The same windows platform again. All python commands are using forward
slashes for paths, but system doesn't handle this situation (it could
at least try to convert immediate forward slashes to backwards)

Use os.path.normpath on the filename. (If you got it from FindExecutable
above, that would not be needed)
os.access() thinks this file is executable, but os.system() fails ...
>>os.access("../../ufo2map.exe", os.X_OK)
True
>>os.system("../../ufo2map.exe")
'..' is not recognized as an internal or external command,
operable program or batch file.
1
the contrary - access() fails to tell this path can be launched, but
file Is executable, ...
>>os.access("..\..\ufo2map", os.X_OK)
False

Same as above - such file does not exist.
Same as above - access() tests path, not file, so the argument is not
valid.
>>os.system("..\..\ufo2map")
---- ufo2map 1.0 ----
0
Is there any workaround in Python or I have to stick with platforms-
specific quirks?
I'm using Python 2.4.2

I think you will have to treat each platform differently. Just for
starting, the concept of "executable" is not the same across platforms.
But you could make some generic functions (with different implementations
on different platforms).
I would prefer to know as little about underlying platforms as
possible.
It would only be a big plus for Python.

--
--t.

Feb 10 '07 #3
En Sat, 10 Feb 2007 08:48:31 -0300, techtonik <te*******@gmail.com>
escribió:
On Feb 10, 12:03 pm, "Gabriel Genellina" <gagsl...@yahoo.com.ar>
Here "executable" means file that
could be be launched by system() (if there are any other ways - I'd be
happy to know them)
This is a very specific definition of "executable". os.access does not use
that definition.
>>>os.access("../../ufo2map", os.X_OK)
False

That's right - such file does not exist. On Windows, in general, X_OK is
the same as F_OK: for any existing file, whatever name or extension,
returns True. Permissions are managed thru ACL and this simple function
does NOT consider them.

It shouldn't matter if the file exists or not. Quoting http://
docs.python.org/lib/os-file-dir.html:
"
X_OK
Value to include in the mode parameter of access() to determine
if path can be executed.
"

See - there is no "file" notation as only "path" is tested and "path"
is pretty executable.
It appears that your argument is: os.system("../../ufo2map") launches a
new process, so "../../ufo2map" must be executable. But
os.system("foo.txt") also works, so "foo.txt" is also executable?
Please define "executable" first. The definition may be so restrictive as
to only include PE files (all others require a wrapping process) or so
broad as to include almost anything known to the system.
I think this should be clarified in os.access()
documentation to make the whole business less confusing if not
implemented in interpreter itself. After all the purpose of cross-
platform language is to free developer from writing platform-specific
code.
os.access documentation is rather clear - it's just a wrapper around the
access() system call, and I think it should not be changed. It is the
underlying OS which gives the answer, not Python.

On the other hand, an utility library exposing FindExecutable,
ShellExecute, associations and other shell goodies might be useful. Maybe
you could do some research, whether such thing exists, and help improve it
or design a good interfase?
I would prefer to know as little about underlying platforms as
possible.
It would only be a big plus for Python.
Sure, but someone has to write it. I can't think of a good abstraction
right now, perhaps you have some ideas?

--
Gabriel Genellina

Feb 11 '07 #4

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

0
by: Web Science | last post by:
Site and Features: http://www.eigensearch.com Search engine, eigenMethod, eigenvector, mathematical, manifolds, science, technical, search tools, eigenmath, Jacobian, quantum, mechanics,...
16
by: JustSomeGuy | last post by:
I have a routine that evaluates a polynomial equation that have 3 variables x,y,z of orders 1,2,3 the coefficients of the polynomial are in an array. This routine is quite slow and I'd like to...
2
by: News | last post by:
Folks, I need help with this task. I have a set of data that needs to be plotted on timeline chart. Example: Unit ProcStart ProcEnd Machine U1 5/5/03 6:01 5/5/03 6:04 M1 U2 ...
0
by: Web Science | last post by:
Site and Features: http://www.eigensearch.com Search engine, eigenMethod, eigenvector, mathematical, manifolds, science, technical, search tools, eigenmath, Jacobian, quantum, mechanics,...
3
by: amanda | last post by:
Hope someone can help me with this - I've been staring at it stupidly for hours now, convinced there must be an easy way to achieve the results I want: I have a very large table recording every...
23
by: Jeff Rodriguez | last post by:
Here's what I want do: Have a main daemon which starts up several threads in a Boss-Queue structure. From those threads, I want them all to sit and watch a queue. Once an entry goes into the...
0
by: Web Science | last post by:
Site and Features: http://www.eigensearch.com Search engine, eigenMethod, eigenvector, mathematical, manifolds, science, technical, search tools, eigenmath, Jacobian, quantum, mechanics,...
2
by: P2P | last post by:
Hi I am wondering if someone know of a free cross-browsers vertical scrolling script that - is cross cross-browsers - will call the scrolling content from an external html page or from a...
1
by: Sebastian Spandauer | last post by:
Hey, i am searching for a php script that features sending a lets say 20 lesson online course. it should: subscription on website opt-in after subsriciption send one lesson per day to every...
6
by: ampo | last post by:
Hello. Can anyone help with cross-domain problem? I have HTML page from server1 that send xmlHTTPRequest to server2. How can I do it? Thanks.
0
by: DolphinDB | last post by:
Tired of spending countless mintues downsampling your data? Look no further! In this article, you’ll learn how to efficiently downsample 6.48 billion high-frequency records to 61 million...
0
isladogs
by: isladogs | last post by:
The next Access Europe meeting will be on Wednesday 6 Mar 2024 starting at 18:00 UK time (6PM UTC) and finishing at about 19:15 (7.15PM). In this month's session, we are pleased to welcome back...
1
isladogs
by: isladogs | last post by:
The next Access Europe meeting will be on Wednesday 6 Mar 2024 starting at 18:00 UK time (6PM UTC) and finishing at about 19:15 (7.15PM). In this month's session, we are pleased to welcome back...
0
by: jfyes | last post by:
As a hardware engineer, after seeing that CEIWEI recently released a new tool for Modbus RTU Over TCP/UDP filtering and monitoring, I actively went to its official website to take a look. It turned...
1
by: PapaRatzi | last post by:
Hello, I am teaching myself MS Access forms design and Visual Basic. I've created a table to capture a list of Top 30 singles and forms to capture new entries. The final step is a form (unbound)...
1
by: CloudSolutions | last post by:
Introduction: For many beginners and individual users, requiring a credit card and email registration may pose a barrier when starting to use cloud servers. However, some cloud server providers now...
1
by: Defcon1945 | last post by:
I'm trying to learn Python using Pycharm but import shutil doesn't work
0
by: af34tf | last post by:
Hi Guys, I have a domain whose name is BytesLimited.com, and I want to sell it. Does anyone know about platforms that allow me to list my domain in auction for free. Thank you
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 3 Apr 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome former...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.