"P - print the current hunk using the pager\n"
"? - print help\n");
+static void apply_patch(struct add_p_state *s, struct file_diff *file_diff)
+{
+ struct child_process cp = CHILD_PROCESS_INIT;
+ size_t j;
+
+ /* Any hunk to be used? */
+ for (j = 0; j < file_diff->hunk_nr; j++)
+ if (file_diff->hunk[j].use == USE_HUNK)
+ break;
+
+ if (j < file_diff->hunk_nr ||
+ (!file_diff->hunk_nr && file_diff->head.use == USE_HUNK)) {
+ /* At least one hunk selected: apply */
+ strbuf_reset(&s->buf);
+ reassemble_patch(s, file_diff, 0, &s->buf);
+
+ discard_index(s->s.r->index);
+ if (s->mode->apply_for_checkout)
+ apply_for_checkout(s, &s->buf,
+ s->mode->is_reverse);
+ else {
+ setup_child_process(s, &cp, "apply", NULL);
+ strvec_pushv(&cp.args, s->mode->apply_args);
+ if (pipe_command(&cp, s->buf.buf, s->buf.len,
+ NULL, 0, NULL, 0))
+ error(_("'git apply' failed"));
+ }
+ if (repo_read_index(s->s.r) >= 0)
+ repo_refresh_and_write_index(s->s.r, REFRESH_QUIET, 0,
+ 1, NULL, NULL, NULL);
+ }
+
+}
+
static size_t dec_mod(size_t a, size_t m)
{
return a > 0 ? a - 1 : m - 1;
ssize_t i, undecided_previous, undecided_next, rendered_hunk_index = -1;
struct hunk *hunk;
char ch;
- struct child_process cp = CHILD_PROCESS_INIT;
int colored = !!s->colored.len, use_pager = 0;
enum prompt_mode_type prompt_mode_type;
struct file_diff *file_diff = s->file_diff + idx;
}
}
- /* Any hunk to be used? */
- for (i = 0; i < file_diff->hunk_nr; i++)
- if (file_diff->hunk[i].use == USE_HUNK)
- break;
-
- if (i < file_diff->hunk_nr ||
- (!file_diff->hunk_nr && file_diff->head.use == USE_HUNK)) {
- /* At least one hunk selected: apply */
- strbuf_reset(&s->buf);
- reassemble_patch(s, file_diff, 0, &s->buf);
-
- discard_index(s->s.r->index);
- if (s->mode->apply_for_checkout)
- apply_for_checkout(s, &s->buf,
- s->mode->is_reverse);
- else {
- setup_child_process(s, &cp, "apply", NULL);
- strvec_pushv(&cp.args, s->mode->apply_args);
- if (pipe_command(&cp, s->buf.buf, s->buf.len,
- NULL, 0, NULL, 0))
- error(_("'git apply' failed"));
- }
- if (repo_read_index(s->s.r) >= 0)
- repo_refresh_and_write_index(s->s.r, REFRESH_QUIET, 0,
- 1, NULL, NULL, NULL);
- }
+ apply_patch(s, file_diff);
putchar('\n');
return patch_update_resp;