Ero sivun ”Patch” versioiden välillä
p (Botti vaihtoi luokan Luokka:Ohjelmistokehitys) |
p (fix) |
||
Rivi 1: | Rivi 1: | ||
Patch on [[:Luokka: | Patch on [[:Luokka:Kehitystyökalut|ohjelmistokehityksessä]] käytetty työkalu, jolla voidaan päivittää tiedosto uuteen versioon jos saatavilla on uuden ja vanhan version välinen [[diff]]-tiedosto. | ||
== Käyttö == | == Käyttö == |
Versio 26. huhtikuuta 2007 kello 22.03
Patch on ohjelmistokehityksessä käytetty työkalu, jolla voidaan päivittää tiedosto uuteen versioon jos saatavilla on uuden ja vanhan version välinen diff-tiedosto.
Käyttö
Esimerkiksi diff-artikkelissa mainitussa esimerkissä meillä on seuraavanlainen hello.c-tiedosto:
#include <stdio.h> void main() { printf("Hello word"); }
Lisäksi sitä on vertailtu tiedostoon hello2.c komennolla diff -u hello.c hello2.c > hello1to2.diff ja saatu seuraavanlainen sisältö tiedostoon hello1to2.diff:
--- hello.c 2006-04-07 10:05:08.000000000 +0000 +++ hello2.c 2006-04-07 10:12:47.000000000 +0000 @@ -1,5 +1,6 @@ #include <stdio.h> -void main() { - printf("Hello word"); +int main() { + printf("Hello world"); + return 0; }
Kun nämä tiedostot nyt ovat samassa hakemistossa, voidaan hello.c patchata uuteen 2-versioon yksinkertaisesti patchilla:
patch -p0 < hello1to2.diff
Jonka jälkeen hello.c:n sisältö olisi seuraava:
#include <stdio.h> int main() { printf("Hello world"); return 0; }
Aivan kuten sen kuuluukin olla. Komennossa valitsin -p0 kertoo diffille, että patchattavat tiedostot (tai tässä tapauksessa yksi tiedosto) on samassa hakemistossa kuin patch-tiedosto. Jos patchissa viitattaisiin joissain hakemistoissa oleviin tiedostoihin, esimerkiksi tiedostoon hello/hello.c, voisimme käskeä patchia "unohtamaan" yhden hakemistoista vivulla -p1. Tämä on hyödyllinen etenkin jos hakemistojen nimet muuttuvat.
Huomaa myös, että patch ei lue patch-tiedoston sisältöä, vaan se välitetään sille syötteenä <-ohjausmerkin avulla.