Jak przenieść powtarzające się części i wiersze kodu C ++ za pomocą awk lub sed?

Nov 25 2020

Mam ogromny fragment kodu w C ++ z tysiącami wierszy w ten sposób:

   case 14: //OrderSelect
      Execute_OrderSelect();
   break;
   case 15: // OrderGetDouble
      Execute_OrderGetDouble();
   break;
   case 16:   //OrderGetInteger
      Execute_OrderGetInteger();
   break;

Moim zadaniem jest nadanie im takiego wyglądu:

   case 14: Execute_OrderSelect();     break;   // OrderSelect
   case 15: Execute_OrderGetDouble();  break;   // OrderGetDouble
   case 16: Execute_OrderGetInteger(); break;   // OrderGetInteger

Zauważ, że zarówno Execute ..., jak i komentarze mogą być dowolnym ciągiem.


Przypuszczam, że schematycznie moglibyśmy napisać oryginał w ten sposób:

AAA NN BBB
CCC
DDD

i starają się przekształcić go w: AAA NN CCC DDD BBB.

Próbowałem bezskutecznie z różnymi rodzajami sedwyrażeń i najlepsze, co mogłem zrobić, to trywialna operacja łączenia wyrażeń Execute...()z break;, ale nie byłem w stanie poruszyć komentarza. Myślę, że używam do tego niewłaściwego narzędzia i być może awkbyłaby lepsza opcja lub prostsza w użyciu?

Oto kilka awkzmiennych:

FNR    The input record number in the current input file.
FS     The input field separator, a space by default.
NF     The number of fields in the current input record.
NR     The total number of input records seen so far.
OFMT   The output format for numbers, "%.6g", by default.
OFS    The output field separator, a space by default.
ORS    The output record separator, by default a newline.
RS     The input record separator, by default a newline.
RT     The  record terminator. Gawk sets RT to the input 
       text that matched the character or regular expression 
       specified by RS.
RSTART The index of the first character matched by match(); 0 if no match

Jak mogę rozjaśnić swój dzień?


Powiązane pytania:

  • AWK lub sed sposób wklejania nie sąsiadujących linii
  • zmień pozycję linii w pliku za pomocą seda
  • Jak zaznaczyć linie między dwoma wzorami znaczników, które mogą wystąpić wielokrotnie w awk / sed

Odpowiedzi

2 EdMorton Nov 25 2020 at 05:34

Oto kości, masaż na miarę;

$ cat tst.awk /^[[:space:]]*case[[:space:]]/ { comment = "" if ( match($0,"//") ) {
        comment = substr($0,RSTART) $0 = substr($0,1,RSTART-1) } caseLineNr = 1 } caseLineNr { if ( caseLineNr++ > 1 ) { sub(/^[[:space:]]+/,"") } sub(/[[:space:]]+$/,"")
    printf "%s\t", $0

    if ( /^break[[:space:]]*;/ ) {
        print comment
        caseLineNr = 0
    }
}

$ awk -f tst.awk file
   case 14:     Execute_OrderSelect();  break;  //OrderSelect
   case 15:     Execute_OrderGetDouble();       break;  // OrderGetDouble
   case 16:     Execute_OrderGetInteger();      break;  //OrderGetInteger