This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: commands.getstatusoutput(): cmd.exe support
Type: Stage:
Components: Library (Lib) Versions:
process
Status: closed Resolution: wont fix
Dependencies: Superseder:
Assigned To: Nosy List: georg.brandl, loewis, matthieu.labbe, pierre_rouleau
Priority: normal Keywords:

Created on 2002-01-20 18:13 by pierre_rouleau, last changed 2022-04-10 16:04 by admin. This issue is now closed.

Messages (4)
msg8902 - (view) Author: Pierre Rouleau (pierre_rouleau) Date: 2002-01-20 18:13
##commands.getstatusoutput(): Does not support for DOS-type shells
# -------------------------------------------------------------
# 
# Inside commands.py, the getstatusoutput() function is not capable of running a 
# DOS-type shell command.  The current code assumes that the operating system 
# is running a Unix-type shell.
# 
# The old code is:

def getstatusoutput(cmd):
    """Return (status, output) of executing cmd in a shell."""
    import os
    pipe = os.popen('{ ' + cmd + '; } 2>&1', 'r')
    text = pipe.read()
    sts = pipe.close()
    if sts is None: sts = 0
    if text[-1:] == '\n': text = text[:-1]
    return sts, text


# I propose that we update that code to check the operating system and support 
# DOS-style shells (for DOS, NT, OS/2) with the following modified code:

def getstatusoutput(cmd):
    """Return (status, output) of executing cmd in a shell."""
    import os
    if os.name in ['nt', 'dos', 'os2'] :
       # use Dos style command shell for NT, DOS and OS/2
       pipe = os.popen(cmd + ' 2>&1', 'r')               
    else :
       # use Unix style for all others
       pipe = os.popen('{ ' + cmd + '; } 2>&1', 'r')
    text = pipe.read()
    sts = pipe.close()
    if sts is None: sts = 0
    if text[-1:] == '\n': text = text[:-1]
    return sts, text

msg8903 - (view) Author: Martin v. Löwis (loewis) * (Python committer) Date: 2002-01-23 08:05
Logged In: YES 
user_id=21627

My first reaction to this was "Is DOS still supported"?
Changing subject to mention cmd.exe (which is not a DOS
application).
msg8904 - (view) Author: Pierre Rouleau (pierre_rouleau) Date: 2002-01-24 01:14
Logged In: YES 
user_id=420631

The changed proposed is for DOS-type shells, not DOS itself (as far as I know pure MS-DOS or PC-DOS 
are not supported). But Win32 platforms are (NT, 2000, ...) and they use the same type of native command 
interpreter shell.  With the proposed change getstatusoutput() works in those.  cmd.exe is available in NT, 
2000 and also in OS/2.
msg8905 - (view) Author: Georg Brandl (georg.brandl) * (Python committer) Date: 2007-03-14 08:36
commands.py explicitly states "UNIX only".

Anyway, nowadays you should use the subprocess module for such tasks.
History
Date User Action Args
2022-04-10 16:04:54adminsetgithub: 35957
2010-07-16 09:21:18matthieu.labbesetnosy: + matthieu.labbe
2002-01-20 18:13:10pierre_rouleaucreate