)]}'
{
  "log": [
    {
      "commit": "80d2ceb22267b7dc61b107934ff5264b6439a785",
      "tree": "8d5c31dc12bf71d3d7f707341c413b3c0801a344",
      "parents": [
        "55e4d464a7f8cf366290ba2d3c8bdd8297d71d32"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Fri Oct 26 12:23:05 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Fri Oct 26 12:24:57 2012 -0700"
      },
      "message": "repo selfupdate: Fix _PostRepoUpgrade takes 2 arguments\n\nChange-Id: I1cf9e0674ea366ddce96c949e0bc085e3452b25a\n"
    },
    {
      "commit": "55e4d464a7f8cf366290ba2d3c8bdd8297d71d32",
      "tree": "d81deb7e0fa393f8a5e43219db8a798b0ef71b35",
      "parents": [
        "c9129d90deb7377324b5178a231657e3d8c74019"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Mon Oct 01 16:12:28 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Fri Oct 26 07:03:59 2012 -0700"
      },
      "message": "Add a PGP key for cco3@android.com\n\nThis change adds a PGP key to allow cco3@android.com to sign releases.\n\nChange-Id: I18a70c8b7d8f272dd1aad9d6b2e4a237ef35af33\n"
    },
    {
      "commit": "c9129d90deb7377324b5178a231657e3d8c74019",
      "tree": "f0dd3f9ade22e48f4ab9cb8447a360e2e01a5aca",
      "parents": [
        "57365c98cc227255f50ab3d71462204c804eb975"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Mon Oct 01 16:12:28 2012 -0700"
      },
      "committer": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Thu Oct 25 17:48:35 2012 -0700"
      },
      "message": "Update PGP keys during _PostRepoUpgrade in `sync`\n\nPreviously, if a key was added, a client wouldn\u0027t add the key during\nthe sync step.  This would cause issues if a new key were added and a\nsubsequent release were signed by that key.\n\nChange-Id: I4fac317573cd9d0e8da62aa42e00faf08bfeb26c\n"
    },
    {
      "commit": "57365c98cc227255f50ab3d71462204c804eb975",
      "tree": "04ade83292c018ffd23beae5b228e4b6f688530e",
      "parents": [
        "dc96476af37558c8eaf6d25087d4a604612642dd",
        "188572170e8cdf28df55a5ca90ed70d14b72b804"
      ],
      "author": {
        "name": "Shawn Pearce",
        "email": "sop@google.com",
        "time": "Thu Oct 25 17:38:05 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Oct 25 17:38:05 2012 -0700"
      },
      "message": "Merge \"sync: Run gc --auto in parallel\""
    },
    {
      "commit": "dc96476af37558c8eaf6d25087d4a604612642dd",
      "tree": "dfdfde22a3ba610bdba5764a184ada1c3996e23e",
      "parents": [
        "2577cec0952899040cd8c6523f69ece4cdc005ac",
        "091f893625269fd12adadf7d1f60c21b4b83e779"
      ],
      "author": {
        "name": "Shawn Pearce",
        "email": "sop@google.com",
        "time": "Thu Oct 25 17:36:03 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Oct 25 17:36:04 2012 -0700"
      },
      "message": "Merge \"project: Support config args in git command callables\""
    },
    {
      "commit": "2577cec0952899040cd8c6523f69ece4cdc005ac",
      "tree": "792f82c975d0d5d039ac3a6c6adc8404d87e8b2c",
      "parents": [
        "e48d34659ebda45431512ab2478558f8e4cdd46c",
        "d947858325ae70ff9c0b2f463a9e8c4ffd00002a"
      ],
      "author": {
        "name": "Shawn Pearce",
        "email": "sop@google.com",
        "time": "Thu Oct 25 17:35:15 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Oct 25 17:35:15 2012 -0700"
      },
      "message": "Merge \"sync: Keep a moving average of last fetch times\""
    },
    {
      "commit": "e48d34659ebda45431512ab2478558f8e4cdd46c",
      "tree": "ab38328b72acf6cb6898f2b6ed3cb859c48249fe",
      "parents": [
        "ab8f911a6721424ddc7cda7ebd2a07270a5909b1",
        "67700e9b90a38cc3719c818bc967153e8b7b429e"
      ],
      "author": {
        "name": "Shawn Pearce",
        "email": "sop@google.com",
        "time": "Thu Oct 25 17:33:36 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Oct 25 17:33:36 2012 -0700"
      },
      "message": "Merge \"sync: Order projects according to last fetch time\""
    },
    {
      "commit": "ab8f911a6721424ddc7cda7ebd2a07270a5909b1",
      "tree": "cf4b0cfab756dc78747894189ef918a262811d48",
      "parents": [
        "608aff7f624e35348ff9fab74bad1d6921944238"
      ],
      "author": {
        "name": "Che-Liang Chiou",
        "email": "clchiou@google.com",
        "time": "Thu Oct 25 13:44:11 2012 -0700"
      },
      "committer": {
        "name": "Che-Liang Chiou",
        "email": "clchiou@google.com",
        "time": "Thu Oct 25 13:55:49 2012 -0700"
      },
      "message": "Fix pylint warnings introduced by the submodule patch\n\n\"69998b0 Represent git-submodule as nested projects\" has introduced a\nfew pylint warnings.\n\nW0612:1439,8:Project._GetSubmodules.get_submodules: Unused variable \u0027sub_gitdir\u0027\nW0613:1424,36:Project._GetSubmodules.get_submodules: Unused argument \u0027path\u0027\nW0612:1450,25:Project._GetSubmodules.parse_gitmodules: Unused variable \u0027e\u0027\nW0622:516,8:Sync.Execute: Redefining built-in \u0027all\u0027\n\nChange-Id: I84378e2832ed1b5ab023e394d53b22dcea799ba4\n"
    },
    {
      "commit": "608aff7f624e35348ff9fab74bad1d6921944238",
      "tree": "e1bdbb8af5927dd226d8e22dc382fd24c4cdfa5e",
      "parents": [
        "13657c407d0424d0866993bea39ed01094caa1c1",
        "a5be53f9c809009e67f217c00b8f30246aacc237"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Thu Oct 25 10:03:36 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Oct 25 10:03:37 2012 -0700"
      },
      "message": "Merge \"Use modern Python exception syntax\""
    },
    {
      "commit": "13657c407d0424d0866993bea39ed01094caa1c1",
      "tree": "74f69003f5f71602e7ed0a6d2d5dd92d03f95caa",
      "parents": [
        "e4ed8f65f376009f70fab0e7978fdfc223f23a76",
        "d75c669fac50f5224b567127291976fd36b31546"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Thu Oct 25 10:00:41 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Oct 25 10:00:42 2012 -0700"
      },
      "message": "Merge \"Add regex matching to repo list command\""
    },
    {
      "commit": "e4ed8f65f376009f70fab0e7978fdfc223f23a76",
      "tree": "00a9118857c613eefdd967d330bc5230ced01555",
      "parents": [
        "fdb44479f8b99e7795021f1b8588a677dcf5fd51",
        "4f7bdea9d24c4eb52f83ada2b67b88ad67cb57a7"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Thu Oct 25 09:51:06 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Oct 25 09:51:07 2012 -0700"
      },
      "message": "Merge \"Add pylint configuration and instructions\""
    },
    {
      "commit": "fdb44479f8b99e7795021f1b8588a677dcf5fd51",
      "tree": "910ad941d3f9882271e3bb0efecafb2e7e104c85",
      "parents": [
        "69998b0c6ff724bf620480140ccce648fec7d6a9",
        "9ed12c5d9cda1f010bc173b0bc622d59e96b0dd0"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Thu Oct 25 09:46:38 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Oct 25 09:46:38 2012 -0700"
      },
      "message": "Merge \"Change PyDev project version to \"python 2.6\"\""
    },
    {
      "commit": "188572170e8cdf28df55a5ca90ed70d14b72b804",
      "tree": "d64ad4724552898c9c49ba19f715c74c5caa504c",
      "parents": [
        "091f893625269fd12adadf7d1f60c21b4b83e779"
      ],
      "author": {
        "name": "Dave Borowitz",
        "email": "dborowitz@google.com",
        "time": "Tue Oct 23 17:02:59 2012 -0700"
      },
      "committer": {
        "name": "Dave Borowitz",
        "email": "dborowitz@google.com",
        "time": "Thu Oct 25 08:12:48 2012 -0700"
      },
      "message": "sync: Run gc --auto in parallel\n\nWe can\u0027t just let this run wild with a high (or even low) -j, since\nthat would hose a system. Instead, limit the total number of threads\nacross all git gc subprocesses to the number of CPUs reported by the\nmultiprocessing module (available in Python 2.6 and above).\n\nChange-Id: Icca0161a1e6116ffa5f7cfc6f5faecda510a7fb9\n"
    },
    {
      "commit": "d75c669fac50f5224b567127291976fd36b31546",
      "tree": "84a7973f8d169b73168d314aa4061424bbd07d2c",
      "parents": [
        "69998b0c6ff724bf620480140ccce648fec7d6a9"
      ],
      "author": {
        "name": "Olof Johansson",
        "email": "olof.johansson@sonymobile.com",
        "time": "Tue Oct 09 08:25:55 2012 +0200"
      },
      "committer": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Thu Oct 25 15:49:13 2012 +0900"
      },
      "message": "Add regex matching to repo list command\n\nThe repo list -r command will execute a regex search for every\nargument provided on both the project name and the project\nworktree path.\n\nUseful for finding rarely used gits.\n\nChange-Id: Iaff90dd36c240b3d5d74817d11469be22d77ae03\n"
    },
    {
      "commit": "091f893625269fd12adadf7d1f60c21b4b83e779",
      "tree": "bec3e027600f88a73108aa3c0f2f8f122903733d",
      "parents": [
        "d947858325ae70ff9c0b2f463a9e8c4ffd00002a"
      ],
      "author": {
        "name": "Dave Borowitz",
        "email": "dborowitz@google.com",
        "time": "Tue Oct 23 17:01:04 2012 -0700"
      },
      "committer": {
        "name": "Dave Borowitz",
        "email": "dborowitz@google.com",
        "time": "Wed Oct 24 14:52:08 2012 -0700"
      },
      "message": "project: Support config args in git command callables\n\nChange-Id: I9d4d0d2b1aeebe41a6b24a339a154d258af665eb\n"
    },
    {
      "commit": "d947858325ae70ff9c0b2f463a9e8c4ffd00002a",
      "tree": "edf33164dfdd829eae74244198f790629d2fabc8",
      "parents": [
        "67700e9b90a38cc3719c818bc967153e8b7b429e"
      ],
      "author": {
        "name": "Dave Borowitz",
        "email": "dborowitz@google.com",
        "time": "Tue Oct 23 16:35:39 2012 -0700"
      },
      "committer": {
        "name": "Dave Borowitz",
        "email": "dborowitz@google.com",
        "time": "Wed Oct 24 14:52:07 2012 -0700"
      },
      "message": "sync: Keep a moving average of last fetch times\n\nTry to more accurately estimate which projects take the longest to\nsync by keeping an exponentially weighted moving average (a\u003d0.5) of\nfetch times, rather than just recording the last observation. This\nshould discount individual outliers (e.g. an unusually large project\nupdate) and hopefully allow truly slow repos to bubble to the top.\n\nChange-Id: I72b2508cb1266e8a19cf15b616d8a7fc08098cb3\n"
    },
    {
      "commit": "67700e9b90a38cc3719c818bc967153e8b7b429e",
      "tree": "57768c3936f66cb28b623c13e59c2bc1dba247ff",
      "parents": [
        "5c6eeac8f0350fd6b14cf226ffcff655f1dd9582"
      ],
      "author": {
        "name": "Dave Borowitz",
        "email": "dborowitz@google.com",
        "time": "Tue Oct 23 15:00:54 2012 -0700"
      },
      "committer": {
        "name": "Dave Borowitz",
        "email": "dborowitz@google.com",
        "time": "Wed Oct 24 14:51:58 2012 -0700"
      },
      "message": "sync: Order projects according to last fetch time\n\nSome projects may consistently take longer to fetch than others, for\nexample a more active project may have many more Gerrit changes than a\nless active project, which take longer to transfer. Use a simple\nheuristic based on the last fetch time to fetch slower projects first,\nso we do not tend to spend the end of the sync fetching a small number\nof outliers.\n\nThis algorithm is probably not optimal, and due to inter-run latency\nvariance and Python thread scheduling, we may not even have good\nestimates of a project sync time.\n\nChange-Id: I9a463f214b3ed742e4d807c42925b62cb8b1745b\n"
    },
    {
      "commit": "a5be53f9c809009e67f217c00b8f30246aacc237",
      "tree": "7ab0da1fd31968eee882de81df8c9b93ae52fdfb",
      "parents": [
        "9ed12c5d9cda1f010bc173b0bc622d59e96b0dd0"
      ],
      "author": {
        "name": "Sarah Owens",
        "email": "sarato@inkylabs.com",
        "time": "Sun Sep 09 15:37:57 2012 -0700"
      },
      "committer": {
        "name": "Sarah Owens",
        "email": "sarato@inkylabs.com",
        "time": "Tue Oct 23 21:35:59 2012 -0700"
      },
      "message": "Use modern Python exception syntax\n\n\"except Exception as e\" instead of \"except Exception, e\"\n\nThis is part of a transition to supporting Python 3.  Python \u003e\u003d 2.6\nsupport \"as\" syntax.\n\nNote: this removes Python 2.5 support.\n\nChange-Id: I309599f3981bba2b46111c43102bee38ff132803\n"
    },
    {
      "commit": "9ed12c5d9cda1f010bc173b0bc622d59e96b0dd0",
      "tree": "0579b811fe078ff5f97cb21a9ec34b500b1c2eae",
      "parents": [
        "5c6eeac8f0350fd6b14cf226ffcff655f1dd9582"
      ],
      "author": {
        "name": "Sarah Owens",
        "email": "sarato@inkylabs.com",
        "time": "Tue Oct 23 21:28:12 2012 -0700"
      },
      "committer": {
        "name": "Sarah Owens",
        "email": "sarato@inkylabs.com",
        "time": "Tue Oct 23 21:35:46 2012 -0700"
      },
      "message": "Change PyDev project version to \"python 2.6\"\n\nRepo is dropping support for Python \u003c2.5 soon, so this updates the\nPyDev configuration appropriately.\n\nChange-Id: If327951e3a9fd9ff7513b931bfcfe6172dc8e4c5\n"
    },
    {
      "commit": "4f7bdea9d24c4eb52f83ada2b67b88ad67cb57a7",
      "tree": "49c93020cd026d13f43325b43d13266542cdc5a1",
      "parents": [
        "69998b0c6ff724bf620480140ccce648fec7d6a9"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Mon Oct 22 12:50:15 2012 +0900"
      },
      "committer": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Wed Oct 24 10:18:13 2012 +0900"
      },
      "message": "Add pylint configuration and instructions\n\npylint configuration file (.pylintrc) is added, and submission\ninstructions are updated to include pylint usage steps.\n\nDeprecated pylint suppression (`disable-msg`) is updated in a few\nmodules to make it work properly with the latest version (0.26).\n\nChange-Id: I4ec2ef318e23557a374ecdbf40fe12645766830c\n"
    },
    {
      "commit": "69998b0c6ff724bf620480140ccce648fec7d6a9",
      "tree": "b6f9c4c00b04a0f140074c4c2dba91ed4f055b11",
      "parents": [
        "5c6eeac8f0350fd6b14cf226ffcff655f1dd9582"
      ],
      "author": {
        "name": "Che-Liang Chiou",
        "email": "clchiou@google.com",
        "time": "Wed Jan 11 11:28:42 2012 +0800"
      },
      "committer": {
        "name": "Che-Liang Chiou",
        "email": "clchiou@google.com",
        "time": "Tue Oct 23 16:08:58 2012 -0700"
      },
      "message": "Represent git-submodule as nested projects\n\nWe need a representation of git-submodule in repo; otherwise repo will\nnot sync submodules, and leave workspace in a broken state.  Of course\nthis will not be a problem if all projects are owned by the owner of the\nmanifest file, who may simply choose not to use git-submodule in all\nprojects.  However, this is not possible in practice because manifest\nfile owner is unlikely to own all upstream projects.\n\nAs git submodules are simply git repositories, it is natural to treat\nthem as plain repo projects that live inside a repo project.  That is,\nwe could use recursively declared projects to denote the is-submodule\nrelation of git repositories.\n\nThe behavior of repo remains the same to projects that do not have a\nsub-project within.  As for parent projects, repo fetches them and their\nsub-projects as normal projects, and then checks out subprojects at the\ncommit specified in parent\u0027s commit object.  The sub-project is fetched\nat a path relative to parent project\u0027s working directory; so the path\nspecified in manifest file should match that of .gitmodules file.\n\nIf a submodule is not registered in repo manifest, repo will derive its\nproperties from itself and its parent project, which might not always be\ncorrect.  In such cases, the subproject is called a derived subproject.\n\nTo a user, a sub-project is merely a git-submodule; so all tips of\nworking with a git-submodule apply here, too.  For example, you should\nnot run `repo sync` in a parent repository if its submodule is dirty.\n\nChange-Id: I541e9e2ac1a70304272dbe09724572aa1004eb5c\n"
    },
    {
      "commit": "5c6eeac8f0350fd6b14cf226ffcff655f1dd9582",
      "tree": "3225695b9d2a97342a49127717ea5e2bc5935a63",
      "parents": [
        "e98607248eec2b149d84efe944c12cbef419b82e"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Thu Oct 11 16:44:48 2012 +0900"
      },
      "committer": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Mon Oct 22 12:30:14 2012 +0900"
      },
      "message": "More coding style cleanup\n\nFixing more issues found with pylint.  Some that were supposed to\nhave been fixed in the previous sweep (Ie0db839e) but were missed:\n\nC0321: More than one statement on a single line\nW0622: Redefining built-in \u0027name\u0027\n\nAnd some more:\n\nW0631: Using possibly undefined loop variable \u0027name\u0027\nW0223: Method \u0027name\u0027 is abstract in class \u0027name\u0027 but is not overridden\nW0231: __init__ method from base class \u0027name\u0027 is not called\n\nChange-Id: Ie119183708609d6279e973057a385fde864230c3\n"
    },
    {
      "commit": "e98607248eec2b149d84efe944c12cbef419b82e",
      "tree": "5a0e8ea0fc7f7b5c55ea6cb725a49e656afdef82",
      "parents": [
        "2f6ab7f5b8f21b2dbfe9ae102674bd1694e94f03"
      ],
      "author": {
        "name": "JoonCheol Park",
        "email": "jooncheol@gmail.com",
        "time": "Thu Oct 11 02:31:44 2012 +0900"
      },
      "committer": {
        "name": "JoonCheol Park",
        "email": "jooncheol@gmail.com",
        "time": "Fri Oct 12 06:02:35 2012 +0900"
      },
      "message": "Support HTTP authentication using user input as fallback\n\nIf repo could not find authentication credentials from ~/.netrc, this\npatch tries to get user and password from user\u0027s console input. This\ncould be a good choice if user doesn\u0027t want to save his plain password\nin ~/.netrc or if user doesn\u0027t know about the netrc usage.\n\nThe user will be prompted only if authentication infomation does not\nexist in the password manager. Since main.py firstly loads auth\ninfomation from ~/.netrc, this will be executed only as fallback\nmechanism.\n\nExample:\n$ repo upload .\nUpload project xxx/ to remote branch master:\n branch yyy ( 1 commit, ...):\n to https://review.zzz.com/gerrit/ (y/N)? y\n\n(repo may try to access to https://review.zzz.com/gerrit/ssh_info and\nwill get the 401 HTTP Basic Authentication response from server. If no\nauthentication info in ~/.netrc, This patch will ask username/passwd)\n\nAuthorization Required (Message from Web Server)\nUser: pororo\nPassword:\n....\n[OK ] xxx/\n\nChange-Id: Ia348a4609ac40060d9093c7dc8d7c2560020455a\n"
    },
    {
      "commit": "2f6ab7f5b8f21b2dbfe9ae102674bd1694e94f03",
      "tree": "040f9045751d83902ea8c479304fdfa2a0061a54",
      "parents": [
        "3a6cd4200e42fbb5a21b3fb8d3c9738c0320cc63"
      ],
      "author": {
        "name": "Mickaël Salaün",
        "email": "mic@digikod.net",
        "time": "Sun Sep 30 00:37:55 2012 +0200"
      },
      "committer": {
        "name": "Mickaël Salaün",
        "email": "mic@digikod.net",
        "time": "Wed Oct 10 08:30:15 2012 +0200"
      },
      "message": "Rename \"dir\" variables\n\nThe variable name \"dir\" conflicts with the name of a Python built-in\nfunction: http://docs.python.org/library/functions.html#dir\n\nChange-Id: I850f3ec8df7563dc85e21f2876fe5e6550ca2d8f\n"
    },
    {
      "commit": "3a6cd4200e42fbb5a21b3fb8d3c9738c0320cc63",
      "tree": "68ae5094d6530453887fb35a73fd5fa55f55a034",
      "parents": [
        "25f17682ca4ecd8acc887462d4bebc7c429cf110",
        "8a68ff96057ec58e524a3e41a2d8dca7b5d016bc"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Tue Oct 09 14:29:46 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Tue Oct 09 14:29:46 2012 -0700"
      },
      "message": "Merge \"Coding style cleanup\""
    },
    {
      "commit": "25f17682ca4ecd8acc887462d4bebc7c429cf110",
      "tree": "8416b3cc2ac42cbf43452da418121f0b056ca878",
      "parents": [
        "e3b1c45aebed329cbc9ad172b1d8e812cf208117",
        "297e7c6ee69077cb063b90a32d22b0b812a95841"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Tue Oct 09 13:46:10 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Tue Oct 09 13:46:10 2012 -0700"
      },
      "message": "Merge \"Expand ~ to user\u0027s home directory for --reference\""
    },
    {
      "commit": "8a68ff96057ec58e524a3e41a2d8dca7b5d016bc",
      "tree": "22f6971e8d3c4a90d11d3704602d073a852328b4",
      "parents": [
        "e3b1c45aebed329cbc9ad172b1d8e812cf208117"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Mon Sep 24 12:15:13 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Tue Oct 09 12:45:30 2012 +0200"
      },
      "message": "Coding style cleanup\n\nFix the following issues reported by pylint:\n\nC0321: More than one statement on a single line\nW0622: Redefining built-in \u0027name\u0027\nW0612: Unused variable \u0027name\u0027\nW0613: Unused argument \u0027name\u0027\nW0102: Dangerous default value \u0027value\u0027 as argument\nW0105: String statement has no effect\n\nAlso fixed a few cases of inconsistent indentation.\n\nChange-Id: Ie0db839e7c57d576cff12d8c055fe87030d00744\n"
    },
    {
      "commit": "297e7c6ee69077cb063b90a32d22b0b812a95841",
      "tree": "5e9c8fea016c7943dd3b933e228e238d171b091b",
      "parents": [
        "7119f94abaa48b3b7fb990f2a12ec5458ef3f133"
      ],
      "author": {
        "name": "Victor Boivie",
        "email": "victor.boivie@sonymobile.com",
        "time": "Fri Oct 05 14:50:05 2012 +0200"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Mon Oct 08 15:03:20 2012 +0200"
      },
      "message": "Expand ~ to user\u0027s home directory for --reference\n\nThis allows a user to have a \u0027repo init\u0027 as:\n  $ repo init -u ... --reference\u003d~/mirror\n\nChange-Id: Ib85b7c8ffca9d732132c68fe9a8d7f0ab1fa9288\n"
    },
    {
      "commit": "e3b1c45aebed329cbc9ad172b1d8e812cf208117",
      "tree": "629984135b1cea3c0a32454eaecbe806ed09ca58",
      "parents": [
        "7119f94abaa48b3b7fb990f2a12ec5458ef3f133"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Wed Oct 03 18:04:02 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Fri Oct 05 10:34:19 2012 +0200"
      },
      "message": "Remove unreachable code\n\nChange 9bb1816b removed part of a block of code, but left the\nremaining part unreachable.  Remove it.\n\nChange-Id: Icdc6061d00e6027df32dee9a3bad3999fe7cdcbc\n"
    },
    {
      "commit": "7119f94abaa48b3b7fb990f2a12ec5458ef3f133",
      "tree": "37c7705cdb457bc9e43de7dc2317981de101378c",
      "parents": [
        "01f443d75a8116aaca5612ee44cceb1ff1a18f2f"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Wed Oct 03 17:20:06 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Thu Oct 04 10:31:09 2012 +0200"
      },
      "message": "Update commit-msg hook to version from Gerrit v2.5-rc0\n\nChange-Id: I0d11ac0c24cd53386e996b7dd9bd37c89c789f60\n"
    },
    {
      "commit": "01f443d75a8116aaca5612ee44cceb1ff1a18f2f",
      "tree": "02f8bc525cfa95d1fae0fd106278f3bf24d87896",
      "parents": [
        "b926116a1483d04df99252ed02418bf8e58094a3"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Wed Oct 03 19:11:28 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Thu Oct 04 10:31:09 2012 +0200"
      },
      "message": "Correct call to `sys.exit()`\n\nIt should be `sys.exit()` not `os.exit()`.\n\nChange-Id: Iaeeef456ddf2d17f5df2b712e50e3630bed856c3\n"
    },
    {
      "commit": "b926116a1483d04df99252ed02418bf8e58094a3",
      "tree": "67bbae4a818085b42de7a6a3ee41aaa5fdade55c",
      "parents": [
        "3ff9decfd4e2f1fed71658d0f78a17895f80ff5f"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Wed Oct 03 15:47:02 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Thu Oct 04 10:31:09 2012 +0200"
      },
      "message": "Remove `ImportError` class\n\nThe definition of `ImportError` redefines the Python built-in\nclass of the same name.\n\nIt is not used anywhere, so remove it.\n\nChange-Id: I557ce28c93a3306fff72873dc6f477330fc33128\n"
    },
    {
      "commit": "3ff9decfd4e2f1fed71658d0f78a17895f80ff5f",
      "tree": "5ecf68da509291eaf368772f3f5c3571060651a8",
      "parents": [
        "9779565abf06d2f1e48548197be350a06c1eab9b",
        "14a6674e32b3000dbe8b7c96b0d1bb4fb0021720"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Wed Oct 03 16:49:12 2012 -0700"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Wed Oct 03 16:49:12 2012 -0700"
      },
      "message": "Merge \"manifest: record the original revision when in -r mode.\""
    },
    {
      "commit": "14a6674e32b3000dbe8b7c96b0d1bb4fb0021720",
      "tree": "024482226fefd4c188f20f56047325b69d388a9f",
      "parents": [
        "34acdd253439448b6c08c3abfc5e7b8bd03f383f"
      ],
      "author": {
        "name": "Brian Harring",
        "email": "ferringb@google.com",
        "time": "Fri Sep 28 20:21:57 2012 -0700"
      },
      "committer": {
        "name": "Brian Harring",
        "email": "ferringb@google.com",
        "time": "Fri Sep 28 22:31:27 2012 -0700"
      },
      "message": "manifest: record the original revision when in -r mode.\n\nCurrently when doing a sync against a revision locked manifest,\nsync has no option but to fall back to sync\u0027ing the entire refs space;\nit doesn\u0027t know which ref to ask for that contains the sha1 it wants.\n\nThis sucks if we\u0027re in -c mode; thus when we generate a revision\nlocked manifest, record the originating branch- and try syncing that\nbranch first.  If the sha1 is found within that branch, this saves\nus having to pull down the rest of the repo- a potentially heavy\nsaving.\n\nIf that branch doesn\u0027t have the desired sha1, we fallback to sync\u0027ing\neverything.\n\nChange-Id: I99a5e44fa1d792dfcada76956a2363187df94cf1\n"
    },
    {
      "commit": "9779565abf06d2f1e48548197be350a06c1eab9b",
      "tree": "2df81e18395ef2a4782e0a889abaaebcea0e40f1",
      "parents": [
        "cf76b1bcec6386f9530636e64746502f9856b5cf"
      ],
      "author": {
        "name": "David Holmer",
        "email": "odinguru@gmail.com",
        "time": "Wed Sep 26 01:58:48 2012 -0400"
      },
      "committer": {
        "name": "David Holmer",
        "email": "odinguru@gmail.com",
        "time": "Wed Sep 26 01:58:48 2012 -0400"
      },
      "message": "Fix incorrect default_groups when parsing projects from XML manifest\n\nChange Details:\n* Switch first default group to \u0027all\u0027 instead of \u0027default\u0027\n\nChange Benefits:\n* More consistent with default_groups in the counterpart Save() function\n* Fixes bug where command \u0027repo manifest\u0027 added an extra \u0027default\u0027\n  group to every output project element groups attribute. This bug was\n  particularly confusing for projects which had \u0027groups\u003d\"notdefault\"\u0027\n  as they were output as \u0027groups\u003d\"notdefault,default\"\u0027 by \u0027repo manifest\u0027\n\nChange-Id: I5611c027a982d3394899466248b971910bec8c6b\n"
    },
    {
      "commit": "cf76b1bcec6386f9530636e64746502f9856b5cf",
      "tree": "15bd204cace8d3d43161f8ef91130984159e9049",
      "parents": [
        "e00aa6b923d28a3c910f85e7726e4ba1d2a9aebd"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Fri Sep 14 10:31:42 2012 +0900"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Fri Sep 21 11:20:59 2012 -0700"
      },
      "message": "sync: Support manual authentication to the manifest server\n\nAdd two new command line options, -u/--manifest-server-username and\n-p/--manifest-server-password, which can be used to specify a username\nand password to authenticate to the manifest server when using the\n-s/--smart-sync or -t/--smart-tag option.\n\nIf -u and -p are not specified when using the -s or -t option, use\nauthentication credentials from the .netrc file (if there are any).\n\nAuthentication credentials from -u/-p or .netrc are not used if the\nmanifest server specified in the manifest file already includes\ncredentials.\n\nChange-Id: I6cf9540d28f6cef64c5694e8928cfe367a71d28d\n"
    },
    {
      "commit": "e00aa6b923d28a3c910f85e7726e4ba1d2a9aebd",
      "tree": "07c848b81c58e5d4a8e34ecae8606ee5fa62679e",
      "parents": [
        "86d973d24ec6771504c37eddc535dff8e03c724f"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Tue Sep 11 14:33:51 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Tue Sep 18 09:54:57 2012 +0200"
      },
      "message": "Clean up imports\n\nmanifest_xml: import `HEAD` and `R_HEADS` from correct module\nversion: import `HEAD` from correct module\n\n`HEAD` and `R_HEADS` should be imported from the git_refs module,\nwhere they are originally defined, rather than from the project\nmodule.\n\nrepo: remove unused import of readline\n\ncherry_pick: import standard modules on separate lines\nsmartsync: import subcmd modules explicitly from subcmd\n\nUse:\n  `import re\n  import sys`\nand\n  `from subcmds.sync import Sync`\n\nInstead of:\n  `import sys, re`\nand\n  `from sync import Sync`\n\nChange-Id: Ie10dd6832710939634c4f5c86b9ba5a9cd6fc92e\n"
    },
    {
      "commit": "86d973d24ec6771504c37eddc535dff8e03c724f",
      "tree": "1676f107c59efd1d92bd92cb48a9dc726bf00e59",
      "parents": [
        "34acdd253439448b6c08c3abfc5e7b8bd03f383f"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Fri Aug 24 10:21:02 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Tue Sep 11 09:45:48 2012 +0200"
      },
      "message": "sync: Support authentication to manifest server with .netrc\n\nWhen using the --smart-sync or --smart-tag option, and the specified\nmanifest server is hosted on a server that requires authentication,\nrepo sync fails with the error: HTTP 401 Unauthorized.\n\nAdd support for getting the credentials from the .netrc file.\n\nIf a .netrc file exists in the user\u0027s home directory, and it contains\ncredentials for the hostname of the manifest server specified in the\nmanifest, use the credentials to authenticate with the manifest server\nusing the URL syntax extension for Basic Authentication:\n\n  http://user:password@host:port/path\n\nCredentials from the .netrc file are only used if the manifest server\nURL specified in the manifest does not already include credentials.\n\nChange-Id: I06e6586e8849d0cd12fa9746789e8d45d5b1f848\n"
    },
    {
      "commit": "34acdd253439448b6c08c3abfc5e7b8bd03f383f",
      "tree": "f3290384d6d47fa8187678f75ed9885dbbfad20e",
      "parents": [
        "d94aaef39e301cc912968c07d1783232bf34a174"
      ],
      "author": {
        "name": "Jooncheol Park",
        "email": "jooncheol@gmail.com",
        "time": "Mon Aug 27 02:25:59 2012 +0900"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Fri Sep 07 08:38:08 2012 -0700"
      },
      "message": "Fix ManifestParseError when first child node is comment\n\nIf the first line of manifest.xml is a XML comment, root.childNodes[0]\nis not a \u0027manifest\u0027 element node. The python minidom module will makes\na \u0027Comment\u0027 node as root.childNodes[0]. Since the original code only\nchecks whether the first child node is \u0027manifest\u0027, it couldn\u0027t do any\ncommand including \u0027sync\u0027 due to the \u0027ManifestParseError\u0027 exception. This\npatch could allow the comments between \u0027\u003c?xml ...?\u003e\u0027 and \u0027\u003cmanifest\u003e\u0027 in\nthe manifest.xml file.\n\nChange-Id: I0b81dea4f806965eca90f704c8aa7df49c579402\n"
    },
    {
      "commit": "d94aaef39e301cc912968c07d1783232bf34a174",
      "tree": "48b884fef63992e8b80127c40687a7cf5ff4c8f7",
      "parents": [
        "bd489c4eaa592af98b8b4f09b0a465e0d2b6046a"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Fri Sep 07 09:52:04 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Fri Sep 07 10:17:00 2012 +0200"
      },
      "message": "sync: Correct imports of `R_HEADS` and `HEAD`\n\n`R_HEADS` is imported twice, from both the git_refs and project\nmodules.\n\nIt is actually defined in git_refs, and in project it is imported\nfrom there, so the import of `R_HEADS` from project in the sync\nmodule is redundant.  Remove it.\n\n`HEAD` is imported from project, but like `R_HEADS` it is actually\ndefined in git_refs.  Import it from git_refs instead.\n\nChange-Id: I8e2b0217d0d9f9f4ee5ef5b8cd0b026174ac52f4\n"
    },
    {
      "commit": "bd489c4eaa592af98b8b4f09b0a465e0d2b6046a",
      "tree": "6954a16b023daaea026d122251157c0b2db39367",
      "parents": [
        "2dc810c2e4028878b9c3484866a5973d5c33479d"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Thu Aug 23 10:21:26 2012 +0900"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Sep 06 11:18:25 2012 -0700"
      },
      "message": "sync: catch exceptions when connecting to the manifest server\n\nWhen connecting to the manifest server, exceptions can occur but\nare not caught, resulting in the repo sync exiting with a python\ntraceback.\n\nAdd handling of the following exceptions:\n\n- IOError, which can be raised for example if the manifest server\nURL is malformed.\n- xmlrpclib.ProtocolError, which can be raised if the connection\nto the manifest server fails with HTTP error.\n- xmlrpclib.Fault, which can be raised if the RPC call fails for\nsome other reason.\n\nChange-Id: I3a4830aef0941debadd515aac776a3932e28a943\n"
    },
    {
      "commit": "2dc810c2e4028878b9c3484866a5973d5c33479d",
      "tree": "567de855659b91a4629d4b555b71612e4c8ed70c",
      "parents": [
        "bb1b5f5f863fca0e85764f5b35c117f5724d15c0"
      ],
      "author": {
        "name": "Matt Gumbel",
        "email": "matthew.k.gumbel@intel.com",
        "time": "Thu Aug 30 09:39:36 2012 -0700"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Thu Sep 06 10:54:46 2012 -0700"
      },
      "message": "Fix errors when clone.bundle missing on server\n\nCatch curl failures to download clone.bundle; don\u0027t let git try to parse\nthe 404 page as a bundle file (was causing much user confusion).\n\nThis should eliminate false error messages from init and sync such as:\n  error: \u0027.repo/manifests.git/clone.bundle\u0027 does not look like a v2 bundle file\n  fatal: Could not read bundle \u0027.repo/manifests.git/clone.bundle\u0027.\n  error: RPC failed; result\u003d22, HTTP code \u003d 400\n\nSigned-off-by: Matt Gumbel \u003cmatthew.k.gumbel@intel.com\u003e\nChange-Id: I7994f7c0baecfb45bb5a5850c48bd2a0ffabe773\n"
    },
    {
      "commit": "bb1b5f5f863fca0e85764f5b35c117f5724d15c0",
      "tree": "0b6b8d0d6d027f2d0e0dd6fabdd4eafc6c919026",
      "parents": [
        "e2126652a3a1e08724a54091793bb29a79d31014"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Mon Aug 13 13:11:18 2012 -0700"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Wed Sep 05 11:46:48 2012 -0700"
      },
      "message": "Allow projects to be specified as notdefault\n\nInstead of every group being in the group \"default\", every project\nis now in the group \"all\".   A group that should not be downloaded\nby default may be added to the group \"notdefault\".\n\nThis allows all group names to be positive (instead of removing groups\ndirectly in the manifest with -default) and offers a clear way of\nselecting every project (--groups all).\n\nChange-Id: I99cd70309adb1f8460db3bbc6eff46bdcd22256f\n"
    },
    {
      "commit": "e2126652a3a1e08724a54091793bb29a79d31014",
      "tree": "a931f598a6a2dcd7bc449ca7167799a18b0b493d",
      "parents": [
        "9a27d0111d5cf88c6b9409261707a5d7d50aaa64"
      ],
      "author": {
        "name": "David \u0027Digit\u0027 Turner",
        "email": "digit@google.com",
        "time": "Wed Sep 05 10:35:06 2012 +0200"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Wed Sep 05 11:38:41 2012 -0700"
      },
      "message": "Make \"repo sync -j\u003ccount\u003e\" stop properly on Ctrl-C.\n\nThe threaded \u0027repo sync\u0027 implementation would very often freeze the\nprocess when interrupted by the user with Ctrl-C. The only solution\nbeing to kill -9 the process explicitly from another terminal.\n\nThe reason for this is best explained here:\n\nhttp://snakesthatbite.blogspot.fr/2010/09/cpython-threading-interrupting.html\n\nThis patch makes all helper sync threads \u0027daemon\u0027, which allows the\nprocess to terminate immediately on Ctrl-C.\n\nNote that this will forcefully kill all threads in case of interruption; this\nis generally a bad thing, but:\n\n  1/ This is equivalent to calling kill -9 in another terminal, which\n     is the _only_ thing that can currently stop the process.\n\n  2/ There doesn\u0027t seem to be a way to tell the worker threads to\n     gently stop when they are in a blocking operation anyway (even\n     in the non-threaded case).\n\n+ Do the same for \"repo status -j\u003ccount\u003e\".\n\nChange-Id: Ieaf45b0eacee36f35427f8edafd87415c2aa7be4\n"
    },
    {
      "commit": "9a27d0111d5cf88c6b9409261707a5d7d50aaa64",
      "tree": "4a80e3e4c1fd1367a120371375c8d3703edb4701",
      "parents": [
        "918ff85c1e9d9606e4924a0af9a8ddc2e4db692a"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Tue Aug 21 14:23:49 2012 +0900"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Wed Sep 05 06:00:47 2012 -0700"
      },
      "message": "manifest-format.txt: Add documentation for GetManifest RPC method\n\nAdd documentation of the GetManifest RPC method in the\nmanifest-server section.\n\nChange-Id: I5cda5929bc8a0ca9d3f2b9da63216427041d2823\n"
    },
    {
      "commit": "918ff85c1e9d9606e4924a0af9a8ddc2e4db692a",
      "tree": "0805e0f28ceef0c2375e53e8011fd0bfd292e869",
      "parents": [
        "3d07da82abe52d0971ea2de75f69db3359af506f"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Tue Aug 07 10:44:01 2012 -0700"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Tue Sep 04 09:30:18 2012 -0700"
      },
      "message": "`repo manifest`: default to stdout if no \"-o\"\n\nChange-Id: I1b0ff9ed5df6386f0c2a851c6c48d063199fe663\n"
    },
    {
      "commit": "3d07da82abe52d0971ea2de75f69db3359af506f",
      "tree": "9ed504bb825957a058f259b5390eef1b902745d9",
      "parents": [
        "e15c65abc25cd1d5d77ec6815a3c011b9f57ddac"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Wed Aug 15 14:22:08 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Thu Aug 23 12:15:49 2012 +0200"
      },
      "message": "init: Improved help text for the --mirror option\n\nChange-Id: Ia6032865f9296b29524c2c25b72bd8e175b30489\n"
    },
    {
      "commit": "e15c65abc25cd1d5d77ec6815a3c011b9f57ddac",
      "tree": "43bd95e2e83abcd88c5d05b6a65393877c51028b",
      "parents": [
        "daa851f6cd9edb3851a3884fd2864f0f3dc583b2"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Wed Aug 22 10:46:11 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Thu Aug 23 12:15:26 2012 +0200"
      },
      "message": "Remove unused imports\n\nThere are several imports that are not used.  Remove them.\n\nChange-Id: I2ac3be66827bd68d3faedcef7d6bbf30ea01d3f2\n"
    },
    {
      "commit": "daa851f6cd9edb3851a3884fd2864f0f3dc583b2",
      "tree": "32479f87b1a60352934074b8999aa3ef975066a1",
      "parents": [
        "a43f42f9ffed69ee807852230e514b7c4bff5855"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Tue Aug 21 13:52:18 2012 +0900"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Wed Aug 22 09:39:41 2012 -0700"
      },
      "message": "manifest-format.txt: Fix a couple of minor spelling mistakes\n\nChange-Id: Ic2d266c8cf08827a71846db9d3711feb02885f01\n"
    },
    {
      "commit": "a43f42f9ffed69ee807852230e514b7c4bff5855",
      "tree": "14779d2ed495d0d06a080ba261ec8caced24bd43",
      "parents": [
        "bb8337fe0fbdd27c91ca0208f9492cf7bf738af0"
      ],
      "author": {
        "name": "David Pursehouse",
        "email": "david.pursehouse@sonymobile.com",
        "time": "Tue Aug 21 16:26:07 2012 +0900"
      },
      "committer": {
        "name": "Gustaf Lundh",
        "email": "gustaf.lundh@sonymobile.com",
        "time": "Tue Aug 21 14:06:10 2012 +0200"
      },
      "message": "Patches should be submitted to master, not maint\n\nUpdate SUBMITTING_PATCHES accordingly.\n\nChange-Id: I6fd57a84c67d3762f1f23276d95cac2aeecd5e8f\n"
    },
    {
      "commit": "bb8337fe0fbdd27c91ca0208f9492cf7bf738af0",
      "tree": "0ae1dffe2eed0bd32b89ab126de70562661593b3",
      "parents": [
        "17f85eab24739c2982bf0613a13b155f712e045d",
        "e7a3bcbbb8083e812ce07a5459f0e6d30edfb9fe"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Tue Aug 14 11:21:19 2012 -0700"
      },
      "committer": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Tue Aug 14 11:34:34 2012 -0700"
      },
      "message": "Merge branch \u0027master\u0027 into maint\n\nmaster\u0027s original purpose was to forge ahead on using git submodules,\nbut this route has been abandoned.\n\nChange-Id: I164a9efc7821bcd1b941ad76649764722046081b\n"
    },
    {
      "commit": "17f85eab24739c2982bf0613a13b155f712e045d",
      "tree": "0ae1dffe2eed0bd32b89ab126de70562661593b3",
      "parents": [
        "b9477bc2dd8ef1e931f208733976c56a0f2344a3"
      ],
      "author": {
        "name": "Dmitry Fink",
        "email": "dmitry@finik.net",
        "time": "Mon Aug 06 14:52:29 2012 -0700"
      },
      "committer": {
        "name": "gerrit code review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Tue Aug 07 11:42:54 2012 -0700"
      },
      "message": "Omit all default groups when generating a manifest\n\nOne of the recent changes introduced implicit path:xxx and name:xxx groups\nto every project, however they are not being stripped when generating\na manifest using \"repo manifest\" command resulting in clutter\n\nChange-Id: Iec8610ba794b2fe4a6cdf0f59ca561595b66f9b5\n"
    },
    {
      "commit": "b9477bc2dd8ef1e931f208733976c56a0f2344a3",
      "tree": "02351b9af113f854c9b5e84c5f6567d78c40d06b",
      "parents": [
        "5e7127d00baf5bdad3e52cf8784c8aaa736395e1"
      ],
      "author": {
        "name": "Mickaël Salaün",
        "email": "mic@digikod.net",
        "time": "Sun Aug 05 13:39:26 2012 +0200"
      },
      "committer": {
        "name": "Mickaël Salaün",
        "email": "mic@digikod.net",
        "time": "Mon Aug 06 23:51:43 2012 +0200"
      },
      "message": "project.py: Replace the relpath function with os.path.relpath\n\nChange-Id: Ib313340344968211cecfc0a718f6072e41da1a91\n"
    },
    {
      "commit": "5e7127d00baf5bdad3e52cf8784c8aaa736395e1",
      "tree": "b28b86ba1eb092483d0f5e02f73e6532a167e8c9",
      "parents": [
        "5d0efdb14a31d651a0f6061ffb73452a20b7ed77"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu Aug 02 14:57:37 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu Aug 02 15:18:10 2012 -0700"
      },
      "message": "Use curl command line tool for clone.bundle\n\nurllib2 is not thread safe and may be causing sync to lock up or\nnot work correctly on various platforms. Instead use the command\nline curl program.\n\nChange-Id: I36eaf18bb4df089d26ea99d533cb015e7c616eb0\n"
    },
    {
      "commit": "5d0efdb14a31d651a0f6061ffb73452a20b7ed77",
      "tree": "a7c781f860bb675d88cfcc8708a28894aa761229",
      "parents": [
        "f35b2d9c31f62a488a0d470f269c85cda5b02d72"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu Aug 02 12:13:01 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu Aug 02 12:13:01 2012 -0700"
      },
      "message": "sync: Honor --no-clone-bundle with -j1\n\nChange-Id: I7c12902e386121a374d525be673092360c67c53d\n"
    },
    {
      "commit": "f35b2d9c31f62a488a0d470f269c85cda5b02d72",
      "tree": "64b0e9105d915467be2a130f8e8848bcd66c4b54",
      "parents": [
        "e0904f721b51fb1f3f11fb4755e476d759b7b3e3"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu Aug 02 11:46:22 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu Aug 02 11:46:22 2012 -0700"
      },
      "message": "Fix mirror mode\n\nChange-Id: Ica0e8392562a7ae5aad7e45441c1540e5e2b0238\n"
    },
    {
      "commit": "e0904f721b51fb1f3f11fb4755e476d759b7b3e3",
      "tree": "3fe7b7c3826fbf7cf913551f759c4f1612c3b36d",
      "parents": [
        "9830553748a2a4a1930361b41a1076dbaa6d9f4a"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Aug 01 20:44:23 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Aug 01 20:44:23 2012 -0700"
      },
      "message": "Fix unsupported operand type(s) for +: \u0027int\u0027 and \u0027str\u0027\n\nChange-Id: I88455107d63daaa60c3b33c010aa8c730a590c70\n"
    },
    {
      "commit": "9830553748a2a4a1930361b41a1076dbaa6d9f4a",
      "tree": "c98e7b66c28c1cef5648b917b1a2311de9e61acc",
      "parents": [
        "2bc7f5cb3af981d673b44ce9a1ff5a272535def6"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Aug 01 17:41:26 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Aug 01 17:41:26 2012 -0700"
      },
      "message": "Fix percent done on resumed /clone.bundle\n\nThe Content-Length when resuming is the number of bytes that\nremain in the file. To compute the total size as expected by\nthe progress meter, we must add the bytes already stored.\n\nWhile we are in this method fix uses of % operator to ensure\na tuple is always supplied.\n\nChange-Id: Ic899231b5bc0ab43b3ddb1d29845f6390e820115\n"
    },
    {
      "commit": "2bc7f5cb3af981d673b44ce9a1ff5a272535def6",
      "tree": "ef9e474c5edde414a226cb26acf72a98807322ed",
      "parents": [
        "b292b98c3e9a9f666ca780ba60fdb4f306eca343"
      ],
      "author": {
        "name": "Chad Jones",
        "email": "chadj@google.com",
        "time": "Thu Jun 28 13:12:13 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jul 31 22:18:47 2012 -0700"
      },
      "message": "Fix bug in version_tuple to handle strings with -rc#\n\nExample of version string that caused a problem: git version 1.7.11-rc3\n\nChange-Id: I8a68b6b37f7b2ded23a1f8ae0d12131050a8807b\nCC: sop@google.com\n"
    },
    {
      "commit": "b292b98c3e9a9f666ca780ba60fdb4f306eca343",
      "tree": "75cea727be50c2e5b86d5c0fa62baae379315bf7",
      "parents": [
        "2f127de7520a0b689bfe5082360eeb53a05d6e2d"
      ],
      "author": {
        "name": "Yestin Sun",
        "email": "sunyi0804@gmail.com",
        "time": "Mon Jul 02 07:32:50 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jul 31 22:13:13 2012 -0700"
      },
      "message": "Add remote alias support in manifest\n\nThe `alias` is an optional attribute in element `remote`. It can be\nused to override attibute `name` to be set as the remote name in each\nproject\u0027s .git/config. Its value can be duplicated while attribute\n`name` has to be unique across the manifest file. This helps each\nproject to be able to have same remote name which actually points\nto different remote url.\n\nIt eases some automation scripts to be able to checkout/push to same\nremote name but actually different remote url, like:\n\nrepo forall -c \"git checkout -b work same_remote/work\"\nrepo forall -c \"git push same_remote work:work\"\n\nfor example:\nThe manifest with \u0027alias\u0027 will look like:\n\n\u003c?xml version\u003d\u00271.0\u0027 encoding\u003d\u0027UTF-8\u0027?\u003e\n\u003cmanifest\u003e\n  \u003cremote alias\u003d\"same_alias\" fetch\u003d\"git://git.external1.org/\" name\u003d\"ext1\"\n      review\u003d\"http://review.external1.org\"/\u003e\n  \u003cremote alias\u003d\"same_alias\" fetch\u003d\"git://git.external2.org/\" name\u003d\"ext2\"\n      review\u003d\"http://review.external2.org\"/\u003e\n  \u003cremote alias\u003d\"same_alias\" fetch\u003d\"ssh://git.internal.com:29418\" name\u003d\"int\"\n      review\u003d\"http://review.internal.com\"/\u003e\n  \u003cdefault remote\u003d\"int\" revision\u003d\"int-branch\" sync-j\u003d\"2\"/\u003e\n  \u003cproject name\u003d\"path/to/project1\" path\u003d\"project1\" remote\u003d\"ext1\"/\u003e\n  \u003cproject name\u003d\"path/to/project2\" path\u003d\"project2\" remote\u003d\"ext2\"/\u003e\n  \u003cproject name\u003d\"path/to/project3\" path\u003d\"project3\"/\u003e\n  ...\n\u003c/manifest\u003e\n\nIn each project, use command \"git remote -v\"\n\nproject1:\nsame_alias  git://git.external1.org/project1 (fetch)\nsame_alias  git://git.external1.org/project1 (push)\n\nproject2:\nsame_alias  git://git.external2.org/project2 (fetch)\nsame_alias  git://git.external2.org/project2 (push)\n\nproject3:\nsame_alias  ssh://git.internal.com:29418/project3 (fetch)\nsame_alias  ssh://git.internal.com:29418/project3 (push)\n\nChange-Id: I2c48263097ff107f0c978f3e83966ae71d06cb90\n"
    },
    {
      "commit": "2f127de7520a0b689bfe5082360eeb53a05d6e2d",
      "tree": "00613e764af267a5c1636c04cb5597f0d4beec9e",
      "parents": [
        "7da1314e38a2bb2941511c9003fa388eddb55c0a"
      ],
      "author": {
        "name": "Joe Hansche",
        "email": "jhansche@myyearbook.com",
        "time": "Mon Jul 09 12:59:56 2012 -0400"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jul 31 22:08:32 2012 -0700"
      },
      "message": "Add \"repo overview\" command.\n\nThe overview command shows an overview of each branch in all (or the\nspecified) projects.  The overview lists any local commits that have\nnot yet been merged into the project.\n\nThe report output is inspired by the report displayed following a\n\"repo prune\" event, with the addition of listing the one-line log\nmessages for each commit that is not yet merged.\n\nThe report can also be filtered to show only active branches; by\ndefault all branches that have commits beyond the upstream HEAD will\nbe listed.\n\nChange-Id: Ibe67793991ad1aa38de3bc9747de4ba64e5591aa\n"
    },
    {
      "commit": "7da1314e38a2bb2941511c9003fa388eddb55c0a",
      "tree": "21eb19cb1edb13fc0931fbef074d3dd36e5dc7ba",
      "parents": [
        "435370c6f0e202378ae233cf1088e499ba07e971"
      ],
      "author": {
        "name": "Brian Harring",
        "email": "ferringb@chromium.org",
        "time": "Fri Jun 15 02:24:20 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jul 31 22:05:44 2012 -0700"
      },
      "message": "Inject the project name into each projects groups.\n\nFor CrOS, we have scenarios were people checkout a smaller version\nof our manifest via groups, and enable individual repositories as\nneeded for their work.  Previously this was via local_manifest\nmanipulation, which breaks via manifest-groups would require a\nremove-project tag.\n\nVia injecting the projects name into the projects groups, this\nallows us to instead manipulate the configured groups allowing\nthe user to turn on/off projects as necessary.\n\nChange-Id: I07b7918e16cc9dc28eb47e19a46a04dc4fd0be74\n"
    },
    {
      "commit": "435370c6f0e202378ae233cf1088e499ba07e971",
      "tree": "17ef58db736d091ad62b54db0c7169b964ccb95e",
      "parents": [
        "e8f75fa3687bfe894a4fa8e59881b7d9170d8a41"
      ],
      "author": {
        "name": "Brian Harring",
        "email": "ferringb@chromium.org",
        "time": "Sat Jul 28 15:37:04 2012 -0700"
      },
      "committer": {
        "name": "Brian Harring",
        "email": "ferringb@google.com",
        "time": "Sat Jul 28 15:44:05 2012 -0700"
      },
      "message": "upload: add --draft option.\n\nChange-Id: I6967ff2f8163cd4116027b3f15ddb36875942af4\n"
    },
    {
      "commit": "e8f75fa3687bfe894a4fa8e59881b7d9170d8a41",
      "tree": "e43b915e9336ddfad189c3855107831300a47257",
      "parents": [
        "87636f2ac2d8a10e7db3be7b5dd47097cc1084ce"
      ],
      "author": {
        "name": "Torne (Richard Coles)",
        "email": "torne@google.com",
        "time": "Fri Jul 20 15:32:19 2012 +0100"
      },
      "committer": {
        "name": "Torne (Richard Coles)",
        "email": "torne@google.com",
        "time": "Fri Jul 20 15:33:17 2012 +0100"
      },
      "message": "Don\u0027t delete the branch config when switching branches.\n\nThe fix for issue #46 in 5d016502ebc6 appears to break syncing in some\nsituations: the branch is deleted after the point where it\u0027s been\nconfigured, which deletes part of its configuration and causes the\nconfig to change each time you call `repo init`, alternating between a\nconfiguration that works and one that doesn\u0027t.\n\nInstead of deleting the branch with git branch -D, use git update-ref -d\nwhich just deletes the ref (to avoid the rebase) without touching the\nconfiguration for the branch that was set up during the first repo init.\n\nThis appears to ensure the config is left in a valid state all the time\nno matter what combination of repo init commands you run, without\nreintroducing the rebasing issue.\n\nChange-Id: Iaadaa6e56a46840bbc593fa5b35cb5b34cd3ce69\n"
    },
    {
      "commit": "87636f2ac2d8a10e7db3be7b5dd47097cc1084ce",
      "tree": "3a85dea53c22e8e98b5a1042be5311776ec7020e",
      "parents": [
        "337aee0a9c6714027ff4fa8659879b0710e2e6aa"
      ],
      "author": {
        "name": "Chad Jones",
        "email": "chadj@google.com",
        "time": "Thu Jun 14 16:53:40 2012 -0700"
      },
      "committer": {
        "name": "Chad Jones",
        "email": "chadj@google.com",
        "time": "Thu Jun 14 16:54:32 2012 -0700"
      },
      "message": "Fix for failures with repo upload for projects that have a SHA1 for a revision; instead use the default manifest revision\n\nChange-Id: Ie5ef5a45ed6b0ca1a52a550df3cd7bd72e745f5f\n"
    },
    {
      "commit": "337aee0a9c6714027ff4fa8659879b0710e2e6aa",
      "tree": "59eeac1d718f560ee7341794206f068a98bc2427",
      "parents": [
        "7cf1b36bcdc79c9239413e35b02dee54aa801a20"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Jun 13 10:40:46 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Jun 13 10:42:16 2012 -0700"
      },
      "message": "Single quote http.proxy in GIT_CONFIG_PARAMETERS\n\nGit requires the values in this environment variable to be\nsingle quoted. repo must wrap the expression into \u0027\u0027 before\nadding it to the environment.\n\nChange-Id: I20a1fb8772f9aa6e9fd5a0516c981c2ca020ef05\n"
    },
    {
      "commit": "7cf1b36bcdc79c9239413e35b02dee54aa801a20",
      "tree": "9b51d1cac514908b2a74c046e7e28b219d106342",
      "parents": [
        "5e57234ec619d0de930333a8dde3004d1dc575d6"
      ],
      "author": {
        "name": "Florian Vallee",
        "email": "florian.vallee@gmail.com",
        "time": "Thu Jun 07 17:11:42 2012 +0200"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Jun 13 10:36:17 2012 -0700"
      },
      "message": "Detach branch even when already on the latest revision using sync -d\n\nThis patch fixes repo behaviour when running sync -d with unmodified\ntopic branches.\n\nPrior to this patch sync -d would see the latest revision is already\nchecked out, thus staying on the branch. Since \"-d\" means detach we\nshould follow git\u0027s behaviour and actually detach from the branch in\nthat case.\n\nBasic test case - after a fresh repo init + sync -\n        * repo start --all testdetach\n        * repo sync -d\n        * repo status\n-\u003e status shows active topic branch \"testdetach\",\n   should show :\nnothing to commit (working directory clean)\n\nChange-Id: Ic1351e6b5721b76557a51ab09f9dd42c38a4b415\n"
    },
    {
      "commit": "5e57234ec619d0de930333a8dde3004d1dc575d6",
      "tree": "40f4eab3f13e5b4a1ca4ff3f501539ae63f44229",
      "parents": [
        "5d016502ebc68bc054d85c98c6cdb51e0b63a1f5"
      ],
      "author": {
        "name": "Joe Hansche",
        "email": "jhansche@myyearbook.com",
        "time": "Mon Mar 05 11:41:19 2012 -0500"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Jun 13 10:34:41 2012 -0700"
      },
      "message": "Support automatically stashing local modifications during repo-rebase.\n\nCurrently repo-rebase requires that all modifications be committed\nlocally before it will allow the rebase. In high-velocity environments,\nyou may want to just pull in newer code without explicitly creating\nlocal commits, which is typically achieved using git-stash.\n\nIf called with the --auto-stash command line argument, and it is\ndetermined that the current index is dirty, the local modifications\nare stashed, and the rebase continues.  If a stash was performed, that\nstash is popped once the rebase completes.\n\nNote that there is still a possibility that the git-stash pop will\nresult in a merge conflict.\n\nChange-Id: Ibe3da96f0b4486cb7ce8d040639187e26501f6af\n"
    },
    {
      "commit": "5d016502ebc68bc054d85c98c6cdb51e0b63a1f5",
      "tree": "da1b47c86049f771f2292c507de21064842809d7",
      "parents": [
        "475a47d531bfe5ad82ec104189075df72a3143b7"
      ],
      "author": {
        "name": "Florian Vallee",
        "email": "florian.vallee@gmail.com",
        "time": "Thu Jun 07 17:19:26 2012 +0200"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Jun 13 10:00:57 2012 -0700"
      },
      "message": "Fix switching manifest branches using repo init -b\n\nSee repo issue #46 :\n\thttps://code.google.com/p/git-repo/issues/detail?id\u003d46\n\nWhen using repo init -b on an already existing repository,\nthe next sync will try to rebase changes coming from the old manifest\nbranch onto the new, leading in the best case scenario to conflicts\nand in the worst case scenario to an incorrect \"mixed up\" manifest.\n\nThis patch fixes this by deleting the \"default\" branch in the local\nmanifest repository when the -d init switch is used, thus forcing\nrepo to perform a fresh checkout of the new manifest branch\n\nChange-Id: I379e4875ec5357d8614d1197b6afbe58f9606751\n"
    },
    {
      "commit": "475a47d531bfe5ad82ec104189075df72a3143b7",
      "tree": "db44a1646f6f02c2105bf7946359076cf1d0a864",
      "parents": [
        "62d0b10a7bea2aa5cb7593ff12d14c482a1a663c"
      ],
      "author": {
        "name": "Brian Harring",
        "email": "ferringb@google.com",
        "time": "Thu Jun 07 20:05:35 2012 -0700"
      },
      "committer": {
        "name": "Brian Harring",
        "email": "ferringb@google.com",
        "time": "Thu Jun 07 20:19:04 2012 -0700"
      },
      "message": "Restore include support.\n\nCalculation of where the include file lives was broken by 23acdd3f14\nsince it resulted in looking for the first include in .repo, rather\nthan .repo/manifests.\n\nWhile people can work around it via setting their includes to\nmanifests/\u003cinclude-target\u003e, that breaks down since each layer of\nincludes would then have to be relative.\n\nAs such, restore the behaviour back to 2644874d; manifests includes\nare calculated relative to the manifest root (ie, .repo/manifests);\nlocal manifests includes are calculated relative to .repo/ .\n\nChange-Id: I74c19ba614c41d2f08cd3e9fd094f3c510e3bfd1\n"
    },
    {
      "commit": "62d0b10a7bea2aa5cb7593ff12d14c482a1a663c",
      "tree": "c03c28ee9e272f1349e135b0259ed919602e4484",
      "parents": [
        "d666e93ecc1f094774dfc7ba9ab0fd6e1695e976"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jun 05 15:11:15 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jun 05 15:11:15 2012 -0700"
      },
      "message": "Use GIT_CONFIG_PARAMETERS instead of -c for http.proxy\n\nAncient versions of Git don\u0027t understand the -c command line flag\nthat we tried to use to pass http_proxy down into Git on Darwin.\nUse the environment variable instead, to more gracefully degrade\nwith these old versions.\n\nChange-Id: Iffffa32088c1fd803895b990b3377ecfec6a1b14\n"
    },
    {
      "commit": "d666e93ecc1f094774dfc7ba9ab0fd6e1695e976",
      "tree": "7d38d7a867a8d70805d57f483fce2b5c47376073",
      "parents": [
        "3f61950f01bac9a3c40d9a6a95f53b6864153bfa"
      ],
      "author": {
        "name": "Anthony Russello",
        "email": "arussello@gmail.com",
        "time": "Fri Jun 01 00:48:22 2012 -0400"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jun 05 08:01:29 2012 -0700"
      },
      "message": "repo: Add option review.URL.uploadtopic support\n\nThis patch adds the option to include topic branches by adding the\nfollowing to a .gitconfig file:\n\n    uploadtopic \u003d true\n\nThis option is only read in when the -t option is not already\nspecified at the command line.\n\nChange-Id: I0e0eea49438bb4e4a21c2ac5bd498b68b5a9a845\n"
    },
    {
      "commit": "3f61950f01bac9a3c40d9a6a95f53b6864153bfa",
      "tree": "eb1339f0d47a489de3a98b186bcaf4bfbea5f4f0",
      "parents": [
        "4fd38ecc3ae6ce004b59ffe6545918495080e165"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jun 05 07:57:24 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jun 05 07:57:24 2012 -0700"
      },
      "message": "Use gerrit.googlesource.com/git-repo as the default URL\n\nThis is basically the same repository, but may be slightly more\nup-to-date than the one on code.google.com/p/git-repo.\n\nChange-Id: I5c99539f53231958eefb6993f00997c9adf0a3c9\n"
    },
    {
      "commit": "4fd38ecc3ae6ce004b59ffe6545918495080e165",
      "tree": "130140de974400ce213b76b5814b36b40f819e38",
      "parents": [
        "9fae805e0421aa4caf1e0a9052f8701a88d7bd0d"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jun 05 07:55:07 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Jun 05 07:56:09 2012 -0700"
      },
      "message": "Detect git is not installed\n\nFix detection for Git not being in $PATH during the initial\nrun of `repo init` in a new directory.\n\nChange-Id: I2b1fcce1fb8afc47271f5c3bd2a28369009b2fb7\n"
    },
    {
      "commit": "9fae805e0421aa4caf1e0a9052f8701a88d7bd0d",
      "tree": "fe1b867c58618ee8a25b833f18d2f22a189499ee",
      "parents": [
        "6a927c5d1990a9391242baa00c5ac71490c50c28"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Fri May 25 07:57:44 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Fri May 25 08:21:37 2012 -0700"
      },
      "message": "Pass http_proxy as -c http.proxy on Mac OS X\n\nThe system libcurl library seems to ignore http_proxy on Mac OS\nX systems. Copy the http_proxy environment variable (if set) as\n`git -c http.proxy` whenever running a Git command.\n\nChange-Id: I0ab29336897178f70b85092601f9fcc306dd17e1\n"
    },
    {
      "commit": "6a927c5d1990a9391242baa00c5ac71490c50c28",
      "tree": "78e93bbfe8efa4cd0f10edc69dbc01d559407d89",
      "parents": [
        "eca119e5d6f0aa61cad6be1421aa523482e9cde7"
      ],
      "author": {
        "name": "Brian Harring",
        "email": "ferringb@chromium.org",
        "time": "Fri May 25 02:21:06 2012 -0700"
      },
      "committer": {
        "name": "Brian Harring",
        "email": "ferringb@chromium.org",
        "time": "Fri May 25 02:25:59 2012 -0700"
      },
      "message": "hooks/pre-auto-gc: look in sysfs to see if a battery is known.\n\nBarring any kernel bugs, if this directory exists and there is\na symlink in there (which will point to the battery object),\nthat means there is a battery known to the kernel.\n\nNo symlink should mean no battery as far as the kernel is concerned.\n\nChange-Id: Ib12819a5bbb816f0ae5ca080e5812a2db08441e9\n"
    },
    {
      "commit": "eca119e5d6f0aa61cad6be1421aa523482e9cde7",
      "tree": "8a89308ba0e76e8922676351333d77afacdcaf49",
      "parents": [
        "6ba6ba0ef3ae4de384d931a50ec25e675e3aab16"
      ],
      "author": {
        "name": "Colin Cross",
        "email": "ccross@android.com",
        "time": "Thu May 24 15:39:14 2012 -0700"
      },
      "committer": {
        "name": "Colin Cross",
        "email": "ccross@android.com",
        "time": "Thu May 24 15:40:05 2012 -0700"
      },
      "message": "Allow projects with groups\u003dNone\n\nMirror manifest and repo projects are outside the manifest and\nhave no groups.  Allow project groups to be None for these\nprojects.\n\nChange-Id: I3e1c4add894fe1c43aa4e77a1fc1558aa10dd191\n"
    },
    {
      "commit": "6ba6ba0ef3ae4de384d931a50ec25e675e3aab16",
      "tree": "a570790f94d09ba475bc5f1b4a74462b6e409259",
      "parents": [
        "23acdd3f1460bc1c040b319940c5e0e8a78f1040"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu May 24 09:46:50 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu May 24 09:46:50 2012 -0700"
      },
      "message": "Fix initial sync broken by sync-c option\n\nChange-Id: I308753da8944e6ce5c46e3bfee1bcd41d5b7e292\n"
    },
    {
      "commit": "23acdd3f1460bc1c040b319940c5e0e8a78f1040",
      "tree": "85709c15416db6717cdff2025cc1aacc438c7ce9",
      "parents": [
        "2644874d9d3e6c16299a01acddf66cd99fd43414"
      ],
      "author": {
        "name": "Colin Cross",
        "email": "ccross@android.com",
        "time": "Sat Apr 21 00:33:54 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu May 24 09:32:15 2012 -0700"
      },
      "message": "Parse manifest and local_manifest together\n\nCombine manifest and local_manifest into a single list of elements\nbefore parsing.  This will allow elements in the local_manifest to\naffect elements in the main manifest.\n\nChange-Id: I4d34c9260b299a76be2960b07c0c3fe1af35f33c\n"
    },
    {
      "commit": "2644874d9d3e6c16299a01acddf66cd99fd43414",
      "tree": "bd2e86186a48a22286c6e919758d7edf366bda9a",
      "parents": [
        "3d125940f6223efe62e35b795f57e7e717b4528e"
      ],
      "author": {
        "name": "Brian Harring",
        "email": "brian.harring@intel.com",
        "time": "Thu Apr 28 05:04:41 2011 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu May 24 09:07:24 2012 -0700"
      },
      "message": "ManifestXml: add include support\n\nHaving the ability to include other manifests is a very practical feature\nto ease the managment of manifest. It allows to divide a manifest into separate\nfiles, and create different environment depending  on what we want to release\n\nYou can have unlimited recursion of include, the manifest configs will simply be concatenated\nas if it was in a single file.\n\ncommand \"repo manifest\" will create a single manifest, and not recreate the manifest hierarchy\n\nfor example:\nOur developement manifest will look like:\n\n\u003c?xml version\u003d\u00271.0\u0027 encoding\u003d\u0027UTF-8\u0027?\u003e\n\u003cmanifest\u003e\n  \u003cdefault revision\u003d\"platform/android/main\" remote\u003d\"intel\"/\u003e\n  \u003cinclude name\u003d\"server.xml\"/\u003e \u003c!-- The Server configuration --\u003e\n  \u003cinclude name\u003d\"aosp.xml\" /\u003e  \u003c!-- All the AOSP projects --\u003e\n  \u003cinclude name\u003d\"bsp.xml\" /\u003e   \u003c!-- The BSP projects that we release in source form --\u003e\n  \u003cinclude name\u003d\"bsp-priv.xml\" /\u003e \u003c!-- The source of the BSP projects we release in binary form --\u003e\n\u003c/manifest\u003e\n\nOur release manifest will look like:\n\n\u003c?xml version\u003d\u00271.0\u0027 encoding\u003d\u0027UTF-8\u0027?\u003e\n\u003cmanifest\u003e\n  \u003cdefault revision\u003d\"platform/android/release-ext\" remote\u003d\"intel\"/\u003e\n  \u003cinclude name\u003d\"server.xml\"/\u003e \u003c!-- The Server configuration --\u003e\n  \u003cinclude name\u003d\"aosp.xml\" /\u003e  \u003c!-- All the AOSP projects --\u003e\n  \u003cinclude name\u003d\"bsp.xml\" /\u003e   \u003c!-- The BSP projects that we release in source form --\u003e\n  \u003cinclude name\u003d\"bsp-ext.xml\" /\u003e \u003c!-- The PREBUILT version of the BSP projects we release in binary form --\u003e\n\u003c/manifest\u003e\n\nAnd it is also easy to create and maintain feature branch with a manifest that looks like:\n\n\u003c?xml version\u003d\u00271.0\u0027 encoding\u003d\u0027UTF-8\u0027?\u003e\n\u003cmanifest\u003e\n  \u003cdefault revision\u003d\"feature_branch_foobar\" remote\u003d\"intel\"/\u003e\n  \u003cinclude name\u003d\"server.xml\"/\u003e \u003c!-- The Server configuration --\u003e\n  \u003cinclude name\u003d\"aosp.xml\" /\u003e  \u003c!-- All the AOSP projects --\u003e\n  \u003cinclude name\u003d\"bsp.xml\" /\u003e   \u003c!-- The BSP projects that we release in source form --\u003e\n  \u003cinclude name\u003d\"bsp-priv.xml\" /\u003e \u003c!-- The source of the BSP projects we release in binary form --\u003e\n\u003c/manifest\u003e\n\nSigned-off-by: Brian Harring \u003cbrian.harring@intel.com\u003e\nSigned-off-by: Pierre Tardy \u003cpierre.tardy@intel.com\u003e\nChange-Id: I833a30d303039e485888768e6b81561b7665e89d\n"
    },
    {
      "commit": "3d125940f6223efe62e35b795f57e7e717b4528e",
      "tree": "518bdd11c5cd3e5f57afdf16a3e1fe3ec1df8370",
      "parents": [
        "a94f162b9fe85389f3e1c9555628d9229105e15d"
      ],
      "author": {
        "name": "Pierre Tardy",
        "email": "pierre.tardy@intel.com",
        "time": "Fri May 04 12:18:12 2012 +0200"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu May 24 09:04:20 2012 -0700"
      },
      "message": "repo download: add --ff-only option\n\nAllows to ff-only a gerrit patch\nThis patch is necessary to automatically ensure that the patch will\nbe correctly submitted on ff-only gerrit projects\n\nYou can now use:\nrepo download (--ff-only|-f) project changeid/patchnumber\n\nThis is useful to automate verification of fast forward status of a patch\nin the context of build automation, and commit gating (e.g. buildbot)\n\nChange-Id: I403a667557a105411a633e62c8eec23d93724b43\nSigned-off-by: Erwan Mahe \u003cerwan.mahe@intel.com\u003e\nSigned-off-by: Pierre Tardy \u003cpierre.tardy@intel.com\u003e\n"
    },
    {
      "commit": "a94f162b9fe85389f3e1c9555628d9229105e15d",
      "tree": "da3852d6ede787a8d1974cddab3db8c98e4fc39e",
      "parents": [
        "e5a2122e6429b5eee861807e7050eb02045a7d4f"
      ],
      "author": {
        "name": "Erwan Mahe",
        "email": "erwan.mahe@intel.com",
        "time": "Fri Aug 19 13:56:09 2011 +0200"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu May 24 09:03:10 2012 -0700"
      },
      "message": "repo download: add --revert option\n\nBZ: 4779\nAllows to revert a gerrit patch\nThis patch is necessary for the on-demand creation of\nengineering builds using buildbot\n\nYou can now use:\nrepo download [--revert|-r project changeid/patchnumber\n\nThis is useful to automate reverting of a patch\nin the context of build automation, and regression bisection\n\nChange-Id: I3985e80e4b2a230f83526191ea1379765a54bdcf\nSigned-off-by: Erwan Mahe \u003cerwan.mahe@intel.com\u003e\nSigned-off-by: Pierre Tardy \u003cpierre.tardy@intel.com\u003e\n"
    },
    {
      "commit": "e5a2122e6429b5eee861807e7050eb02045a7d4f",
      "tree": "b58878391a4a6a80bdda7edf096d22cff8b7f1c4",
      "parents": [
        "ccf86432b39ce2506fca472bbdbe379fdc53d3e3"
      ],
      "author": {
        "name": "Pierre Tardy",
        "email": "pierre.tardy@intel.com",
        "time": "Thu Mar 24 16:28:18 2011 +0100"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu May 24 09:02:38 2012 -0700"
      },
      "message": "repo download: add --cherry-pick option\n\ndefault option uses git checkout, and thus overwrite the previous\ncheckouts.  this is a problem for automated builds of several\nchangesets in the same project for daily builds of pending submission\n\nYou can now use:\nrepo download [--cherry-pick|-c] project changeid/patchnumber\n\nThis will parse the manifest, cd to the corresponding project\ndownload the changes to FETCH_HEAD and cherry-pick the result.\n\nThis is useful to automate cherry-picking of a patch\nin the context of build automation, and commit gating (e.g. buildbot)\n\nChange-Id: Ib638afd87677f1be197afb7b0f73c70fb98909fe\nSigned-off-by: Pierre Tardy \u003cpierre.tardy@intel.com\u003e\n"
    },
    {
      "commit": "ccf86432b39ce2506fca472bbdbe379fdc53d3e3",
      "tree": "8066007b25cc9b245add60ca08055ee0bb09b91b",
      "parents": [
        "79770d269e319dee578beed682669703d4c764ba"
      ],
      "author": {
        "name": "Cezary Baginski",
        "email": "cezary.baginski@gmail.com",
        "time": "Mon Apr 23 23:55:35 2012 +0200"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu May 24 08:58:10 2012 -0700"
      },
      "message": "Avoid failing concat for multi-encoding filenames\n\nrepo status should output filenames one by one instead of trying to\nbuild a string from incompatible encodings (like utf-8 and sjis\nfilenames)\n\nChange-Id: I52282236ececa562f109f9ea4b2e971d2b4bc045\n"
    },
    {
      "commit": "79770d269e319dee578beed682669703d4c764ba",
      "tree": "23e733be2bf80454de9352225366b92ef5cc9139",
      "parents": [
        "c39864f5e12fa4a6d3f2cdb4921afc021406d106"
      ],
      "author": {
        "name": "Anatol Pomazau",
        "email": "anatol@google.com",
        "time": "Fri Apr 20 14:41:59 2012 -0700"
      },
      "committer": {
        "name": "Anatol Pomazau",
        "email": "anatol@google.com",
        "time": "Mon Apr 23 14:10:52 2012 -0700"
      },
      "message": "Add sync-c option to manifest\n\nThere are use-cases when fetching all branch is impractical and\nwe really need to fetch only one branch/tag.\ne.g. there is a large project with binaries and every update of a\nbinary file is put to a separate branch.\nThe whole project history might be too large to allow users fetch it.\n\nAdd \u0027sync-c\u0027 option to \u0027project\u0027 and \u0027default\u0027 tags to make it possible\nto configure \u0027sync-c\u0027 behavior at per-project and per-manifest level.\n\nNote that currently there is no possibility to revert boolean flag from\ncommand line. If \u0027sync-c\u0027 is set in manifest then you cannot make\nfull fetch by providing a repo tool argument.\n\nChange-Id: Ie36fe5737304930493740370239403986590f593\n"
    },
    {
      "commit": "c39864f5e12fa4a6d3f2cdb4921afc021406d106",
      "tree": "b8e5749072fb6e08c2f2f6f019aeb7532a1cccb3",
      "parents": [
        "5465727e538bcd77200f8b3c75f002367597fc51"
      ],
      "author": {
        "name": "Colin Cross",
        "email": "ccross@android.com",
        "time": "Mon Apr 23 13:41:58 2012 -0700"
      },
      "committer": {
        "name": "Colin Cross",
        "email": "ccross@android.com",
        "time": "Mon Apr 23 13:43:41 2012 -0700"
      },
      "message": "Treat groups\u003d as default\n\nPrevious incarnations of groups support left \"groups\u003d\" in the\nrepo .config, which is now treated as \"delete all the projects\".\nTreat empty groups configuration the same as no groups\nconfiguration.\n\nChange-Id: I57dab8dac55bdbf4cc181e2748cd2e4e510764f5\n"
    },
    {
      "commit": "5465727e538bcd77200f8b3c75f002367597fc51",
      "tree": "51f376719b489eb25b57dc3fd88da116af99a53c",
      "parents": [
        "d21720db313369f25b99b4d2f3f87c8be46513d9"
      ],
      "author": {
        "name": "Colin Cross",
        "email": "ccross@android.com",
        "time": "Mon Apr 23 13:39:48 2012 -0700"
      },
      "committer": {
        "name": "Colin Cross",
        "email": "ccross@android.com",
        "time": "Mon Apr 23 13:43:41 2012 -0700"
      },
      "message": "Fix syntax errors in subcmds/init.py\n\nFixes three errors:\nPython doesn\u0027t like the line wrap after \u0027and\u0027.\nplatform.system is a function, needs to be platform.system().\nTypo all_platfroms instead of all_platforms.\n\nChange-Id: Ia875e521bc01ae2eb321ec62d839173c00f86c2d\n"
    },
    {
      "commit": "d21720db313369f25b99b4d2f3f87c8be46513d9",
      "tree": "a73e659e8fd18c7e3fc67880a1a9be8c2a409c86",
      "parents": [
        "971de8ea7b7e474a4d9253b6c9f47da3f1130973"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Mon Apr 16 11:02:21 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Mon Apr 23 12:50:00 2012 -0700"
      },
      "message": "Add a --platform flag\n\nProjects may optionally specify their platform\n(eg, groups\u003d\"platform-linux\" in the manifest).\n\nBy default, repo will automatically detect the platform. However,\nusers may specify --platform\u003d[auto|all|linux|darwin].\n\nChange-Id: Ie678851fb2fec5b0938aede01f16c53138a16537\n"
    },
    {
      "commit": "971de8ea7b7e474a4d9253b6c9f47da3f1130973",
      "tree": "d8ac52741957b38d57d15f208e57b984d71ddc19",
      "parents": [
        "24c130884018364f91baa8de0ff3541f4c32d1bb"
      ],
      "author": {
        "name": "Conley Owens",
        "email": "cco3@android.com",
        "time": "Mon Apr 16 10:36:08 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Mon Apr 23 12:39:05 2012 -0700"
      },
      "message": "Refine groups functionality\n\nEvery project is in group \"default\".  \"-default\" does not remove\nit from this project.  All group names specified in the manifest\nare positive names as opposed to a mix of negative and positive.\n\nSpecified groups are resolved in order.  If init is supplied with\n--groups\u003d\"group1,-group2\", the following describes the project\nselection when syncing:\n\n  * all projects in \"group1\" will be added, and\n  * all projects in \"group2\" will be removed.\n\nChange-Id: I1df3dcdb64bbd4cd80d675f9b2d3becbf721f661\n"
    },
    {
      "commit": "24c130884018364f91baa8de0ff3541f4c32d1bb",
      "tree": "213b269d05e2a5f2b70d895325301a9a9f30e4a2",
      "parents": [
        "b962a1f5e0daad323bdd66fad93f00a3738cc255"
      ],
      "author": {
        "name": "James W. Mills",
        "email": "jameswmills@gmail.com",
        "time": "Thu Apr 12 15:04:13 2012 -0500"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Mon Apr 23 12:35:08 2012 -0700"
      },
      "message": "Add project annotation handling to repo\n\nAllow the optional addition of \"annotation\" nodes nested under\nprojects.  Each annotation node must have \"name\" and \"value\"\nattributes.  These name/value pairs will be exported into the\nenvironment during any forall command, prefixed with \"REPO__\"\n\nIn addition, an optional \"keep\" attribute with case insensitive \"true\"\nor \"false\" values can be included to determine whether the annotation\nwill be exported with \u0027repo manifest\u0027\n\nChange-Id: Icd7540afaae02c958f769ce3d25661aa721a9de8\nSigned-off-by: James W. Mills \u003cjameswmills@gmail.com\u003e\n"
    },
    {
      "commit": "b962a1f5e0daad323bdd66fad93f00a3738cc255",
      "tree": "aa93a22bdec6f982cfee5c3ab5d1f5361f7bd9e9",
      "parents": [
        "5acde75e5d70b323197ffb2c9d4fdea3612098f5"
      ],
      "author": {
        "name": "Anatol Pomazau",
        "email": "anatol@google.com",
        "time": "Thu Mar 29 18:06:43 2012 -0700"
      },
      "committer": {
        "name": "Anatol Pomazau",
        "email": "anatol@google.com",
        "time": "Mon Apr 23 11:09:17 2012 -0700"
      },
      "message": "Check if SHA1 presents in repository\n\nPreviously repo had incorrect code that did not really check\nif sha1 presents in a project. It worked for tags though.\n\nCheck if a revision (either tag or sha1) is present by using\n\u0027git rev_parse\u0027 functionality.\n\nChange-Id: I1787f3348573948573948753987394839487572b\n"
    },
    {
      "commit": "5acde75e5d70b323197ffb2c9d4fdea3612098f5",
      "tree": "e995a64614ce7406633ae6e99c2a0e6f86872e09",
      "parents": [
        "d67872d2f47b2f09a0e2aa4adfd62e6f69154c9b"
      ],
      "author": {
        "name": "Colin Cross",
        "email": "ccross@android.com",
        "time": "Wed Mar 28 20:15:45 2012 -0700"
      },
      "committer": {
        "name": "Shawn Pearce",
        "email": "sop@google.com",
        "time": "Fri Apr 13 09:46:00 2012 -0700"
      },
      "message": "Add manifest groups\n\nAllows specifying a list of groups with a -g argument to repo init.\nThe groups act on a group\u003d attribute specified on projects in the\nmanifest.\nAll projects are implicitly labelled with \"default\" unless they are\nexplicitly labelled \"-default\".\nPrefixing a group with \"-\" removes matching projects from the list\nof projects to sync.\nIf any non-inverted manifest groups are specified, the default label\nis ignored.\n\nChange-Id: I3a0dd7a93a8a1756205de1d03eee8c00906af0e5\nReviewed-on: https://gerrit-review.googlesource.com/34570\nReviewed-by: Shawn Pearce \u003csop@google.com\u003e\nTested-by: Shawn Pearce \u003csop@google.com\u003e\n"
    },
    {
      "commit": "d67872d2f47b2f09a0e2aa4adfd62e6f69154c9b",
      "tree": "654e38712aec5961e0e628b8be95b260b7eb9c80",
      "parents": [
        "e9d6b611c5bec499360c175035770132f1e60c71"
      ],
      "author": {
        "name": "pelya",
        "email": "x.pelya.x@gmail.com",
        "time": "Wed Mar 28 14:49:58 2012 +0300"
      },
      "committer": {
        "name": "Shawn Pearce",
        "email": "sop@google.com",
        "time": "Fri Apr 13 09:20:10 2012 -0700"
      },
      "message": "Option for \u0027repo diff\u0027 to generate output suitable for \u0027patch\u0027 cmd\n\nThe -u option causes \u0027repo diff\u0027 to generate diff output\nwith file paths relative to the repository root,\nso the output can be applied to the Unix \u0027patch\u0027 command.\nThe name \u0027-u\u0027 was selected for convenience, because\nboth \u0027diff\u0027 and \u0027git diff\u0027 accept the option with the same name\nto generate an \u0027unified diff\u0027 output suitable for \u0027patch\u0027 command.\n\nChange-Id: I79c8356db4ed20ecaccc258b3ba139db76666fe0\nReviewed-on: https://gerrit-review.googlesource.com/34380\nReviewed-by: Shawn Pearce \u003csop@google.com\u003e\nTested-by: Shawn Pearce \u003csop@google.com\u003e\n"
    },
    {
      "commit": "e9d6b611c5bec499360c175035770132f1e60c71",
      "tree": "f20482b6545d436d9be3204e5e2d3afdddc2ccd5",
      "parents": [
        "c3d2f2b76f1f34703106031bdbcb6c34df81686c"
      ],
      "author": {
        "name": "Daniel Sandler",
        "email": "dsandler@android.com",
        "time": "Fri Apr 06 10:39:32 2012 -0400"
      },
      "committer": {
        "name": "Daniel Sandler",
        "email": "dsandler@android.com",
        "time": "Fri Apr 06 10:43:36 2012 -0400"
      },
      "message": "New flag for repo upload: --current_branch (--cbr)\n\nA convenient equivalent to `repo upload --br\u003d\u003ccurrent git branch\u003e`.\n\nNote that the head branch will be selected for each project\nuploaded by repo, so different branches may be uploaded for\ndifferent projects.\n\nChange-Id: I10ad8ceaa63f055105c2d847c6e329fa4226dbaf\n"
    },
    {
      "commit": "c3d2f2b76f1f34703106031bdbcb6c34df81686c",
      "tree": "af7b57c5e81512bcd7e3d7ab530069303c98fcfb",
      "parents": [
        "cd7c5deca0b0594bd8addd5a0fe18b962d2679e9"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu Mar 22 14:09:22 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Thu Mar 22 14:18:40 2012 -0700"
      },
      "message": "Ignore /clone.bundle on HTTP 401, 403 and 404\n\n401: Unauthorized, authentication may be required. This is usually\n     handled internally by the HTTP client in Python. If it reaches\n     our code in repo, the Python HTTP client didn\u0027t find a password\n     in ~/.netrc that it could use.\n\n403: Authentication was supplied, but is incorrect. It might be\n     that the CDN doesn\u0027t want to offer this clone.bundle file\n     to the client, but the Git fetch operation would still be\n     successful. This might arise if branch level read controls\n     were used in Gerrit Code Review and the /clone.bundle file\n     contained branches not visible to the client.\n\n404: The server has no /clone.bundle file available.\n\nIn all of these cases, sliently ignore the /clone.bundle file HTTP\nerror and let the Git operation take over.\n\nChange-Id: I1787f3cac86b017351952bbb793fe5874d83c72b\n"
    },
    {
      "commit": "cd7c5deca0b0594bd8addd5a0fe18b962d2679e9",
      "tree": "ec56d17e669c94bd297d8080f4f5bbb226a4841c",
      "parents": [
        "e02ac0af2e69f2c149de942d639bf305e5ae391a"
      ],
      "author": {
        "name": "Anatol Pomazau",
        "email": "anatol@google.com",
        "time": "Tue Mar 20 13:45:00 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Tue Mar 20 14:11:56 2012 -0700"
      },
      "message": "Do not change branch.foo.merge in case of manifest sync\n\nIn case of manifest/smart sync repo changes \".merge\" config\noption from branch to SHA. Doing \u0027repo upload\u0027 fails as\nrepo tries to upload to a remote branch that looks like SHA\n(e.g. refs/for/23423423423423423423423)\n\nDo not update the .merge in case if revision is SHA.\n\nChange-Id: I9139708fa17f21eec5a7e23c3255333626bf529e\n"
    },
    {
      "commit": "e02ac0af2e69f2c149de942d639bf305e5ae391a",
      "tree": "47da1f6f01e8429659ca10de890c9747c2a0e80a",
      "parents": [
        "898e12a2d9340706eca79e6c611166dfe35a1d3e"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Mar 14 15:36:59 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Mar 14 15:38:28 2012 -0700"
      },
      "message": "sync: --no-clone-bundle disables the clone bundle support\n\nChange-Id: Ia9ed7da8451b273c1be620c3dd0dcad777b29096\n"
    },
    {
      "commit": "898e12a2d9340706eca79e6c611166dfe35a1d3e",
      "tree": "f417382da1c4237825dc13b47194dd98ecd808f0",
      "parents": [
        "ae0a36c9a59e7f872578b17b3b7fa8f72df3cb59"
      ],
      "author": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Mar 14 15:22:28 2012 -0700"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Mar 14 15:28:22 2012 -0700"
      },
      "message": "Permit - in URL schemes for special URLs\n\nClients might be using their own special git-remote-* helper that\nhas a hypen in its name. Permit - in the scheme part of the URL\nwhen trying to decide if it is an SSH URL and assume it is *not*\nSSH if the URL matches \"foo-bar://\" style.\n\nChange-Id: I7ba2d810a614f6e605a441d5972902c4a14e73fd\n"
    },
    {
      "commit": "ae0a36c9a59e7f872578b17b3b7fa8f72df3cb59",
      "tree": "2cfb4182ad08064d001463aa5aa9079ab638f78a",
      "parents": [
        "76abcc1d1ea2da6cf0ce381486e2f9bf4ca55c36"
      ],
      "author": {
        "name": "Xiaodong Xu",
        "email": "stid.smth@gmail.com",
        "time": "Tue Jan 31 11:10:09 2012 +0800"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Wed Mar 14 15:01:34 2012 -0700"
      },
      "message": "Add support for Apache Digest authentication for repo init.\n\nrepo tool supports only Basic authentication for now. For those\nwho want to use this tool to manage their own projects, in case\nthe administrator has configured the Apache server with Digest\nauthentication method, users will fail to be authenticated when\nthey run the command \u0027repo init\u0027.\nAdd the digest authentication password manager to the handler\nlist will fix this issue.\n\nSince Git HTTP protocol will require the user be authenticated\nfor fetch operation first before pushing commits to the remote,\nit is unlikely for the administrator to implement anonymous\nread (aka pull) access and write access (aka push) for\nauthenticated user. Both read and write have to be authenticated.\nBe aware that the user may have to add an extra line in his\n~/.netrc file:\n-------------------\naccount example.com\n-------------------\nwhere \u0027example.com\u0027 is the realm for Apache Digest authentication.\n\nChange-Id: I76eb27b205554426d9ce1965deaaf727b87916cd\nSigned-off-by: Xiaodong Xu \u003cstid.smth@gmail.com\u003e\n"
    },
    {
      "commit": "76abcc1d1ea2da6cf0ce381486e2f9bf4ca55c36",
      "tree": "99bb142cb8baeb9f3b0210dee1457f854ea985ba",
      "parents": [
        "d3153825723b2bec3476e84f2e423c646fd4c598"
      ],
      "author": {
        "name": "Ali Utku Selen",
        "email": "aliutku.selen@sonyericsson.com",
        "time": "Wed Jan 25 10:51:12 2012 +0100"
      },
      "committer": {
        "name": "Shawn O. Pearce",
        "email": "sop@google.com",
        "time": "Mon Mar 12 12:25:40 2012 -0700"
      },
      "message": "repo status to print project name on clean gits\n\nrepo status just prints \"# on branch oprofile\" if you have branched\nin clean status. This doesn\u0027t really tell which branch is meant.\n\nInstead we can use the same syntax with modified gits which will\ngive us detailed information.\n\nChange-Id: I55fe5154d278e10a814281dd2ba501ec6e956730\n"
    }
  ],
  "next": "d3153825723b2bec3476e84f2e423c646fd4c598"
}
