Как применить патч к проекту Java? - PullRequest
10 голосов
/ 12 июня 2009

Патч для орешка 0,9: http://cvs.tty.org/~butch/blog/nutch_0.9_OR.patch

Как правильно применить патч?

ОС - это Windows XP

Точнее, я использую eclipse для отладки основного проекта.

Вот мое испытание:

D:\nutch-0.9.bak>patch -p0 < nutch_0.9_OR.patch
Hmm...  Looks like an ed script to me...
(Patch is indented 5 spaces.)
The text leading up to this was:
--------------------------
|diff -rBNu src.orig/java/org/apache/nutch/analysis/NutchAnalysisConstants.java src/java/org/apache/nutch/analysis/NutchAnalysisConstants.java
|--- src.orig/java/org/apache/nutch/analysis/NutchAnalysisConstants.java        2009-03-10 11:34:01.000000000 -0700
|+++ src/java/org/apache/nutch/analysis/NutchAnalysisConstants.java     2009-03-10 14:11:55.000000000 -0700
|@@ -4,30 +4,34 @@
| public interface NutchAnalysisConstants {
|
|   int EOF = 0;
|-  int WORD = 1;
|-  int ACRONYM = 2;
|-  int SIGRAM = 3;
|-  int IRREGULAR_WORD = 4;
|-  int C_PLUS_PLUS = 5;
|-  int C_SHARP = 6;
|-  int PLUS = 7;
|-  int MINUS = 8;
|-  int QUOTE = 9;
|-  int COLON = 10;
|-  int SLASH = 11;
|-  int DOT = 12;
|-  int ATSIGN = 13;
|-  int APOSTROPHE = 14;
|-  int WHITE = 15;
|-  int WORD_PUNCT = 16;
|-  int LETTER = 17;
|-  int CJK = 18;
|-  int DIGIT = 19;
|+  int QOR = 1;
|+  int WORD = 2;
|+  int ACRONYM = 3;
|+  int SIGRAM = 4;
|+  int IRREGULAR_WORD = 5;
|+  int C_PLUS_PLUS = 6;
|+  int C_SHARP = 7;
|+  int PLUS = 8;
|+  int MINUS = 9;
|+  int QUOTE = 10;
|+  int COLON = 11;
|+  int SLASH = 12;
|+  int LPAREN = 13;
|+  int RPAREN = 14;
|+  int DOT = 15;
|+  int ATSIGN = 16;
|+  int APOSTROPHE = 17;
|+  int WHITE = 18;
|+  int WORD_PUNCT = 19;
|+  int LETTER = 20;
|+  int CJK = 21;
|+  int DIGIT = 22;
|
|   int DEFAULT = 0;
|
|   String[] tokenImage = {
|     "<EOF>",
|+    "\"OR\"",
|     "<WORD>",
|     "<ACRONYM>",
|     "<SIGRAM>",
|@@ -39,6 +43,8 @@
|     "\"\\\"\"",
|     "\":\"",
|     "\"/\"",
|+    "\"(\"",
|+    "\")\"",
|     "\".\"",
|     "\"@\"",
|     "\"\\\'\"",
|diff -rBNu src.orig/java/org/apache/nutch/analysis/NutchAnalysis.java src/java/org/apache/nutch/analysis/NutchAnalysis.java
|--- src.orig/java/org/apache/nutch/analysis/NutchAnalysis.java 2009-03-10 11:34:01.000000000 -0700
|+++ src/java/org/apache/nutch/analysis/NutchAnalysis.java      2009-03-10 14:11:55.000000000 -0700
|@@ -56,7 +56,11 @@
|           queryString, (analyzer != null) ? analyzer : new NutchDocumentAnalyzer(conf));
|     parser.queryString = queryString;
|     parser.queryFilters = new QueryFilters(conf);
|-    return parser.parse(conf);
|+    try {
|+      return parser.parse(conf);
|+    } catch (ParseException pe) {
|+      throw new IOException("Parse exception: " + pe);
|+    }
|   }
|
|   /** For debugging. */
|@@ -77,44 +81,60 @@
|   String field;
|   boolean stop;
|   boolean prohibited;
|+  boolean required;
|     nonOpOrTerm();
|     label_1:
--------------------------
File to patch:

Ответы [ 6 ]

18 голосов
/ 12 июня 2009

Поскольку вы упомянули Eclipse - щелкните правой кнопкой мыши проект, перейдите в Team -> Apply patch.

5 голосов
/ 12 июня 2009

Вы должны использовать правый клик по проекту, патч Team / Apply.

Третий шаг мастера (обзорный патч) содержит раздел Patch Content, в котором перечислены измененные исходные файлы.

1 голос
/ 12 июня 2009

Я предполагаю следующее:

  • UnxUtils установлен в C: \ unxutils
  • "C: \ unxutils \ bin" и " C: \ unxutils \ usr \ local \ wbin " включены в переменную PATH.
  • Файлы Nutch в C: \ nutch-0.9
  • nutch_0.9_OR.patch преобразован в разделители строк Windows, в противном случае вы получите ошибку, подобную этой "Утверждение не удалось: блок, файл patch.c, строка 321"
  • nutch_0.9_OR.patch скопировано в C: \ nutch-0.9

Затем откройте командную строку CD C: \ NUTCH-0,9 patch.exe -p0 -u -i nutch_0.9_OR.patch

Готово!

0 голосов
/ 12 июня 2009

Один: сделайте резервную копию вашего кода.

Два: Вы сделали резервную копию своего кода, не так ли? 8 -)

Три:

cd \path\to\nutch
patch -p0 < nutch_0.9_OR.patch
0 голосов
/ 12 июня 2009

У вас есть Cygwin ? Установка этого файла даст вам patch.exe, который вы можете использовать вместе с вышеизложенным (и множество других очень полезных вещей).

Вы можете применить патч используя:

patch originalfile -i patchfile.patch -o updatedfile 
0 голосов
/ 12 июня 2009
  1. Вам нужен оригинальный источник (по данной версии!)
  2. Вам понадобится patch Unix-утилита (у меня есть копия для Windows, поставляемая с моим драгоценным UnxUtils, Google это имя, чтобы найти проект SourceForge) Ну, просто сделал это, чтобы убедиться, что имя верно: UnxUtils
  3. Вы применяете патч, он изменит источники
  4. Вы компилируете проект.
...