Removing c-style comments with sed












2















I need to delete some kind of characteristic, single line C++ comments from all files in our repository. Code looks something like this:



some_code
// characteristic_comment_to_delete
some_more_code // another_comment
another_line_with_code // characteristic_comment_to_delete
even_more_code


As a result, I would like to get this:



some_code
some_more_code // another_comment
another_line_with_code
even_more_code


I used sed command that makes my result almost as good as I would like:



#sed -i -e 's&// characteristic_comment_to_delete.*&&g' some_file.cpp
some_code

some_more_code // another_comment
another_line_with_code
even_more_code


Unfortunately, leaving those blank lines is unacceptable solution, so I need somehow improve my command so that it removes whole line, but only if it is left blank after removing this specific comment.










share|improve this question









New contributor




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





















  • @jimmij, the OP doesn't want to remove all comments, only // characteristic_comment_to_delete

    – Stéphane Chazelas
    12 hours ago











  • For C-style comments, How can I delete all characters falling under /* .... */ including /* & */? would be a closer match.

    – Stéphane Chazelas
    12 hours ago











  • Off topic, but you're not really running this command as root, are you? That # prompt makes my eye twitch.

    – David Conrad
    9 hours ago











  • Possible duplicate of Remove comments in a C file

    – MCCCS
    8 hours ago
















2















I need to delete some kind of characteristic, single line C++ comments from all files in our repository. Code looks something like this:



some_code
// characteristic_comment_to_delete
some_more_code // another_comment
another_line_with_code // characteristic_comment_to_delete
even_more_code


As a result, I would like to get this:



some_code
some_more_code // another_comment
another_line_with_code
even_more_code


I used sed command that makes my result almost as good as I would like:



#sed -i -e 's&// characteristic_comment_to_delete.*&&g' some_file.cpp
some_code

some_more_code // another_comment
another_line_with_code
even_more_code


Unfortunately, leaving those blank lines is unacceptable solution, so I need somehow improve my command so that it removes whole line, but only if it is left blank after removing this specific comment.










share|improve this question









New contributor




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





















  • @jimmij, the OP doesn't want to remove all comments, only // characteristic_comment_to_delete

    – Stéphane Chazelas
    12 hours ago











  • For C-style comments, How can I delete all characters falling under /* .... */ including /* & */? would be a closer match.

    – Stéphane Chazelas
    12 hours ago











  • Off topic, but you're not really running this command as root, are you? That # prompt makes my eye twitch.

    – David Conrad
    9 hours ago











  • Possible duplicate of Remove comments in a C file

    – MCCCS
    8 hours ago














2












2








2








I need to delete some kind of characteristic, single line C++ comments from all files in our repository. Code looks something like this:



some_code
// characteristic_comment_to_delete
some_more_code // another_comment
another_line_with_code // characteristic_comment_to_delete
even_more_code


As a result, I would like to get this:



some_code
some_more_code // another_comment
another_line_with_code
even_more_code


I used sed command that makes my result almost as good as I would like:



#sed -i -e 's&// characteristic_comment_to_delete.*&&g' some_file.cpp
some_code

some_more_code // another_comment
another_line_with_code
even_more_code


Unfortunately, leaving those blank lines is unacceptable solution, so I need somehow improve my command so that it removes whole line, but only if it is left blank after removing this specific comment.










share|improve this question









New contributor




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












I need to delete some kind of characteristic, single line C++ comments from all files in our repository. Code looks something like this:



some_code
// characteristic_comment_to_delete
some_more_code // another_comment
another_line_with_code // characteristic_comment_to_delete
even_more_code


As a result, I would like to get this:



some_code
some_more_code // another_comment
another_line_with_code
even_more_code


I used sed command that makes my result almost as good as I would like:



#sed -i -e 's&// characteristic_comment_to_delete.*&&g' some_file.cpp
some_code

some_more_code // another_comment
another_line_with_code
even_more_code


Unfortunately, leaving those blank lines is unacceptable solution, so I need somehow improve my command so that it removes whole line, but only if it is left blank after removing this specific comment.







linux sed






share|improve this question









New contributor




forteller 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




forteller 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








edited 10 hours ago









Rui F Ribeiro

40.7k1479137




40.7k1479137






New contributor




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









asked 14 hours ago









fortellerforteller

112




112




New contributor




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





New contributor





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






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













  • @jimmij, the OP doesn't want to remove all comments, only // characteristic_comment_to_delete

    – Stéphane Chazelas
    12 hours ago











  • For C-style comments, How can I delete all characters falling under /* .... */ including /* & */? would be a closer match.

    – Stéphane Chazelas
    12 hours ago











  • Off topic, but you're not really running this command as root, are you? That # prompt makes my eye twitch.

    – David Conrad
    9 hours ago











  • Possible duplicate of Remove comments in a C file

    – MCCCS
    8 hours ago



















  • @jimmij, the OP doesn't want to remove all comments, only // characteristic_comment_to_delete

    – Stéphane Chazelas
    12 hours ago











  • For C-style comments, How can I delete all characters falling under /* .... */ including /* & */? would be a closer match.

    – Stéphane Chazelas
    12 hours ago











  • Off topic, but you're not really running this command as root, are you? That # prompt makes my eye twitch.

    – David Conrad
    9 hours ago











  • Possible duplicate of Remove comments in a C file

    – MCCCS
    8 hours ago

















@jimmij, the OP doesn't want to remove all comments, only // characteristic_comment_to_delete

– Stéphane Chazelas
12 hours ago





@jimmij, the OP doesn't want to remove all comments, only // characteristic_comment_to_delete

– Stéphane Chazelas
12 hours ago













For C-style comments, How can I delete all characters falling under /* .... */ including /* & */? would be a closer match.

– Stéphane Chazelas
12 hours ago





For C-style comments, How can I delete all characters falling under /* .... */ including /* & */? would be a closer match.

– Stéphane Chazelas
12 hours ago













Off topic, but you're not really running this command as root, are you? That # prompt makes my eye twitch.

– David Conrad
9 hours ago





Off topic, but you're not really running this command as root, are you? That # prompt makes my eye twitch.

– David Conrad
9 hours ago













Possible duplicate of Remove comments in a C file

– MCCCS
8 hours ago





Possible duplicate of Remove comments in a C file

– MCCCS
8 hours ago










4 Answers
4






active

oldest

votes


















4














Sed has a d command for deleting whole lines - it can also take an arbitrary (non /) delimiter, however it needs to be escaped with on first use. So you could do something like



$ sed -e '#^// characteristic_comment_to_delete$#d' -e 's#// characteristic_comment_to_delete.*##' file
some_code
some_more_code // another_comment
another_line_with_code
even_more_code


to first delete lines that consist entirely of // characteristic_comment_to_delete, then substitute any remaining occurrences.



(I changed your & to # to avoid confusion with the sed & replacement operator).






share|improve this answer































    2














    With GNU sed:



    sed 's|s*// characteristic_comment_to_delete.*||;T;/./!d'


    T is a GNU extension that branches off unless the previous s substitution was successful. So if no comment was removed, we branch off, and the next /./!d (which deletes the line unless it contains at least one character) is skipped.



    Standard equivalent:



    sed '/[[:space:]]*// characteristic_comment_to_delete.*/{s///;/./!d;}'


    Or:



    sed 's|[[:space:]]*// characteristic_comment_to_delete.*||
    t 1
    b
    :1
    /./!d'


    Both suppress empty lines only if the substitution was successful.






    share|improve this answer

































      1














      If you accept an AWK solution:



      awk -F "[   ]*//[   ]*characteristic_comment_to_delete.*" '$1 != "" { print $1; }' some_file.cpp


      Note: The pattern contains a space and a TAB between the brackets [ ].



      This solution does not correctly handle string literals containing the comment pattern, e.g.
      char text = "// characteristic_comment_to_delete bla bla";






      share|improve this answer































        1














        Demonstrating storing the comment in a shell variable, and escaping the slash characters with shell parameter expansion. Otherwise, same as steeldriver's answer.



        $ comment='// characteristic_comment_to_delete'
        $ sed -e "/^[[:blank:]]*${comment////\/}/d" -e "s/${comment////\/}.*//" file
        some_code
        some_more_code // another_comment
        another_line_with_code
        even_more_code





        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',
          autoActivateHeartbeat: false,
          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
          });


          }
          });






          forteller 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%2f503784%2fremoving-c-style-comments-with-sed%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          4 Answers
          4






          active

          oldest

          votes








          4 Answers
          4






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          4














          Sed has a d command for deleting whole lines - it can also take an arbitrary (non /) delimiter, however it needs to be escaped with on first use. So you could do something like



          $ sed -e '#^// characteristic_comment_to_delete$#d' -e 's#// characteristic_comment_to_delete.*##' file
          some_code
          some_more_code // another_comment
          another_line_with_code
          even_more_code


          to first delete lines that consist entirely of // characteristic_comment_to_delete, then substitute any remaining occurrences.



          (I changed your & to # to avoid confusion with the sed & replacement operator).






          share|improve this answer




























            4














            Sed has a d command for deleting whole lines - it can also take an arbitrary (non /) delimiter, however it needs to be escaped with on first use. So you could do something like



            $ sed -e '#^// characteristic_comment_to_delete$#d' -e 's#// characteristic_comment_to_delete.*##' file
            some_code
            some_more_code // another_comment
            another_line_with_code
            even_more_code


            to first delete lines that consist entirely of // characteristic_comment_to_delete, then substitute any remaining occurrences.



            (I changed your & to # to avoid confusion with the sed & replacement operator).






            share|improve this answer


























              4












              4








              4







              Sed has a d command for deleting whole lines - it can also take an arbitrary (non /) delimiter, however it needs to be escaped with on first use. So you could do something like



              $ sed -e '#^// characteristic_comment_to_delete$#d' -e 's#// characteristic_comment_to_delete.*##' file
              some_code
              some_more_code // another_comment
              another_line_with_code
              even_more_code


              to first delete lines that consist entirely of // characteristic_comment_to_delete, then substitute any remaining occurrences.



              (I changed your & to # to avoid confusion with the sed & replacement operator).






              share|improve this answer













              Sed has a d command for deleting whole lines - it can also take an arbitrary (non /) delimiter, however it needs to be escaped with on first use. So you could do something like



              $ sed -e '#^// characteristic_comment_to_delete$#d' -e 's#// characteristic_comment_to_delete.*##' file
              some_code
              some_more_code // another_comment
              another_line_with_code
              even_more_code


              to first delete lines that consist entirely of // characteristic_comment_to_delete, then substitute any remaining occurrences.



              (I changed your & to # to avoid confusion with the sed & replacement operator).







              share|improve this answer












              share|improve this answer



              share|improve this answer










              answered 14 hours ago









              steeldriversteeldriver

              36.4k35286




              36.4k35286

























                  2














                  With GNU sed:



                  sed 's|s*// characteristic_comment_to_delete.*||;T;/./!d'


                  T is a GNU extension that branches off unless the previous s substitution was successful. So if no comment was removed, we branch off, and the next /./!d (which deletes the line unless it contains at least one character) is skipped.



                  Standard equivalent:



                  sed '/[[:space:]]*// characteristic_comment_to_delete.*/{s///;/./!d;}'


                  Or:



                  sed 's|[[:space:]]*// characteristic_comment_to_delete.*||
                  t 1
                  b
                  :1
                  /./!d'


                  Both suppress empty lines only if the substitution was successful.






                  share|improve this answer






























                    2














                    With GNU sed:



                    sed 's|s*// characteristic_comment_to_delete.*||;T;/./!d'


                    T is a GNU extension that branches off unless the previous s substitution was successful. So if no comment was removed, we branch off, and the next /./!d (which deletes the line unless it contains at least one character) is skipped.



                    Standard equivalent:



                    sed '/[[:space:]]*// characteristic_comment_to_delete.*/{s///;/./!d;}'


                    Or:



                    sed 's|[[:space:]]*// characteristic_comment_to_delete.*||
                    t 1
                    b
                    :1
                    /./!d'


                    Both suppress empty lines only if the substitution was successful.






                    share|improve this answer




























                      2












                      2








                      2







                      With GNU sed:



                      sed 's|s*// characteristic_comment_to_delete.*||;T;/./!d'


                      T is a GNU extension that branches off unless the previous s substitution was successful. So if no comment was removed, we branch off, and the next /./!d (which deletes the line unless it contains at least one character) is skipped.



                      Standard equivalent:



                      sed '/[[:space:]]*// characteristic_comment_to_delete.*/{s///;/./!d;}'


                      Or:



                      sed 's|[[:space:]]*// characteristic_comment_to_delete.*||
                      t 1
                      b
                      :1
                      /./!d'


                      Both suppress empty lines only if the substitution was successful.






                      share|improve this answer















                      With GNU sed:



                      sed 's|s*// characteristic_comment_to_delete.*||;T;/./!d'


                      T is a GNU extension that branches off unless the previous s substitution was successful. So if no comment was removed, we branch off, and the next /./!d (which deletes the line unless it contains at least one character) is skipped.



                      Standard equivalent:



                      sed '/[[:space:]]*// characteristic_comment_to_delete.*/{s///;/./!d;}'


                      Or:



                      sed 's|[[:space:]]*// characteristic_comment_to_delete.*||
                      t 1
                      b
                      :1
                      /./!d'


                      Both suppress empty lines only if the substitution was successful.







                      share|improve this answer














                      share|improve this answer



                      share|improve this answer








                      edited 9 hours ago

























                      answered 12 hours ago









                      Stéphane ChazelasStéphane Chazelas

                      308k57581939




                      308k57581939























                          1














                          If you accept an AWK solution:



                          awk -F "[   ]*//[   ]*characteristic_comment_to_delete.*" '$1 != "" { print $1; }' some_file.cpp


                          Note: The pattern contains a space and a TAB between the brackets [ ].



                          This solution does not correctly handle string literals containing the comment pattern, e.g.
                          char text = "// characteristic_comment_to_delete bla bla";






                          share|improve this answer




























                            1














                            If you accept an AWK solution:



                            awk -F "[   ]*//[   ]*characteristic_comment_to_delete.*" '$1 != "" { print $1; }' some_file.cpp


                            Note: The pattern contains a space and a TAB between the brackets [ ].



                            This solution does not correctly handle string literals containing the comment pattern, e.g.
                            char text = "// characteristic_comment_to_delete bla bla";






                            share|improve this answer


























                              1












                              1








                              1







                              If you accept an AWK solution:



                              awk -F "[   ]*//[   ]*characteristic_comment_to_delete.*" '$1 != "" { print $1; }' some_file.cpp


                              Note: The pattern contains a space and a TAB between the brackets [ ].



                              This solution does not correctly handle string literals containing the comment pattern, e.g.
                              char text = "// characteristic_comment_to_delete bla bla";






                              share|improve this answer













                              If you accept an AWK solution:



                              awk -F "[   ]*//[   ]*characteristic_comment_to_delete.*" '$1 != "" { print $1; }' some_file.cpp


                              Note: The pattern contains a space and a TAB between the brackets [ ].



                              This solution does not correctly handle string literals containing the comment pattern, e.g.
                              char text = "// characteristic_comment_to_delete bla bla";







                              share|improve this answer












                              share|improve this answer



                              share|improve this answer










                              answered 13 hours ago









                              BodoBodo

                              1,780212




                              1,780212























                                  1














                                  Demonstrating storing the comment in a shell variable, and escaping the slash characters with shell parameter expansion. Otherwise, same as steeldriver's answer.



                                  $ comment='// characteristic_comment_to_delete'
                                  $ sed -e "/^[[:blank:]]*${comment////\/}/d" -e "s/${comment////\/}.*//" file
                                  some_code
                                  some_more_code // another_comment
                                  another_line_with_code
                                  even_more_code





                                  share|improve this answer




























                                    1














                                    Demonstrating storing the comment in a shell variable, and escaping the slash characters with shell parameter expansion. Otherwise, same as steeldriver's answer.



                                    $ comment='// characteristic_comment_to_delete'
                                    $ sed -e "/^[[:blank:]]*${comment////\/}/d" -e "s/${comment////\/}.*//" file
                                    some_code
                                    some_more_code // another_comment
                                    another_line_with_code
                                    even_more_code





                                    share|improve this answer


























                                      1












                                      1








                                      1







                                      Demonstrating storing the comment in a shell variable, and escaping the slash characters with shell parameter expansion. Otherwise, same as steeldriver's answer.



                                      $ comment='// characteristic_comment_to_delete'
                                      $ sed -e "/^[[:blank:]]*${comment////\/}/d" -e "s/${comment////\/}.*//" file
                                      some_code
                                      some_more_code // another_comment
                                      another_line_with_code
                                      even_more_code





                                      share|improve this answer













                                      Demonstrating storing the comment in a shell variable, and escaping the slash characters with shell parameter expansion. Otherwise, same as steeldriver's answer.



                                      $ comment='// characteristic_comment_to_delete'
                                      $ sed -e "/^[[:blank:]]*${comment////\/}/d" -e "s/${comment////\/}.*//" file
                                      some_code
                                      some_more_code // another_comment
                                      another_line_with_code
                                      even_more_code






                                      share|improve this answer












                                      share|improve this answer



                                      share|improve this answer










                                      answered 10 hours ago









                                      glenn jackmanglenn jackman

                                      52.1k572112




                                      52.1k572112






















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










                                          draft saved

                                          draft discarded


















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













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












                                          forteller 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.




                                          draft saved


                                          draft discarded














                                          StackExchange.ready(
                                          function () {
                                          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f503784%2fremoving-c-style-comments-with-sed%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

                                          If I really need a card on my start hand, how many mulligans make sense? [duplicate]

                                          Alcedinidae

                                          Can an atomic nucleus contain both particles and antiparticles? [duplicate]