GNU/Linux >> Znalost Linux >  >> Linux

Linux – jak vytvořit záplatu ignorující rozdíly v odsazení v kódu?

Snažím se vytvořit záplatu souboru pomocí nástroje diff. Ale čelím problémům. Způsob, jakým to dělám, je níže.

Vytvořil jsem jeden adresář s názvem a a vložil jsem do něj původní soubor.

a/original_file.c

Nyní jsem vytvořil další adresář s názvem b a vložil jsem do něj stejný soubor s upraveným obsahem.

b/original_file.c

Nyní obsah b/original_file.c soubor jsem zkopíroval z internetu a vložil do nějakého textového editoru.

Po zadání příkazu:diff -Naur a b > patch_file.patch , soubor patch_file.patch je generován a má nějaké nežádoucí změny (souvisí s odsazením).

Například:

return mg_nw (MG_READY_NOY, &rmsg, seqnr,
-                 sizeof (struct mg_rdy_notify));
+                  sizeof (struct mg_rdy_notify)); 

Nyní můžete vidět, že došlo ke změně související s odsazením, kde sizeof (struct mg_rdy_notify)) je nahrazena stejnou sizeof (struct mg_rdy_notify)) ale jeden základ odsazení, což je to, co nechceme.

Přijatá odpověď:

diff má více než jednu možnost související s mezerami. Jeden je však méně užitečný pro záplaty. Manuálová stránka poskytuje nejasnou nápovědu, která se týká obou GNU:

   -B, --ignore-blank-lines
          ignore changes where lines are all blank
   -b, --ignore-space-change
          ignore changes in the amount of white space
   -w, --ignore-all-space
          ignore all white space

a FreeBSD

   -b     Ignore changes in amount of white space.
   -B     Ignore changes that just insert or delete blank lines.
   -w     Ignore white space when comparing lines.

Obvykle se používá -b , protože je méně pravděpodobné, že přehlédnete významné změny. Pokud jste změnili pouze odsazení, pak obě -b a -w dát stejný výsledek. Na druhou stranu, pokud jste vložili mezery tam, kde žádné nebyly, nebo smazali existující mezery (nenechali žádné), může to být změna ve vašem programu. Zde je příklad:

$ diff foo.c foo2.c
4c4
<     setlocale(LC_ALL, "");
---
>     setlocale(LC_ALL, " ");
6,7c6,7
<     printw("U0001F0A1");
<     getch();
---
>     printw ("U0001F0A1");
>     getch();  /* comment */
$ diff -b foo.c foo2.c
4c4
<     setlocale(LC_ALL, "");
---
>     setlocale(LC_ALL, " ");
6,7c6,7
<     printw("U0001F0A1");
<     getch();
---
>     printw ("U0001F0A1");
>     getch();  /* comment */
$ diff -w foo.c foo2.c
7c7
<     getch();
---
>     getch();  /* comment */

V tomto případě -w volba umožňuje ignorovat změnu setlocale parametr (možná ne to, co bylo zamýšleno).

POSIX diff, mimochodem, má pouze -b možnost.

Pro patch , POSIX dokumentuje -l možnost:

-l
(písmeno ell .) Způsobí libovolnou sekvenci <blank> znaky v rozdílovém skriptu, aby odpovídaly jakékoli sekvenci <blank> znaků ve vstupním souboru. Ostatní znaky se musí přesně shodovat.


Linux
  1. Jak vytvořit swap v Linuxu

  2. Jak vytvořit odkládací soubor v Linuxu

  3. Jak rozebrat binární spustitelný soubor v Linuxu, abyste získali kód sestavení?

  1. Jak používat Linuxový příkaz grep

  2. Jak používat příkaz historie v Linuxu

  3. Jak se Linux dostal k sálovému počítači

  1. Jak vytvořit alias a používat příkaz Alias ​​v Linuxu

  2. Jak vytvořit balíček RPM pro Linux

  3. Jak vytvořit službu Systemd v Linuxu