builtin-fetch-pack.con commit sha1_file: don't malloc the whole compressed result when writing out objects (9892beb)
   1#include "cache.h"
   2#include "refs.h"
   3#include "pkt-line.h"
   4#include "commit.h"
   5#include "tag.h"
   6#include "exec_cmd.h"
   7#include "pack.h"
   8#include "sideband.h"
   9#include "fetch-pack.h"
  10#include "remote.h"
  11#include "run-command.h"
  12
  13static int transfer_unpack_limit = -1;
  14static int fetch_unpack_limit = -1;
  15static int unpack_limit = 100;
  16static int prefer_ofs_delta = 1;
  17static struct fetch_pack_args args = {
  18        /* .uploadpack = */ "git-upload-pack",
  19};
  20
  21static const char fetch_pack_usage[] =
  22"git fetch-pack [--all] [--quiet|-q] [--keep|-k] [--thin] [--include-tag] [--upload-pack=<git-upload-pack>] [--depth=<n>] [--no-progress] [-v] [<host>:]<directory> [<refs>...]";
  23
  24#define COMPLETE        (1U << 0)
  25#define COMMON          (1U << 1)
  26#define COMMON_REF      (1U << 2)
  27#define SEEN            (1U << 3)
  28#define POPPED          (1U << 4)
  29
  30static int marked;
  31
  32/*
  33 * After sending this many "have"s if we do not get any new ACK , we
  34 * give up traversing our history.
  35 */
  36#define MAX_IN_VAIN 256
  37
  38static struct commit_list *rev_list;
  39static int non_common_revs, multi_ack, use_sideband;
  40
  41static void rev_list_push(struct commit *commit, int mark)
  42{
  43        if (!(commit->object.flags & mark)) {
  44                commit->object.flags |= mark;
  45
  46                if (!(commit->object.parsed))
  47                        if (parse_commit(commit))
  48                                return;
  49
  50                insert_by_date(commit, &rev_list);
  51
  52                if (!(commit->object.flags & COMMON))
  53                        non_common_revs++;
  54        }
  55}
  56
  57static int rev_list_insert_ref(const char *path, const unsigned char *sha1, int flag, void *cb_data)
  58{
  59        struct object *o = deref_tag(parse_object(sha1), path, 0);
  60
  61        if (o && o->type == OBJ_COMMIT)
  62                rev_list_push((struct commit *)o, SEEN);
  63
  64        return 0;
  65}
  66
  67static int clear_marks(const char *path, const unsigned char *sha1, int flag, void *cb_data)
  68{
  69        struct object *o = deref_tag(parse_object(sha1), path, 0);
  70
  71        if (o && o->type == OBJ_COMMIT)
  72                clear_commit_marks((struct commit *)o,
  73                                   COMMON | COMMON_REF | SEEN | POPPED);
  74        return 0;
  75}
  76
  77/*
  78   This function marks a rev and its ancestors as common.
  79   In some cases, it is desirable to mark only the ancestors (for example
  80   when only the server does not yet know that they are common).
  81*/
  82
  83static void mark_common(struct commit *commit,
  84                int ancestors_only, int dont_parse)
  85{
  86        if (commit != NULL && !(commit->object.flags & COMMON)) {
  87                struct object *o = (struct object *)commit;
  88
  89                if (!ancestors_only)
  90                        o->flags |= COMMON;
  91
  92                if (!(o->flags & SEEN))
  93                        rev_list_push(commit, SEEN);
  94                else {
  95                        struct commit_list *parents;
  96
  97                        if (!ancestors_only && !(o->flags & POPPED))
  98                                non_common_revs--;
  99                        if (!o->parsed && !dont_parse)
 100                                if (parse_commit(commit))
 101                                        return;
 102
 103                        for (parents = commit->parents;
 104                                        parents;
 105                                        parents = parents->next)
 106                                mark_common(parents->item, 0, dont_parse);
 107                }
 108        }
 109}
 110
 111/*
 112  Get the next rev to send, ignoring the common.
 113*/
 114
 115static const unsigned char *get_rev(void)
 116{
 117        struct commit *commit = NULL;
 118
 119        while (commit == NULL) {
 120                unsigned int mark;
 121                struct commit_list *parents;
 122
 123                if (rev_list == NULL || non_common_revs == 0)
 124                        return NULL;
 125
 126                commit = rev_list->item;
 127                if (!commit->object.parsed)
 128                        parse_commit(commit);
 129                parents = commit->parents;
 130
 131                commit->object.flags |= POPPED;
 132                if (!(commit->object.flags & COMMON))
 133                        non_common_revs--;
 134
 135                if (commit->object.flags & COMMON) {
 136                        /* do not send "have", and ignore ancestors */
 137                        commit = NULL;
 138                        mark = COMMON | SEEN;
 139                } else if (commit->object.flags & COMMON_REF)
 140                        /* send "have", and ignore ancestors */
 141                        mark = COMMON | SEEN;
 142                else
 143                        /* send "have", also for its ancestors */
 144                        mark = SEEN;
 145
 146                while (parents) {
 147                        if (!(parents->item->object.flags & SEEN))
 148                                rev_list_push(parents->item, mark);
 149                        if (mark & COMMON)
 150                                mark_common(parents->item, 1, 0);
 151                        parents = parents->next;
 152                }
 153
 154                rev_list = rev_list->next;
 155        }
 156
 157        return commit->object.sha1;
 158}
 159
 160enum ack_type {
 161        NAK = 0,
 162        ACK,
 163        ACK_continue,
 164        ACK_common,
 165        ACK_ready
 166};
 167
 168static void consume_shallow_list(int fd)
 169{
 170        if (args.stateless_rpc && args.depth > 0) {
 171                /* If we sent a depth we will get back "duplicate"
 172                 * shallow and unshallow commands every time there
 173                 * is a block of have lines exchanged.
 174                 */
 175                char line[1000];
 176                while (packet_read_line(fd, line, sizeof(line))) {
 177                        if (!prefixcmp(line, "shallow "))
 178                                continue;
 179                        if (!prefixcmp(line, "unshallow "))
 180                                continue;
 181                        die("git fetch-pack: expected shallow list");
 182                }
 183        }
 184}
 185
 186static enum ack_type get_ack(int fd, unsigned char *result_sha1)
 187{
 188        static char line[1000];
 189        int len = packet_read_line(fd, line, sizeof(line));
 190
 191        if (!len)
 192                die("git fetch-pack: expected ACK/NAK, got EOF");
 193        if (line[len-1] == '\n')
 194                line[--len] = 0;
 195        if (!strcmp(line, "NAK"))
 196                return NAK;
 197        if (!prefixcmp(line, "ACK ")) {
 198                if (!get_sha1_hex(line+4, result_sha1)) {
 199                        if (strstr(line+45, "continue"))
 200                                return ACK_continue;
 201                        if (strstr(line+45, "common"))
 202                                return ACK_common;
 203                        if (strstr(line+45, "ready"))
 204                                return ACK_ready;
 205                        return ACK;
 206                }
 207        }
 208        die("git fetch_pack: expected ACK/NAK, got '%s'", line);
 209}
 210
 211static void send_request(int fd, struct strbuf *buf)
 212{
 213        if (args.stateless_rpc) {
 214                send_sideband(fd, -1, buf->buf, buf->len, LARGE_PACKET_MAX);
 215                packet_flush(fd);
 216        } else
 217                safe_write(fd, buf->buf, buf->len);
 218}
 219
 220static int find_common(int fd[2], unsigned char *result_sha1,
 221                       struct ref *refs)
 222{
 223        int fetching;
 224        int count = 0, flushes = 0, retval;
 225        const unsigned char *sha1;
 226        unsigned in_vain = 0;
 227        int got_continue = 0;
 228        struct strbuf req_buf = STRBUF_INIT;
 229        size_t state_len = 0;
 230
 231        if (args.stateless_rpc && multi_ack == 1)
 232                die("--stateless-rpc requires multi_ack_detailed");
 233        if (marked)
 234                for_each_ref(clear_marks, NULL);
 235        marked = 1;
 236
 237        for_each_ref(rev_list_insert_ref, NULL);
 238
 239        fetching = 0;
 240        for ( ; refs ; refs = refs->next) {
 241                unsigned char *remote = refs->old_sha1;
 242                const char *remote_hex;
 243                struct object *o;
 244
 245                /*
 246                 * If that object is complete (i.e. it is an ancestor of a
 247                 * local ref), we tell them we have it but do not have to
 248                 * tell them about its ancestors, which they already know
 249                 * about.
 250                 *
 251                 * We use lookup_object here because we are only
 252                 * interested in the case we *know* the object is
 253                 * reachable and we have already scanned it.
 254                 */
 255                if (((o = lookup_object(remote)) != NULL) &&
 256                                (o->flags & COMPLETE)) {
 257                        continue;
 258                }
 259
 260                remote_hex = sha1_to_hex(remote);
 261                if (!fetching) {
 262                        struct strbuf c = STRBUF_INIT;
 263                        if (multi_ack == 2)     strbuf_addstr(&c, " multi_ack_detailed");
 264                        if (multi_ack == 1)     strbuf_addstr(&c, " multi_ack");
 265                        if (use_sideband == 2)  strbuf_addstr(&c, " side-band-64k");
 266                        if (use_sideband == 1)  strbuf_addstr(&c, " side-band");
 267                        if (args.use_thin_pack) strbuf_addstr(&c, " thin-pack");
 268                        if (args.no_progress)   strbuf_addstr(&c, " no-progress");
 269                        if (args.include_tag)   strbuf_addstr(&c, " include-tag");
 270                        if (prefer_ofs_delta)   strbuf_addstr(&c, " ofs-delta");
 271                        packet_buf_write(&req_buf, "want %s%s\n", remote_hex, c.buf);
 272                        strbuf_release(&c);
 273                } else
 274                        packet_buf_write(&req_buf, "want %s\n", remote_hex);
 275                fetching++;
 276        }
 277
 278        if (!fetching) {
 279                strbuf_release(&req_buf);
 280                packet_flush(fd[1]);
 281                return 1;
 282        }
 283
 284        if (is_repository_shallow())
 285                write_shallow_commits(&req_buf, 1);
 286        if (args.depth > 0)
 287                packet_buf_write(&req_buf, "deepen %d", args.depth);
 288        packet_buf_flush(&req_buf);
 289        state_len = req_buf.len;
 290
 291        if (args.depth > 0) {
 292                char line[1024];
 293                unsigned char sha1[20];
 294
 295                send_request(fd[1], &req_buf);
 296                while (packet_read_line(fd[0], line, sizeof(line))) {
 297                        if (!prefixcmp(line, "shallow ")) {
 298                                if (get_sha1_hex(line + 8, sha1))
 299                                        die("invalid shallow line: %s", line);
 300                                register_shallow(sha1);
 301                                continue;
 302                        }
 303                        if (!prefixcmp(line, "unshallow ")) {
 304                                if (get_sha1_hex(line + 10, sha1))
 305                                        die("invalid unshallow line: %s", line);
 306                                if (!lookup_object(sha1))
 307                                        die("object not found: %s", line);
 308                                /* make sure that it is parsed as shallow */
 309                                if (!parse_object(sha1))
 310                                        die("error in object: %s", line);
 311                                if (unregister_shallow(sha1))
 312                                        die("no shallow found: %s", line);
 313                                continue;
 314                        }
 315                        die("expected shallow/unshallow, got %s", line);
 316                }
 317        } else if (!args.stateless_rpc)
 318                send_request(fd[1], &req_buf);
 319
 320        if (!args.stateless_rpc) {
 321                /* If we aren't using the stateless-rpc interface
 322                 * we don't need to retain the headers.
 323                 */
 324                strbuf_setlen(&req_buf, 0);
 325                state_len = 0;
 326        }
 327
 328        flushes = 0;
 329        retval = -1;
 330        while ((sha1 = get_rev())) {
 331                packet_buf_write(&req_buf, "have %s\n", sha1_to_hex(sha1));
 332                if (args.verbose)
 333                        fprintf(stderr, "have %s\n", sha1_to_hex(sha1));
 334                in_vain++;
 335                if (!(31 & ++count)) {
 336                        int ack;
 337
 338                        packet_buf_flush(&req_buf);
 339                        send_request(fd[1], &req_buf);
 340                        strbuf_setlen(&req_buf, state_len);
 341                        flushes++;
 342
 343                        /*
 344                         * We keep one window "ahead" of the other side, and
 345                         * will wait for an ACK only on the next one
 346                         */
 347                        if (!args.stateless_rpc && count == 32)
 348                                continue;
 349
 350                        consume_shallow_list(fd[0]);
 351                        do {
 352                                ack = get_ack(fd[0], result_sha1);
 353                                if (args.verbose && ack)
 354                                        fprintf(stderr, "got ack %d %s\n", ack,
 355                                                        sha1_to_hex(result_sha1));
 356                                switch (ack) {
 357                                case ACK:
 358                                        flushes = 0;
 359                                        multi_ack = 0;
 360                                        retval = 0;
 361                                        goto done;
 362                                case ACK_common:
 363                                case ACK_ready:
 364                                case ACK_continue: {
 365                                        struct commit *commit =
 366                                                lookup_commit(result_sha1);
 367                                        if (args.stateless_rpc
 368                                         && ack == ACK_common
 369                                         && !(commit->object.flags & COMMON)) {
 370                                                /* We need to replay the have for this object
 371                                                 * on the next RPC request so the peer knows
 372                                                 * it is in common with us.
 373                                                 */
 374                                                const char *hex = sha1_to_hex(result_sha1);
 375                                                packet_buf_write(&req_buf, "have %s\n", hex);
 376                                                state_len = req_buf.len;
 377                                        }
 378                                        mark_common(commit, 0, 1);
 379                                        retval = 0;
 380                                        in_vain = 0;
 381                                        got_continue = 1;
 382                                        break;
 383                                        }
 384                                }
 385                        } while (ack);
 386                        flushes--;
 387                        if (got_continue && MAX_IN_VAIN < in_vain) {
 388                                if (args.verbose)
 389                                        fprintf(stderr, "giving up\n");
 390                                break; /* give up */
 391                        }
 392                }
 393        }
 394done:
 395        packet_buf_write(&req_buf, "done\n");
 396        send_request(fd[1], &req_buf);
 397        if (args.verbose)
 398                fprintf(stderr, "done\n");
 399        if (retval != 0) {
 400                multi_ack = 0;
 401                flushes++;
 402        }
 403        strbuf_release(&req_buf);
 404
 405        consume_shallow_list(fd[0]);
 406        while (flushes || multi_ack) {
 407                int ack = get_ack(fd[0], result_sha1);
 408                if (ack) {
 409                        if (args.verbose)
 410                                fprintf(stderr, "got ack (%d) %s\n", ack,
 411                                        sha1_to_hex(result_sha1));
 412                        if (ack == ACK)
 413                                return 0;
 414                        multi_ack = 1;
 415                        continue;
 416                }
 417                flushes--;
 418        }
 419        /* it is no error to fetch into a completely empty repo */
 420        return count ? retval : 0;
 421}
 422
 423static struct commit_list *complete;
 424
 425static int mark_complete(const char *path, const unsigned char *sha1, int flag, void *cb_data)
 426{
 427        struct object *o = parse_object(sha1);
 428
 429        while (o && o->type == OBJ_TAG) {
 430                struct tag *t = (struct tag *) o;
 431                if (!t->tagged)
 432                        break; /* broken repository */
 433                o->flags |= COMPLETE;
 434                o = parse_object(t->tagged->sha1);
 435        }
 436        if (o && o->type == OBJ_COMMIT) {
 437                struct commit *commit = (struct commit *)o;
 438                commit->object.flags |= COMPLETE;
 439                insert_by_date(commit, &complete);
 440        }
 441        return 0;
 442}
 443
 444static void mark_recent_complete_commits(unsigned long cutoff)
 445{
 446        while (complete && cutoff <= complete->item->date) {
 447                if (args.verbose)
 448                        fprintf(stderr, "Marking %s as complete\n",
 449                                sha1_to_hex(complete->item->object.sha1));
 450                pop_most_recent_commit(&complete, COMPLETE);
 451        }
 452}
 453
 454static void filter_refs(struct ref **refs, int nr_match, char **match)
 455{
 456        struct ref **return_refs;
 457        struct ref *newlist = NULL;
 458        struct ref **newtail = &newlist;
 459        struct ref *ref, *next;
 460        struct ref *fastarray[32];
 461
 462        if (nr_match && !args.fetch_all) {
 463                if (ARRAY_SIZE(fastarray) < nr_match)
 464                        return_refs = xcalloc(nr_match, sizeof(struct ref *));
 465                else {
 466                        return_refs = fastarray;
 467                        memset(return_refs, 0, sizeof(struct ref *) * nr_match);
 468                }
 469        }
 470        else
 471                return_refs = NULL;
 472
 473        for (ref = *refs; ref; ref = next) {
 474                next = ref->next;
 475                if (!memcmp(ref->name, "refs/", 5) &&
 476                    check_ref_format(ref->name + 5))
 477                        ; /* trash */
 478                else if (args.fetch_all &&
 479                         (!args.depth || prefixcmp(ref->name, "refs/tags/") )) {
 480                        *newtail = ref;
 481                        ref->next = NULL;
 482                        newtail = &ref->next;
 483                        continue;
 484                }
 485                else {
 486                        int order = path_match(ref->name, nr_match, match);
 487                        if (order) {
 488                                return_refs[order-1] = ref;
 489                                continue; /* we will link it later */
 490                        }
 491                }
 492                free(ref);
 493        }
 494
 495        if (!args.fetch_all) {
 496                int i;
 497                for (i = 0; i < nr_match; i++) {
 498                        ref = return_refs[i];
 499                        if (ref) {
 500                                *newtail = ref;
 501                                ref->next = NULL;
 502                                newtail = &ref->next;
 503                        }
 504                }
 505                if (return_refs != fastarray)
 506                        free(return_refs);
 507        }
 508        *refs = newlist;
 509}
 510
 511static int everything_local(struct ref **refs, int nr_match, char **match)
 512{
 513        struct ref *ref;
 514        int retval;
 515        unsigned long cutoff = 0;
 516
 517        save_commit_buffer = 0;
 518
 519        for (ref = *refs; ref; ref = ref->next) {
 520                struct object *o;
 521
 522                o = parse_object(ref->old_sha1);
 523                if (!o)
 524                        continue;
 525
 526                /* We already have it -- which may mean that we were
 527                 * in sync with the other side at some time after
 528                 * that (it is OK if we guess wrong here).
 529                 */
 530                if (o->type == OBJ_COMMIT) {
 531                        struct commit *commit = (struct commit *)o;
 532                        if (!cutoff || cutoff < commit->date)
 533                                cutoff = commit->date;
 534                }
 535        }
 536
 537        if (!args.depth) {
 538                for_each_ref(mark_complete, NULL);
 539                if (cutoff)
 540                        mark_recent_complete_commits(cutoff);
 541        }
 542
 543        /*
 544         * Mark all complete remote refs as common refs.
 545         * Don't mark them common yet; the server has to be told so first.
 546         */
 547        for (ref = *refs; ref; ref = ref->next) {
 548                struct object *o = deref_tag(lookup_object(ref->old_sha1),
 549                                             NULL, 0);
 550
 551                if (!o || o->type != OBJ_COMMIT || !(o->flags & COMPLETE))
 552                        continue;
 553
 554                if (!(o->flags & SEEN)) {
 555                        rev_list_push((struct commit *)o, COMMON_REF | SEEN);
 556
 557                        mark_common((struct commit *)o, 1, 1);
 558                }
 559        }
 560
 561        filter_refs(refs, nr_match, match);
 562
 563        for (retval = 1, ref = *refs; ref ; ref = ref->next) {
 564                const unsigned char *remote = ref->old_sha1;
 565                unsigned char local[20];
 566                struct object *o;
 567
 568                o = lookup_object(remote);
 569                if (!o || !(o->flags & COMPLETE)) {
 570                        retval = 0;
 571                        if (!args.verbose)
 572                                continue;
 573                        fprintf(stderr,
 574                                "want %s (%s)\n", sha1_to_hex(remote),
 575                                ref->name);
 576                        continue;
 577                }
 578
 579                hashcpy(ref->new_sha1, local);
 580                if (!args.verbose)
 581                        continue;
 582                fprintf(stderr,
 583                        "already have %s (%s)\n", sha1_to_hex(remote),
 584                        ref->name);
 585        }
 586        return retval;
 587}
 588
 589static int sideband_demux(int fd, void *data)
 590{
 591        int *xd = data;
 592
 593        int ret = recv_sideband("fetch-pack", xd[0], fd);
 594        close(fd);
 595        return ret;
 596}
 597
 598static int get_pack(int xd[2], char **pack_lockfile)
 599{
 600        struct async demux;
 601        const char *argv[20];
 602        char keep_arg[256];
 603        char hdr_arg[256];
 604        const char **av;
 605        int do_keep = args.keep_pack;
 606        struct child_process cmd;
 607
 608        memset(&demux, 0, sizeof(demux));
 609        if (use_sideband) {
 610                /* xd[] is talking with upload-pack; subprocess reads from
 611                 * xd[0], spits out band#2 to stderr, and feeds us band#1
 612                 * through demux->out.
 613                 */
 614                demux.proc = sideband_demux;
 615                demux.data = xd;
 616                if (start_async(&demux))
 617                        die("fetch-pack: unable to fork off sideband"
 618                            " demultiplexer");
 619        }
 620        else
 621                demux.out = xd[0];
 622
 623        memset(&cmd, 0, sizeof(cmd));
 624        cmd.argv = argv;
 625        av = argv;
 626        *hdr_arg = 0;
 627        if (!args.keep_pack && unpack_limit) {
 628                struct pack_header header;
 629
 630                if (read_pack_header(demux.out, &header))
 631                        die("protocol error: bad pack header");
 632                snprintf(hdr_arg, sizeof(hdr_arg),
 633                         "--pack_header=%"PRIu32",%"PRIu32,
 634                         ntohl(header.hdr_version), ntohl(header.hdr_entries));
 635                if (ntohl(header.hdr_entries) < unpack_limit)
 636                        do_keep = 0;
 637                else
 638                        do_keep = 1;
 639        }
 640
 641        if (do_keep) {
 642                if (pack_lockfile)
 643                        cmd.out = -1;
 644                *av++ = "index-pack";
 645                *av++ = "--stdin";
 646                if (!args.quiet && !args.no_progress)
 647                        *av++ = "-v";
 648                if (args.use_thin_pack)
 649                        *av++ = "--fix-thin";
 650                if (args.lock_pack || unpack_limit) {
 651                        int s = sprintf(keep_arg,
 652                                        "--keep=fetch-pack %"PRIuMAX " on ", (uintmax_t) getpid());
 653                        if (gethostname(keep_arg + s, sizeof(keep_arg) - s))
 654                                strcpy(keep_arg + s, "localhost");
 655                        *av++ = keep_arg;
 656                }
 657        }
 658        else {
 659                *av++ = "unpack-objects";
 660                if (args.quiet)
 661                        *av++ = "-q";
 662        }
 663        if (*hdr_arg)
 664                *av++ = hdr_arg;
 665        *av++ = NULL;
 666
 667        cmd.in = demux.out;
 668        cmd.git_cmd = 1;
 669        if (start_command(&cmd))
 670                die("fetch-pack: unable to fork off %s", argv[0]);
 671        if (do_keep && pack_lockfile) {
 672                *pack_lockfile = index_pack_lockfile(cmd.out);
 673                close(cmd.out);
 674        }
 675
 676        if (finish_command(&cmd))
 677                die("%s failed", argv[0]);
 678        if (use_sideband && finish_async(&demux))
 679                die("error in sideband demultiplexer");
 680        return 0;
 681}
 682
 683static struct ref *do_fetch_pack(int fd[2],
 684                const struct ref *orig_ref,
 685                int nr_match,
 686                char **match,
 687                char **pack_lockfile)
 688{
 689        struct ref *ref = copy_ref_list(orig_ref);
 690        unsigned char sha1[20];
 691
 692        if (is_repository_shallow() && !server_supports("shallow"))
 693                die("Server does not support shallow clients");
 694        if (server_supports("multi_ack_detailed")) {
 695                if (args.verbose)
 696                        fprintf(stderr, "Server supports multi_ack_detailed\n");
 697                multi_ack = 2;
 698        }
 699        else if (server_supports("multi_ack")) {
 700                if (args.verbose)
 701                        fprintf(stderr, "Server supports multi_ack\n");
 702                multi_ack = 1;
 703        }
 704        if (server_supports("side-band-64k")) {
 705                if (args.verbose)
 706                        fprintf(stderr, "Server supports side-band-64k\n");
 707                use_sideband = 2;
 708        }
 709        else if (server_supports("side-band")) {
 710                if (args.verbose)
 711                        fprintf(stderr, "Server supports side-band\n");
 712                use_sideband = 1;
 713        }
 714        if (server_supports("ofs-delta")) {
 715                if (args.verbose)
 716                        fprintf(stderr, "Server supports ofs-delta\n");
 717        } else
 718                prefer_ofs_delta = 0;
 719        if (everything_local(&ref, nr_match, match)) {
 720                packet_flush(fd[1]);
 721                goto all_done;
 722        }
 723        if (find_common(fd, sha1, ref) < 0)
 724                if (!args.keep_pack)
 725                        /* When cloning, it is not unusual to have
 726                         * no common commit.
 727                         */
 728                        warning("no common commits");
 729
 730        if (args.stateless_rpc)
 731                packet_flush(fd[1]);
 732        if (get_pack(fd, pack_lockfile))
 733                die("git fetch-pack: fetch failed.");
 734
 735 all_done:
 736        return ref;
 737}
 738
 739static int remove_duplicates(int nr_heads, char **heads)
 740{
 741        int src, dst;
 742
 743        for (src = dst = 0; src < nr_heads; src++) {
 744                /* If heads[src] is different from any of
 745                 * heads[0..dst], push it in.
 746                 */
 747                int i;
 748                for (i = 0; i < dst; i++) {
 749                        if (!strcmp(heads[i], heads[src]))
 750                                break;
 751                }
 752                if (i < dst)
 753                        continue;
 754                if (src != dst)
 755                        heads[dst] = heads[src];
 756                dst++;
 757        }
 758        return dst;
 759}
 760
 761static int fetch_pack_config(const char *var, const char *value, void *cb)
 762{
 763        if (strcmp(var, "fetch.unpacklimit") == 0) {
 764                fetch_unpack_limit = git_config_int(var, value);
 765                return 0;
 766        }
 767
 768        if (strcmp(var, "transfer.unpacklimit") == 0) {
 769                transfer_unpack_limit = git_config_int(var, value);
 770                return 0;
 771        }
 772
 773        if (strcmp(var, "repack.usedeltabaseoffset") == 0) {
 774                prefer_ofs_delta = git_config_bool(var, value);
 775                return 0;
 776        }
 777
 778        return git_default_config(var, value, cb);
 779}
 780
 781static struct lock_file lock;
 782
 783static void fetch_pack_setup(void)
 784{
 785        static int did_setup;
 786        if (did_setup)
 787                return;
 788        git_config(fetch_pack_config, NULL);
 789        if (0 <= transfer_unpack_limit)
 790                unpack_limit = transfer_unpack_limit;
 791        else if (0 <= fetch_unpack_limit)
 792                unpack_limit = fetch_unpack_limit;
 793        did_setup = 1;
 794}
 795
 796int cmd_fetch_pack(int argc, const char **argv, const char *prefix)
 797{
 798        int i, ret, nr_heads;
 799        struct ref *ref = NULL;
 800        char *dest = NULL, **heads;
 801        int fd[2];
 802        char *pack_lockfile = NULL;
 803        char **pack_lockfile_ptr = NULL;
 804        struct child_process *conn;
 805
 806        nr_heads = 0;
 807        heads = NULL;
 808        for (i = 1; i < argc; i++) {
 809                const char *arg = argv[i];
 810
 811                if (*arg == '-') {
 812                        if (!prefixcmp(arg, "--upload-pack=")) {
 813                                args.uploadpack = arg + 14;
 814                                continue;
 815                        }
 816                        if (!prefixcmp(arg, "--exec=")) {
 817                                args.uploadpack = arg + 7;
 818                                continue;
 819                        }
 820                        if (!strcmp("--quiet", arg) || !strcmp("-q", arg)) {
 821                                args.quiet = 1;
 822                                continue;
 823                        }
 824                        if (!strcmp("--keep", arg) || !strcmp("-k", arg)) {
 825                                args.lock_pack = args.keep_pack;
 826                                args.keep_pack = 1;
 827                                continue;
 828                        }
 829                        if (!strcmp("--thin", arg)) {
 830                                args.use_thin_pack = 1;
 831                                continue;
 832                        }
 833                        if (!strcmp("--include-tag", arg)) {
 834                                args.include_tag = 1;
 835                                continue;
 836                        }
 837                        if (!strcmp("--all", arg)) {
 838                                args.fetch_all = 1;
 839                                continue;
 840                        }
 841                        if (!strcmp("-v", arg)) {
 842                                args.verbose = 1;
 843                                continue;
 844                        }
 845                        if (!prefixcmp(arg, "--depth=")) {
 846                                args.depth = strtol(arg + 8, NULL, 0);
 847                                continue;
 848                        }
 849                        if (!strcmp("--no-progress", arg)) {
 850                                args.no_progress = 1;
 851                                continue;
 852                        }
 853                        if (!strcmp("--stateless-rpc", arg)) {
 854                                args.stateless_rpc = 1;
 855                                continue;
 856                        }
 857                        if (!strcmp("--lock-pack", arg)) {
 858                                args.lock_pack = 1;
 859                                pack_lockfile_ptr = &pack_lockfile;
 860                                continue;
 861                        }
 862                        usage(fetch_pack_usage);
 863                }
 864                dest = (char *)arg;
 865                heads = (char **)(argv + i + 1);
 866                nr_heads = argc - i - 1;
 867                break;
 868        }
 869        if (!dest)
 870                usage(fetch_pack_usage);
 871
 872        if (args.stateless_rpc) {
 873                conn = NULL;
 874                fd[0] = 0;
 875                fd[1] = 1;
 876        } else {
 877                conn = git_connect(fd, (char *)dest, args.uploadpack,
 878                                   args.verbose ? CONNECT_VERBOSE : 0);
 879        }
 880
 881        get_remote_heads(fd[0], &ref, 0, NULL, 0, NULL);
 882
 883        ref = fetch_pack(&args, fd, conn, ref, dest,
 884                nr_heads, heads, pack_lockfile_ptr);
 885        if (pack_lockfile) {
 886                printf("lock %s\n", pack_lockfile);
 887                fflush(stdout);
 888        }
 889        close(fd[0]);
 890        close(fd[1]);
 891        if (finish_connect(conn))
 892                ref = NULL;
 893        ret = !ref;
 894
 895        if (!ret && nr_heads) {
 896                /* If the heads to pull were given, we should have
 897                 * consumed all of them by matching the remote.
 898                 * Otherwise, 'git fetch remote no-such-ref' would
 899                 * silently succeed without issuing an error.
 900                 */
 901                for (i = 0; i < nr_heads; i++)
 902                        if (heads[i] && heads[i][0]) {
 903                                error("no such remote ref %s", heads[i]);
 904                                ret = 1;
 905                        }
 906        }
 907        while (ref) {
 908                printf("%s %s\n",
 909                       sha1_to_hex(ref->old_sha1), ref->name);
 910                ref = ref->next;
 911        }
 912
 913        return ret;
 914}
 915
 916struct ref *fetch_pack(struct fetch_pack_args *my_args,
 917                       int fd[], struct child_process *conn,
 918                       const struct ref *ref,
 919                const char *dest,
 920                int nr_heads,
 921                char **heads,
 922                char **pack_lockfile)
 923{
 924        struct stat st;
 925        struct ref *ref_cpy;
 926
 927        fetch_pack_setup();
 928        if (&args != my_args)
 929                memcpy(&args, my_args, sizeof(args));
 930        if (args.depth > 0) {
 931                if (stat(git_path("shallow"), &st))
 932                        st.st_mtime = 0;
 933        }
 934
 935        if (heads && nr_heads)
 936                nr_heads = remove_duplicates(nr_heads, heads);
 937        if (!ref) {
 938                packet_flush(fd[1]);
 939                die("no matching remote head");
 940        }
 941        ref_cpy = do_fetch_pack(fd, ref, nr_heads, heads, pack_lockfile);
 942
 943        if (args.depth > 0) {
 944                struct cache_time mtime;
 945                struct strbuf sb = STRBUF_INIT;
 946                char *shallow = git_path("shallow");
 947                int fd;
 948
 949                mtime.sec = st.st_mtime;
 950                mtime.nsec = ST_MTIME_NSEC(st);
 951                if (stat(shallow, &st)) {
 952                        if (mtime.sec)
 953                                die("shallow file was removed during fetch");
 954                } else if (st.st_mtime != mtime.sec
 955#ifdef USE_NSEC
 956                                || ST_MTIME_NSEC(st) != mtime.nsec
 957#endif
 958                          )
 959                        die("shallow file was changed during fetch");
 960
 961                fd = hold_lock_file_for_update(&lock, shallow,
 962                                               LOCK_DIE_ON_ERROR);
 963                if (!write_shallow_commits(&sb, 0)
 964                 || write_in_full(fd, sb.buf, sb.len) != sb.len) {
 965                        unlink_or_warn(shallow);
 966                        rollback_lock_file(&lock);
 967                } else {
 968                        commit_lock_file(&lock);
 969                }
 970                strbuf_release(&sb);
 971        }
 972
 973        reprepare_packed_git();
 974        return ref_cpy;
 975}