Redirecting stdout from two programs











up vote
1
down vote

favorite












I'm running a memory check tool (prog1) on a C++ code (prog2), both of which give me a huge and detailed output. In order to chase down some bugs I need to save this output to a file.



I tried redirecting the stdout to a file:




prog1 prog2 > outfile.txt




But that gives me a file containing the output of prog2, while the output of prog1 is still going to the terminal.



Anyone know a way to specify that I want BOTH outputs to go to a file? Like (prog1 prog2) > outfile.txt?










share|improve this question







New contributor




FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
























    up vote
    1
    down vote

    favorite












    I'm running a memory check tool (prog1) on a C++ code (prog2), both of which give me a huge and detailed output. In order to chase down some bugs I need to save this output to a file.



    I tried redirecting the stdout to a file:




    prog1 prog2 > outfile.txt




    But that gives me a file containing the output of prog2, while the output of prog1 is still going to the terminal.



    Anyone know a way to specify that I want BOTH outputs to go to a file? Like (prog1 prog2) > outfile.txt?










    share|improve this question







    New contributor




    FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.






















      up vote
      1
      down vote

      favorite









      up vote
      1
      down vote

      favorite











      I'm running a memory check tool (prog1) on a C++ code (prog2), both of which give me a huge and detailed output. In order to chase down some bugs I need to save this output to a file.



      I tried redirecting the stdout to a file:




      prog1 prog2 > outfile.txt




      But that gives me a file containing the output of prog2, while the output of prog1 is still going to the terminal.



      Anyone know a way to specify that I want BOTH outputs to go to a file? Like (prog1 prog2) > outfile.txt?










      share|improve this question







      New contributor




      FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      I'm running a memory check tool (prog1) on a C++ code (prog2), both of which give me a huge and detailed output. In order to chase down some bugs I need to save this output to a file.



      I tried redirecting the stdout to a file:




      prog1 prog2 > outfile.txt




      But that gives me a file containing the output of prog2, while the output of prog1 is still going to the terminal.



      Anyone know a way to specify that I want BOTH outputs to go to a file? Like (prog1 prog2) > outfile.txt?







      command-line io-redirection stdout






      share|improve this question







      New contributor




      FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question







      New contributor




      FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question






      New contributor




      FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 1 hour ago









      FJC

      1084




      1084




      New contributor




      FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      FJC is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          3
          down vote



          accepted










          There’s a good chance that prog1 is writing its output to standard error. You can redirect both outputs to a single file with



          prog1 prog2 2>&1 > outfile.txt


          or you can split the outputs with



          prog1 prog2 > outfile.txt 2> errors.txt


          This doesn’t separate the individual programs’ output, it separates the output channels. See What are the shell's control and redirection operators? for details.



          If you look at prog1’s documentation, you might find an option to tell it to store its output in a named file instead. For example, with strace,



          strace -o strace.txt prog2 > outfile.txt


          would store strace’s output in strace.txt, and everything written to standard output in outfile.txt.






          share|improve this answer





















            Your Answer








            StackExchange.ready(function() {
            var channelOptions = {
            tags: "".split(" "),
            id: "106"
            };
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function() {
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled) {
            StackExchange.using("snippets", function() {
            createEditor();
            });
            }
            else {
            createEditor();
            }
            });

            function createEditor() {
            StackExchange.prepareEditor({
            heartbeatType: 'answer',
            convertImagesToLinks: false,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            imageUploader: {
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            },
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            });


            }
            });






            FJC is a new contributor. Be nice, and check out our Code of Conduct.










            draft saved

            draft discarded


















            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f489462%2fredirecting-stdout-from-two-programs%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes








            up vote
            3
            down vote



            accepted










            There’s a good chance that prog1 is writing its output to standard error. You can redirect both outputs to a single file with



            prog1 prog2 2>&1 > outfile.txt


            or you can split the outputs with



            prog1 prog2 > outfile.txt 2> errors.txt


            This doesn’t separate the individual programs’ output, it separates the output channels. See What are the shell's control and redirection operators? for details.



            If you look at prog1’s documentation, you might find an option to tell it to store its output in a named file instead. For example, with strace,



            strace -o strace.txt prog2 > outfile.txt


            would store strace’s output in strace.txt, and everything written to standard output in outfile.txt.






            share|improve this answer

























              up vote
              3
              down vote



              accepted










              There’s a good chance that prog1 is writing its output to standard error. You can redirect both outputs to a single file with



              prog1 prog2 2>&1 > outfile.txt


              or you can split the outputs with



              prog1 prog2 > outfile.txt 2> errors.txt


              This doesn’t separate the individual programs’ output, it separates the output channels. See What are the shell's control and redirection operators? for details.



              If you look at prog1’s documentation, you might find an option to tell it to store its output in a named file instead. For example, with strace,



              strace -o strace.txt prog2 > outfile.txt


              would store strace’s output in strace.txt, and everything written to standard output in outfile.txt.






              share|improve this answer























                up vote
                3
                down vote



                accepted







                up vote
                3
                down vote



                accepted






                There’s a good chance that prog1 is writing its output to standard error. You can redirect both outputs to a single file with



                prog1 prog2 2>&1 > outfile.txt


                or you can split the outputs with



                prog1 prog2 > outfile.txt 2> errors.txt


                This doesn’t separate the individual programs’ output, it separates the output channels. See What are the shell's control and redirection operators? for details.



                If you look at prog1’s documentation, you might find an option to tell it to store its output in a named file instead. For example, with strace,



                strace -o strace.txt prog2 > outfile.txt


                would store strace’s output in strace.txt, and everything written to standard output in outfile.txt.






                share|improve this answer












                There’s a good chance that prog1 is writing its output to standard error. You can redirect both outputs to a single file with



                prog1 prog2 2>&1 > outfile.txt


                or you can split the outputs with



                prog1 prog2 > outfile.txt 2> errors.txt


                This doesn’t separate the individual programs’ output, it separates the output channels. See What are the shell's control and redirection operators? for details.



                If you look at prog1’s documentation, you might find an option to tell it to store its output in a named file instead. For example, with strace,



                strace -o strace.txt prog2 > outfile.txt


                would store strace’s output in strace.txt, and everything written to standard output in outfile.txt.







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered 1 hour ago









                Stephen Kitt

                162k24358436




                162k24358436






















                    FJC is a new contributor. Be nice, and check out our Code of Conduct.










                    draft saved

                    draft discarded


















                    FJC is a new contributor. Be nice, and check out our Code of Conduct.













                    FJC is a new contributor. Be nice, and check out our Code of Conduct.












                    FJC is a new contributor. Be nice, and check out our Code of Conduct.
















                    Thanks for contributing an answer to Unix & Linux Stack Exchange!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.





                    Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                    Please pay close attention to the following guidance:


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f489462%2fredirecting-stdout-from-two-programs%23new-answer', 'question_page');
                    }
                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    flock() on closed filehandle LOCK_FILE at /usr/bin/apt-mirror

                    Mangá

                     ⁒  ․,‪⁊‑⁙ ⁖, ⁇‒※‌, †,⁖‗‌⁝    ‾‸⁘,‖⁔⁣,⁂‾
”‑,‥–,‬ ,⁀‹⁋‴⁑ ‒ ,‴⁋”‼ ⁨,‷⁔„ ‰′,‐‚ ‥‡‎“‷⁃⁨⁅⁣,⁔
⁇‘⁔⁡⁏⁌⁡‿‶‏⁨ ⁣⁕⁖⁨⁩⁥‽⁀  ‴‬⁜‟ ⁃‣‧⁕‮ …‍⁨‴ ⁩,⁚⁖‫ ,‵ ⁀,‮⁝‣‣ ⁑  ⁂– ․, ‾‽ ‏⁁“⁗‸ ‾… ‹‡⁌⁎‸‘ ‡⁏⁌‪ ‵⁛ ‎⁨ ―⁦⁤⁄⁕