• Re: subprocess.Popen does not launch audacity

    From MRAB@21:1/5 to Tim Johnson via Python-list on Fri Jan 10 20:32:08 2025
    On 2025-01-10 19:15, Tim Johnson via Python-list wrote:
    Using Python 3.12.3 on Ubuntu 24.04

    I've converted a legacy python2 script to python3. All went well.
    However, a glitch from python2 remains.

    The script uses dmenu to create menus to pick applications. Applications
    are then invoked from python

    using subprocess.Popen(). I have never been able to successfully launch audacity using this approach,

    which does work for other apps.

    I can launch audacity successfully using dmenu_run (on its own, outside
    of the script)

    Below is the pertinent code:

     Popen(choice, stdout=PIPE, stderr=PIPE,
                      stdin=PIPE, close_fds=True)

    My guess is my argument list is either insufficient or an argument is
    causing the problem, but am unsure of which.

    I have been retired from python programming for ten years, and am pretty rusty, but it is still fun. There are plenty

    of other ways to successfully launch audacity but it would be great to
    make it work from this script.


    What is the value of 'choice'?

    You could try printing out the value of 'choice' for one that works and
    the one that doesn't and then try them again interactively from the
    Python prompt with the given values. That should eliminate all but the essential code for easier debugging.

    --- SoupGate-Win32 v1.05
    * Origin: fsxNet Usenet Gateway (21:1/5)
  • From Gilmeh Serda@21:1/5 to Tim Johnson on Fri Jan 10 21:46:53 2025
    On Fri, 10 Jan 2025 10:15:50 -0900, Tim Johnson wrote:

    using subprocess.Popen(). I have never been able to successfully launch audacity using this approach,

    Some thoughts you might try:

    What does your .desktop file say (launcher menu)? Assuming you have it installed that way. Or is it a flatpak or something?

    Read the .desktop file so you use the exact same command. It might not be
    what you expected. It might need some option or it's a different command
    from what you thought.

    Or, try the command you used, but at the prompt, does that work? Get any errors?

    Or try something simpler, like without PIPEs, sort of back to basics, as
    it were.

    What's in "choice" variable? Only the (correct) command, or something else also? Test it to be sure, it's easy to add things that shouldn't be there
    in a moment of a brain fatigue.

    Does it work outside your script file? For instance by invoking the Python prompt and try there?

    --
    Gilmeh

    They are relatively good but absolutely terrible. -- Alan Kay, commenting
    on Apollos

    --- SoupGate-Win32 v1.05
    * Origin: fsxNet Usenet Gateway (21:1/5)
  • From Thomas Passin@21:1/5 to Tim Johnson via Python-list on Fri Jan 10 16:53:14 2025
    On 1/10/2025 4:00 PM, Tim Johnson via Python-list wrote:

    On 1/10/25 11:32, MRAB via Python-list wrote:
    ,,, snipped

    Below is the pertinent code:

       Popen(choice, stdout=PIPE, stderr=PIPE,
                        stdin=PIPE, close_fds=True)

    My guess is my argument list is either insufficient or an argument is
    causing the problem, but am unsure of which.

    I have been retired from python programming for ten years, and am pretty >>> rusty, but it is still fun. There are plenty

    of other ways to successfully launch audacity but it would be great to
    make it work from this script.


    What is the value of 'choice'?

    You could try printing out the value of 'choice' for one that works
    and the one that doesn't and then try them again interactively from
    the Python prompt with the given values. That should eliminate all but
    the essential code for easier debugging.

    choice is /usr/local/bin/audacity, which is the correct path for
    audacity on my system. As far as I can see, that string has no hidden
    bytes.

    Invoking /usr/local/bin/audacity from the command line launches audacity
    and so does choosing  with dmenu_run. which -a audacity shows only that item.

    Maybe I need to isolate the function call and start stripping out
    parameters. I should have time to do that later today.

    I don't know why you would want to redirect stdin, etc. It's a GUI application.

    This worked for me in a Python session on EndeavourOS, python 3.13.1:

    from subprocess import run
    run('/usr/bin/audacity')

    --- SoupGate-Win32 v1.05
    * Origin: fsxNet Usenet Gateway (21:1/5)