)]}'
{
  "log": [
    {
      "commit": "2ea480cac89460ee2524cd080e90f6240e8eebf5",
      "tree": "819e7a2456acd7b6b851efd97361023b168c1562",
      "parents": [
        "2b9f9186fa4b4e336f9d889b66da757c985c2f04",
        "5d0b18cddfcb933d7960c5a6a820045d77a0285c"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Fri Nov 15 00:39:57 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Nov 15 00:39:57 2013 -0800"
      },
      "message": "am 5d0b18cd: am 3de885be: Merge \"Disallow applications from initiating cast screen.\" into klp-dev\n\n* commit \u00275d0b18cddfcb933d7960c5a6a820045d77a0285c\u0027:\n  Disallow applications from initiating cast screen.\n"
    },
    {
      "commit": "3de885bef2f0f85ea76fd96c8f18cdd743ce66a4",
      "tree": "c104583897d8b7ca33826b1b1172df764d7d617e",
      "parents": [
        "2785892dbf6c53b7e1a08596969bfcdf0148c8e9",
        "af574183c274f51d04487a9c8355e9f34a1150f2"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Fri Nov 15 08:35:50 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Nov 15 08:35:50 2013 +0000"
      },
      "message": "Merge \"Disallow applications from initiating cast screen.\" into klp-dev"
    },
    {
      "commit": "af574183c274f51d04487a9c8355e9f34a1150f2",
      "tree": "c325b02a379f86bc9d8eb42b0bb5d8b700cc80bb",
      "parents": [
        "1907c0d280d97776708810c9d24931aa6f818790"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Thu Nov 14 18:16:08 2013 -0800"
      },
      "committer": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Fri Nov 15 00:29:43 2013 -0800"
      },
      "message": "Disallow applications from initiating cast screen.\n\nOnly allow the system ui and settings to connect to a remote display.\nTo do this, we essentially hide the remote displays from applications\nby using the ROUTE_TYPE_REMOTE_DISPLAY then add permission checks\naround the operations that connect to them.\n\nAs a bonus, this may actually save power on devices since applications\nthat use MediaRouter will not longer be performing discover on\nremote display routes at all.\n\nBug: 11257292\nChange-Id: I9ea8c568df4df5a0f0cf3d0f11b39c87e2110795\n"
    },
    {
      "commit": "461febadc44190bf19e870a0bc1a706ec3667212",
      "tree": "79db72b35fad356edbc1ae8435d8934b19c2fb61",
      "parents": [
        "fa0211adc3a8bcc988f5a886e71aab1459f7435e",
        "64397749effa088dcea3799fc8440845c5a1c193"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Thu Nov 14 18:41:02 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 14 18:41:02 2013 -0800"
      },
      "message": "am 64397749: am 22010817: Merge \"Handle backup transport registration dynamically\" into klp-dev\n\n* commit \u002764397749effa088dcea3799fc8440845c5a1c193\u0027:\n  Handle backup transport registration dynamically\n"
    },
    {
      "commit": "22010817b90f97756a76777fcd1dbe7e3b63e808",
      "tree": "2eead3fac5e069223774cd730665eb77fd3edd24",
      "parents": [
        "1907c0d280d97776708810c9d24931aa6f818790",
        "cefba58d14f9669b57c16b4ea493779d882c43bd"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Fri Nov 15 02:34:37 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Nov 15 02:34:38 2013 +0000"
      },
      "message": "Merge \"Handle backup transport registration dynamically\" into klp-dev"
    },
    {
      "commit": "cefba58d14f9669b57c16b4ea493779d882c43bd",
      "tree": "a8b0799b5c642b0a4e671c3da6be477003ae51ac",
      "parents": [
        "a951fa56f1855cd0337bddacc01e35868c6d66d6"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Thu Nov 14 18:10:35 2013 -0800"
      },
      "committer": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Thu Nov 14 18:13:25 2013 -0800"
      },
      "message": "Handle backup transport registration dynamically\n\nBug 11369873\n\nChange-Id: I9bbdcc21ce25159c6645690123b5d03c553b0ddc\n"
    },
    {
      "commit": "a5acd62bdefe5b616c0ea080434e9dd221169527",
      "tree": "7e6ff24a50b1dd5a286b142e6aef621712533efe",
      "parents": [
        "8e9b5fc93278084487fd98726c6e20333d675c40",
        "6e5cf573f2f2e17825af2973daeba893c6aa5855"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Thu Nov 14 15:44:40 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 14 15:44:40 2013 -0800"
      },
      "message": "am 6e5cf573: am 99437f25: Merge \"Ensure recipient can be launched before attempting broadcast delivery\" into klp-dev\n\n* commit \u00276e5cf573f2f2e17825af2973daeba893c6aa5855\u0027:\n  Ensure recipient can be launched before attempting broadcast delivery\n"
    },
    {
      "commit": "8e9b5fc93278084487fd98726c6e20333d675c40",
      "tree": "d1d7059dcbd2b6bc31d9d000f3ba50e6097af9f7",
      "parents": [
        "0dcddb447c97d5220d21315de428079dada9bdcb",
        "59bf3be7d1cd7311cf60ead6872f33433a097bd1"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Nov 14 15:44:36 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 14 15:44:36 2013 -0800"
      },
      "message": "am 59bf3be7: am 2e3ede74: Merge \"Maybe fix issue #11634365: Leaking restarting services\" into klp-dev\n\n* commit \u002759bf3be7d1cd7311cf60ead6872f33433a097bd1\u0027:\n  Maybe fix issue #11634365: Leaking restarting services\n"
    },
    {
      "commit": "99437f252b728f4946940f232c4b73b9dda76cfb",
      "tree": "16fc09f101e0dfa8da5d792f1bc756b43b207a34",
      "parents": [
        "2e3ede74978d14f7bd853c3228864280d99a438e",
        "ba629da331d01d74067afdda5d4255682d4b24d7"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Thu Nov 14 22:59:20 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 14 22:59:20 2013 +0000"
      },
      "message": "Merge \"Ensure recipient can be launched before attempting broadcast delivery\" into klp-dev"
    },
    {
      "commit": "2e3ede74978d14f7bd853c3228864280d99a438e",
      "tree": "f17c652a881db1719749d59f088601f024bc712f",
      "parents": [
        "2a96fc1f516f7ac7fcbf5bd8c8c4fe8c7b2a8a7f",
        "ddc19e98476eec54da83b7386602443ed4aa195e"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Nov 14 22:56:14 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 14 22:56:14 2013 +0000"
      },
      "message": "Merge \"Maybe fix issue #11634365: Leaking restarting services\" into klp-dev"
    },
    {
      "commit": "ddc19e98476eec54da83b7386602443ed4aa195e",
      "tree": "578b150f185b3f03ec834fe715858562b9a17c9e",
      "parents": [
        "d6f5b629216a2566883ccc6f2506fee198b07f99"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Nov 14 14:32:17 2013 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Nov 14 14:32:17 2013 -0800"
      },
      "message": "Maybe fix issue #11634365: Leaking restarting services\n\nIt looks like we could add services to the restart list because\nthey end up left in the process\u0027s list of running services after\nthey have been removed from the main activity list, and we can\ntrip up on them there when the app is being force stopped.\n\nChange-Id: I79805b67fcf5b593430dc5c856c97927e1a54a57\n"
    },
    {
      "commit": "ba629da331d01d74067afdda5d4255682d4b24d7",
      "tree": "9c1044d486111af341585ca377e0877880e6aa88",
      "parents": [
        "a951fa56f1855cd0337bddacc01e35868c6d66d6"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Wed Nov 13 17:42:28 2013 -0800"
      },
      "committer": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Thu Nov 14 12:37:31 2013 -0800"
      },
      "message": "Ensure recipient can be launched before attempting broadcast delivery\n\nUser removal or eviction inherently races with broadcast delivery.  This\npatch introduces a latest-possible recheck of the availbility of the\ntarget application before attempting to send it a broadcast.\n\nOnce the process has actually been spun up the system is essentially\ncommitted to presenting it as a running application, and there is no\nlater check of the availability of the app: the failure mode for\ncontinuing to attempt delivery is a crash *in the app process*,\nand is user-visible.\n\nWe now check the app+userid existence of the intended recipient\njust prior to committing to launch its process for receipt, and\nif it is no longer available we simply skip that receiver and\ncontinue normally.\n\nBug 11652784\nBug 11272019\nBug 8263020\n\nChange-Id: Ib19ba2af493250890db7371c1a9f853772db1af0\n"
    },
    {
      "commit": "72402f9de7b108d77316e3c93399b07a2f98c42a",
      "tree": "71915600b082d30618247ea43e5143bbff7218b4",
      "parents": [
        "d1b0af82855528c531a35d28d3c65d7a94f2228c",
        "09d8e3cf4e411b016ee65d8328dd7a443c9de0ff"
      ],
      "author": {
        "name": "Matthew Williams",
        "email": "mjwilliams@google.com",
        "time": "Thu Nov 14 09:27:26 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 14 09:27:26 2013 -0800"
      },
      "message": "am 09d8e3cf: am c68bb182: Merge \"SyncManager now returns copy on getCurrentSyncs()\" into klp-dev\n\n* commit \u002709d8e3cf4e411b016ee65d8328dd7a443c9de0ff\u0027:\n  SyncManager now returns copy on getCurrentSyncs()\n"
    },
    {
      "commit": "c68bb18244aa12d19bea9f9d59f2fe0d81478904",
      "tree": "4001380e058d54c1ce0bc380800a8f4f96024bc1",
      "parents": [
        "5fd5aa3d066fc12c92b5b6541d85ac243556223f",
        "a7456e46f4cb64524386b22e2596ea93c244c16f"
      ],
      "author": {
        "name": "Matthew Williams",
        "email": "mjwilliams@google.com",
        "time": "Thu Nov 14 17:18:58 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 14 17:18:58 2013 +0000"
      },
      "message": "Merge \"SyncManager now returns copy on getCurrentSyncs()\" into klp-dev"
    },
    {
      "commit": "a7456e46f4cb64524386b22e2596ea93c244c16f",
      "tree": "d9aabcce03de71591a2c0ab50447bd9eeb4a9cb8",
      "parents": [
        "c641de017ae0b15bbc13f43fd14fca6b1523ec02"
      ],
      "author": {
        "name": "Matthew Williams",
        "email": "mjwilliams@google.com",
        "time": "Tue Nov 12 14:41:02 2013 -0800"
      },
      "committer": {
        "name": "Matthew Williams",
        "email": "mjwilliams@google.com",
        "time": "Wed Nov 13 18:17:54 2013 -0800"
      },
      "message": "SyncManager now returns copy on getCurrentSyncs()\n\nBug:11559103\nAdded a new getCurrentSyncsCopy() that is public. The other version\nis needed for internal SSE calls.\n\nChange-Id: I0287f039a6f75abf04b65b85cb30f78353aeef4f\n"
    },
    {
      "commit": "7fdfe28c75e103b8a66b559dcb813576fbbf2eb5",
      "tree": "26efd6a084a27dcc41e7e0781955072a932cf28e",
      "parents": [
        "1fbb5da29a4ebef1d758dffad9c2704a5932d223",
        "4c514f2a688bdae319c919987092ccfee690f390"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Wed Nov 13 16:29:12 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 16:29:12 2013 -0800"
      },
      "message": "am 4c514f2a: am 594eeb08: Merge \"Fix for the invalid Global Proxy Setting\" into klp-dev\n\n* commit \u00274c514f2a688bdae319c919987092ccfee690f390\u0027:\n  Fix for the invalid Global Proxy Setting\n"
    },
    {
      "commit": "1fbb5da29a4ebef1d758dffad9c2704a5932d223",
      "tree": "24d93cf8324d3e4a263a67778d1727d306263005",
      "parents": [
        "3857dbe11c723795e9456e5934ca3a4a3513e4b7",
        "29bbd570fe36c55321a3cd9d84330dea9d2f1e10"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 13 16:23:38 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 16:23:38 2013 -0800"
      },
      "message": "am 29bbd570: am 1f0f9fa9: Merge \"Add null pointer check.\" into klp-dev\n\n* commit \u002729bbd570fe36c55321a3cd9d84330dea9d2f1e10\u0027:\n  Add null pointer check.\n"
    },
    {
      "commit": "594eeb082e548617ff5092496888c43457593c2b",
      "tree": "2c7db390e9689975fd57157c327f4cea7ef6a06b",
      "parents": [
        "1f0f9fa94913198cd79b8d350cf9e8df8001daeb",
        "92d02491aded7ca233fd52d586cc0b0bda4521cf"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Thu Nov 14 00:22:46 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 14 00:22:46 2013 +0000"
      },
      "message": "Merge \"Fix for the invalid Global Proxy Setting\" into klp-dev"
    },
    {
      "commit": "1f0f9fa94913198cd79b8d350cf9e8df8001daeb",
      "tree": "15ac9a47f1a7a05043ec43847e9bdeae5967d62b",
      "parents": [
        "a951fa56f1855cd0337bddacc01e35868c6d66d6",
        "ada62fca51d314cefe2c5da4e007df5b9abf320d"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 14 00:15:55 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 14 00:15:55 2013 +0000"
      },
      "message": "Merge \"Add null pointer check.\" into klp-dev"
    },
    {
      "commit": "92d02491aded7ca233fd52d586cc0b0bda4521cf",
      "tree": "c876817adb28c781f7736ccc17d36e1c12fc7b8a",
      "parents": [
        "a951fa56f1855cd0337bddacc01e35868c6d66d6"
      ],
      "author": {
        "name": "Raj Mamadgi",
        "email": "rmamadgi@sta.samsung.com",
        "time": "Mon Nov 11 13:52:58 2013 -0800"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Thu Nov 14 00:08:21 2013 +0000"
      },
      "message": "Fix for the invalid Global Proxy Setting\n\nAdding validation for Global Proxy setting before it is\nbeing set.\n\nProxy is validated at the boot time also to make sure\nthe value set is valid.\n\nSigned-off-by: Raj Mamadgi \u003crmamadgi@sta.samsung.com\u003e\nbug:11598568\n\nChange-Id: Idff5ae81119d8143da096b5291ecbfbc5875cbd4\n"
    },
    {
      "commit": "f4703da89b220f94b3ed1cf3dd24466e47ba5d85",
      "tree": "1d790a39f67cde08a5028969344e3bd7f93c097b",
      "parents": [
        "d5cb5d0fea49491d3f5ff6a757574d7be82dcf50",
        "ef1dd26ee7b4d8a6ec854bd0b5b9557d67b554f5"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 13 15:18:47 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 15:18:47 2013 -0800"
      },
      "message": "am ef1dd26e: am 0e823a45: Merge \"Keyguard isn\\\u0027t visible if it hasn\\\u0027t been drawn.\" into klp-dev\n\n* commit \u0027ef1dd26ee7b4d8a6ec854bd0b5b9557d67b554f5\u0027:\n  Keyguard isn\u0027t visible if it hasn\u0027t been drawn.\n"
    },
    {
      "commit": "0e823a450a729a753fb8e0618474b6ae3cf3b810",
      "tree": "808bf2d549b305588f4be840aa32b91d7e8c875e",
      "parents": [
        "dc0acc6f5d4cc8e4ed6d2a13793030350cd6262d",
        "5c7bd017058ff073b73e96726aa44c4a113f453f"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 13 23:11:12 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Nov 13 23:11:12 2013 +0000"
      },
      "message": "Merge \"Keyguard isn\u0027t visible if it hasn\u0027t been drawn.\" into klp-dev"
    },
    {
      "commit": "ada62fca51d314cefe2c5da4e007df5b9abf320d",
      "tree": "f0dcd5cfe1e3eb0e10273069768213975d0db312",
      "parents": [
        "48dab493b927f4a71687ccd557084ccee195de73"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 13 15:06:15 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 13 15:09:55 2013 -0800"
      },
      "message": "Add null pointer check.\n\nFixes bug 11673948.\n\nChange-Id: I60b590b9793ae1b8d5c3d343f4bb6cb40ba4a092\n"
    },
    {
      "commit": "5c7bd017058ff073b73e96726aa44c4a113f453f",
      "tree": "57118a4d74eb5e14b8986e75b2cca2aaf6341439",
      "parents": [
        "48dab493b927f4a71687ccd557084ccee195de73"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 13 13:09:35 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 13 13:09:35 2013 -0800"
      },
      "message": "Keyguard isn\u0027t visible if it hasn\u0027t been drawn.\n\nReduces jank in multiuser lock from QuickSettings. The launcher and\nwallpaper were being hidden as soon as the surface for the keyguard\nwas created. Now they are not hidden until the keyguard has been\ndrawn. This still leaves a short time where there is a black screen\nbut it is considerably shorter than it was. Comparable to jb now.\n\nFixes bug 11046339.\n\nChange-Id: I349d95dba72da27e5c05a7a64c95a2774d17a34e\n"
    },
    {
      "commit": "87b84ca6fc5070f2fbbb5f6d94863680b33d188b",
      "tree": "80f2e08a1bed79982af02a1fd13a3dd176cccc22",
      "parents": [
        "086034117d9214de6339a29b93412276eb00afea",
        "e995ad1559ac12a0ac5e2e56ce378b0b29f10f24"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Wed Nov 13 12:14:29 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 12:14:29 2013 -0800"
      },
      "message": "am e995ad15: am 0b2c2b10: Merge \"Support preferred activities with zero or one scheme in the filter\" into klp-dev\n\n* commit \u0027e995ad1559ac12a0ac5e2e56ce378b0b29f10f24\u0027:\n  Support preferred activities with zero or one scheme in the filter\n"
    },
    {
      "commit": "c4f535bddac2491aa0e354a609fcbf7c49276295",
      "tree": "a734b89a074fc6741e70793518629ab04f0f150f",
      "parents": [
        "955b575dd94370f618f6b6424d60c1aa9dc34c14",
        "299e011ebd7ce9593c203ecfc9f5eed45360a5ed"
      ],
      "author": {
        "name": "John Huang",
        "email": "jsh@google.com",
        "time": "Wed Nov 13 12:14:16 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 12:14:16 2013 -0800"
      },
      "message": "am 299e011e: am 54ca9066: Merge \"Get rid of a race in NsdService in stopResolveService and getAddrInfo\" into klp-dev\n\n* commit \u0027299e011ebd7ce9593c203ecfc9f5eed45360a5ed\u0027:\n  Get rid of a race in NsdService in stopResolveService and getAddrInfo\n"
    },
    {
      "commit": "0b2c2b10053afd7a525dbf8a4eb0f0aaf98739b3",
      "tree": "65c5ea096baece4ff474db4e6095b7bb71c3e484",
      "parents": [
        "31f7c912f0b6a2cfa2ea0f0b3a9022e8323f5542",
        "087044c902e693dd2b7b267163f4d9f892592a67"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Wed Nov 13 19:33:46 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Nov 13 19:33:46 2013 +0000"
      },
      "message": "Merge \"Support preferred activities with zero or one scheme in the filter\" into klp-dev"
    },
    {
      "commit": "54ca906604c2ff0a58274e5d1b66cdba4df8c3d8",
      "tree": "b0471ba448dccf28976ce3fbee6e1c801eca26c6",
      "parents": [
        "41b92b008e03be95db938e0238ccb9373c2aaadc",
        "4038724a536c990859866489195add7ed537006b"
      ],
      "author": {
        "name": "John Huang",
        "email": "jsh@google.com",
        "time": "Wed Nov 13 19:13:59 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Nov 13 19:14:00 2013 +0000"
      },
      "message": "Merge \"Get rid of a race in NsdService in stopResolveService and getAddrInfo\" into klp-dev"
    },
    {
      "commit": "955b575dd94370f618f6b6424d60c1aa9dc34c14",
      "tree": "74938fa7ab768e2d47302fa1e5906e82206fdc8c",
      "parents": [
        "d24bf4ab07693e910410cffb745e83bc572fd339",
        "6eddb39c857b178672218a345a276c4304e7ad37"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Wed Nov 13 10:27:46 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 10:27:46 2013 -0800"
      },
      "message": "am 6eddb39c: am 18490abd: Merge \"Fix NPE in ConnectivityService\"\n\n* commit \u00276eddb39c857b178672218a345a276c4304e7ad37\u0027:\n  Fix NPE in ConnectivityService\n"
    },
    {
      "commit": "6eddb39c857b178672218a345a276c4304e7ad37",
      "tree": "db20fbbe123bccd81d42d61734c6cc2a0cdf9d99",
      "parents": [
        "221080078a36f4b30fe6edc8c91f339a5b84ed83",
        "18490abd9bcb401f0d75a314056fb2a44dd61f07"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Wed Nov 13 10:25:30 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 10:25:30 2013 -0800"
      },
      "message": "am 18490abd: Merge \"Fix NPE in ConnectivityService\"\n\n* commit \u002718490abd9bcb401f0d75a314056fb2a44dd61f07\u0027:\n  Fix NPE in ConnectivityService\n"
    },
    {
      "commit": "18490abd9bcb401f0d75a314056fb2a44dd61f07",
      "tree": "d07a96d6cc25250050a27d2883d084c868fd606a",
      "parents": [
        "01e42c0be27f492a7325141f509755aa064923f3",
        "151d3032eb81337b0b876b0a43c6faefe54e516a"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Wed Nov 13 18:22:26 2013 +0000"
      },
      "committer": {
        "name": "Gerrit Code Review",
        "email": "noreply-gerritcodereview@google.com",
        "time": "Wed Nov 13 18:22:26 2013 +0000"
      },
      "message": "Merge \"Fix NPE in ConnectivityService\""
    },
    {
      "commit": "e5ae0bfdf7933d7ea8bec94f0c7e25347c423710",
      "tree": "ba468d62eec515df41aafe4c9be85dbb443d6214",
      "parents": [
        "e86ab5e1d34beb6706589f0ce316c0cfa0053ee4",
        "a20f625cc1006b03d4a2be90ba35d1a9783ad363"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Wed Nov 13 08:58:53 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 08:58:53 2013 -0800"
      },
      "message": "am a20f625c: am 41b92b00: Merge \"Finalize assets for screen casting.\" into klp-dev\n\n* commit \u0027a20f625cc1006b03d4a2be90ba35d1a9783ad363\u0027:\n  Finalize assets for screen casting.\n"
    },
    {
      "commit": "41b92b008e03be95db938e0238ccb9373c2aaadc",
      "tree": "89377fe52633b69366da4960319a488a6872ffa1",
      "parents": [
        "7d667ee2de2c6add257466d9648024d7e8402926",
        "e7ae644522f692c204d0233f91e77c7841bdfe53"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Wed Nov 13 16:51:53 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Nov 13 16:51:53 2013 +0000"
      },
      "message": "Merge \"Finalize assets for screen casting.\" into klp-dev"
    },
    {
      "commit": "e86ab5e1d34beb6706589f0ce316c0cfa0053ee4",
      "tree": "de51d8860ffe0a9796ef7f09eea3d9b83714fbbf",
      "parents": [
        "f7400aa1da0b3604dbb5fc1bf4b4242a8e65e860",
        "79033da8e42ba6ccf096bf10dea1e51873f7d402"
      ],
      "author": {
        "name": "John Spurlock",
        "email": "jspurlock@google.com",
        "time": "Wed Nov 13 08:50:07 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 13 08:50:07 2013 -0800"
      },
      "message": "am 79033da8: am 7d667ee2: Merge \"Ensure wallpaper hint is at least as large as the display.\" into klp-dev\n\n* commit \u002779033da8e42ba6ccf096bf10dea1e51873f7d402\u0027:\n  Ensure wallpaper hint is at least as large as the display.\n"
    },
    {
      "commit": "7d667ee2de2c6add257466d9648024d7e8402926",
      "tree": "bed22f17b93567df2d4a0e07e0c480c2bd808e97",
      "parents": [
        "78cfdf31b7c48589ea3a148ec1d6d573235bc06b",
        "41f6464b3f247c6ee0828e1b1aa3300e56e8cabb"
      ],
      "author": {
        "name": "John Spurlock",
        "email": "jspurlock@google.com",
        "time": "Wed Nov 13 16:41:43 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Nov 13 16:41:44 2013 +0000"
      },
      "message": "Merge \"Ensure wallpaper hint is at least as large as the display.\" into klp-dev"
    },
    {
      "commit": "e7ae644522f692c204d0233f91e77c7841bdfe53",
      "tree": "62576b08cf67d11e70b9359f2fdcdb84536c46dc",
      "parents": [
        "218ecd43946001f07b60757db130ef5585d474d3"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Wed Nov 13 00:45:18 2013 -0800"
      },
      "committer": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Wed Nov 13 02:17:53 2013 -0800"
      },
      "message": "Finalize assets for screen casting.\n\nExtend wifi display connection timeout.\n\nShow a notification while connecting to wifi display.\n\nEnsure that remote display providers are really trusted before\nconnecting to them.\n\nBug: 11257292\nChange-Id: Iad0caaa30d7946df818bc75ade071f2e377f8a53\n"
    },
    {
      "commit": "151d3032eb81337b0b876b0a43c6faefe54e516a",
      "tree": "ebdfdca8200fd0eaa86d38ab3ebf528697788ff5",
      "parents": [
        "0b807d2e74f786af0d44162d92cc0bf85883349a"
      ],
      "author": {
        "name": "Ken Mixter",
        "email": "kmixter@google.com",
        "time": "Thu Nov 07 22:08:24 2013 -0800"
      },
      "committer": {
        "name": "Ken Mixter",
        "email": "kmixter@google.com",
        "time": "Tue Nov 12 22:17:46 2013 -0800"
      },
      "message": "Fix NPE in ConnectivityService\n\nCould occur when requestRouteToHostAddress is called on a network\nwith no associated tracker.  Code later in the method handles\nthis case gracefully but code introduced in JB throws an exception.\n\nChange-Id: I6c8a0e313ecbcca120aeb5dd0802a72114749aa1\n"
    },
    {
      "commit": "bf581034f9771fd67ea796e91ce28787c33fbb82",
      "tree": "928911711d01348edfa3ef9416ac35be67ebe689",
      "parents": [
        "69689fc9e66c3a3c3a7e0faf219a4da82d344cba",
        "679ba4e86e4fecb6dbfe48d6c49205c32f995a1c"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Tue Nov 12 16:00:54 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 12 16:00:54 2013 -0800"
      },
      "message": "am 679ba4e8: am 6cd206b2: Merge \"Relayout windows that handle their own config change.\" into klp-dev\n\n* commit \u0027679ba4e86e4fecb6dbfe48d6c49205c32f995a1c\u0027:\n  Relayout windows that handle their own config change.\n"
    },
    {
      "commit": "6cd206b2aa0039c215fc0a4cc487471c4b3f1496",
      "tree": "d3957bdae0c258a8beedc83601067d0085f2c8f2",
      "parents": [
        "48dab493b927f4a71687ccd557084ccee195de73",
        "5d9f547720e07a2715d34320a9e11004654cede6"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Tue Nov 12 23:56:21 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Nov 12 23:56:21 2013 +0000"
      },
      "message": "Merge \"Relayout windows that handle their own config change.\" into klp-dev"
    },
    {
      "commit": "4038724a536c990859866489195add7ed537006b",
      "tree": "bf1d2b0aa115f2a182e821294f9423bc5bb4f332",
      "parents": [
        "105b9b05041ea6f1109d961d548f3dde2bd69501"
      ],
      "author": {
        "name": "Vinit Deshapnde",
        "email": "vinitd@google.com",
        "time": "Tue Nov 12 15:36:37 2013 -0800"
      },
      "committer": {
        "name": "Vinit Deshapnde",
        "email": "vinitd@google.com",
        "time": "Tue Nov 12 15:36:37 2013 -0800"
      },
      "message": "Get rid of a race in NsdService in stopResolveService and getAddrInfo\n\nBoth requests are made using same id; and there is a chance that\nstopResolve() is not fully completed when getAddrInfo() is issued. That\nresults getAddrInfo() failure, because both are using same requestId.\n\nThis change fixes this problem by creating a new unique id to call\ngetAddrInfo() with.\n\nBug: 11597153\nChange-Id: I56bd78740e8a40bd31c52705dc797486aff53a50\n"
    },
    {
      "commit": "d62887519266951e63ae4f3d5c4b33d235c64ce3",
      "tree": "f8d2fe3265126750265f39ad0efccfed619cb934",
      "parents": [
        "8a71cdaeb159af1bf851264c8ad5d037a705bcfa",
        "221080078a36f4b30fe6edc8c91f339a5b84ed83"
      ],
      "author": {
        "name": "Elliott Hughes",
        "email": "enh@google.com",
        "time": "Tue Nov 12 15:02:18 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 12 15:02:18 2013 -0800"
      },
      "message": "am 22108007: am 01e42c0b: Merge \"Fix libinput to build with uapi headers.\"\n\n* commit \u0027221080078a36f4b30fe6edc8c91f339a5b84ed83\u0027:\n  Fix libinput to build with uapi headers.\n"
    },
    {
      "commit": "221080078a36f4b30fe6edc8c91f339a5b84ed83",
      "tree": "87d6ba53f31e5182849a2185fbabbfae62db3ff9",
      "parents": [
        "ede7f9d3a39d87f12d58df495f28108784e9b588",
        "01e42c0be27f492a7325141f509755aa064923f3"
      ],
      "author": {
        "name": "Elliott Hughes",
        "email": "enh@google.com",
        "time": "Tue Nov 12 14:55:38 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 12 14:55:38 2013 -0800"
      },
      "message": "am 01e42c0b: Merge \"Fix libinput to build with uapi headers.\"\n\n* commit \u002701e42c0be27f492a7325141f509755aa064923f3\u0027:\n  Fix libinput to build with uapi headers.\n"
    },
    {
      "commit": "8a71cdaeb159af1bf851264c8ad5d037a705bcfa",
      "tree": "d3cdaa2fc5bc20b1180fcdd5c17f0c5a787b802c",
      "parents": [
        "1d64812a35350692e0a770dcf278fab45ff855c8",
        "f174b5162664da2cb7f1e91c2b03324711540ba2"
      ],
      "author": {
        "name": "Amith Yamasani",
        "email": "yamasani@google.com",
        "time": "Tue Nov 12 14:53:19 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 12 14:53:19 2013 -0800"
      },
      "message": "am f174b516: am 48dab493: Merge \"Fix inconsistency in reporting device admin active state.\" into klp-dev\n\n* commit \u0027f174b5162664da2cb7f1e91c2b03324711540ba2\u0027:\n  Fix inconsistency in reporting device admin active state.\n"
    },
    {
      "commit": "48dab493b927f4a71687ccd557084ccee195de73",
      "tree": "7ad57e91b33aad104677fc9e125107bc0b417c67",
      "parents": [
        "c641de017ae0b15bbc13f43fd14fca6b1523ec02",
        "f65c0a99583cfaa8119836b8691d3a79db21dbbf"
      ],
      "author": {
        "name": "Amith Yamasani",
        "email": "yamasani@google.com",
        "time": "Tue Nov 12 22:47:55 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Nov 12 22:47:55 2013 +0000"
      },
      "message": "Merge \"Fix inconsistency in reporting device admin active state.\" into klp-dev"
    },
    {
      "commit": "5d9f547720e07a2715d34320a9e11004654cede6",
      "tree": "cb8b2477167e7bd4840ae1c8894e204072702162",
      "parents": [
        "c481a634f4db6e95bc03b22b72414ba12da99f4b"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Tue Nov 12 14:02:52 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Tue Nov 12 14:02:52 2013 -0800"
      },
      "message": "Relayout windows that handle their own config change.\n\nIf a window claims to handle its own configuration change then we\nwon\u0027t destroy and recreate its window on a configuration change.\nNormally that recreation triggers the first layout following\norientation change because mHaveFrame is false. Windows that handle\ntheir own configuration changes never got a relayout pass following a\nchange in orientation.\n\nThis change passes the configuration changes that an application\nhandles into the AppWindowToken. If the app says it handles\norientation or screen size changes then a relayout will occur when the\nconfiguration has changed.\n\nFixes bug 11647107.\n\nChange-Id: Ie8d49fd050442ebbdcf0b805087894e3a2fc4be9\n"
    },
    {
      "commit": "6a2e9bccefe4de367125d8c04c3c9a7a3bebef10",
      "tree": "645121296e1753f707610ce7b5e6ea68cf63d534",
      "parents": [
        "9e71310d15d9dfcbf5e1c94948e0260f3dc3e678"
      ],
      "author": {
        "name": "Elliott Hughes",
        "email": "enh@google.com",
        "time": "Tue Nov 12 13:16:37 2013 -0800"
      },
      "committer": {
        "name": "Elliott Hughes",
        "email": "enh@google.com",
        "time": "Tue Nov 12 13:16:37 2013 -0800"
      },
      "message": "Fix libinput to build with uapi headers.\n\nBug: 11559337\nChange-Id: I00ca91162de7cd42e03df23bbe4208e169b2ebfe\n"
    },
    {
      "commit": "087044c902e693dd2b7b267163f4d9f892592a67",
      "tree": "7aaa3dfe0cac63d40988248aec7040765abd40e6",
      "parents": [
        "596e409ec9703e5071bb9a0de08787cde7745f7a"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Mon Nov 11 17:43:43 2013 -0800"
      },
      "committer": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Tue Nov 12 12:23:10 2013 -0800"
      },
      "message": "Support preferred activities with zero or one scheme in the filter\n\nAlso use the existing full PreferredActivity match machinery instead\nof the existing direct comparison now that the intent filters can\nbe more flexible.\n\nBug 11482259\n\nChange-Id: Icb649ca60ecfbdb9ee3c256ee512d3f3f989e05f\n"
    },
    {
      "commit": "191b2bd8d0f6e33b2123c64bc8af1c6ec175b5f0",
      "tree": "d4f097607989859f8620a55a0b0b328c48bf5d16",
      "parents": [
        "d303549b5175d3e589ca656c5e01a88b55bf373a",
        "449b32e844b9bdadbcbca68e87f446b509e5e667"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Tue Nov 12 11:24:43 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Nov 12 11:24:43 2013 -0800"
      },
      "message": "am 449b32e8: am c641de01: Merge \"Add event logging for tasks and stacks.\" into klp-dev\n\n* commit \u0027449b32e844b9bdadbcbca68e87f446b509e5e667\u0027:\n  Add event logging for tasks and stacks.\n"
    },
    {
      "commit": "2c2549c5f44b712dbbf66a69d91f07d6f5336ee6",
      "tree": "7beb409e840b1e31015691d01bd8f63c49661322",
      "parents": [
        "c481a634f4db6e95bc03b22b72414ba12da99f4b"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Tue Nov 12 08:31:15 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Tue Nov 12 09:57:00 2013 -0800"
      },
      "message": "Add event logging for tasks and stacks.\n\nAlso remove crufty write-only DisplayContent.mStackHistory.\n\nChange-Id: I62b2b53dc02377c5d0d3b79df70b1990eed87d23\n"
    },
    {
      "commit": "41f6464b3f247c6ee0828e1b1aa3300e56e8cabb",
      "tree": "f9279faf0a421c71c9fba6171414587eb44edf30",
      "parents": [
        "c481a634f4db6e95bc03b22b72414ba12da99f4b"
      ],
      "author": {
        "name": "John Spurlock",
        "email": "jspurlock@google.com",
        "time": "Mon Nov 04 13:48:38 2013 -0500"
      },
      "committer": {
        "name": "John Spurlock",
        "email": "jspurlock@google.com",
        "time": "Tue Nov 12 10:28:14 2013 -0500"
      },
      "message": "Ensure wallpaper hint is at least as large as the display.\n\nBug:11332853\nBug:11606952\nChange-Id: I1840d7b723015c379da8eab7e22aa478d56adeb3\n"
    },
    {
      "commit": "9ffc4a65e51ae8695be0531c6fae0d33301ded60",
      "tree": "eedfd44e375e7d02c1501eb4b1bcdc9c0cb3257e",
      "parents": [
        "ebda68bf844d4b5b75a01317b45ee04041e726e3",
        "854395add8ceaa2b80a14e063567f1292eb91c4d"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Mon Nov 11 22:04:54 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 11 22:04:54 2013 -0800"
      },
      "message": "am 854395ad: am c481a634: Merge \"UI tweaks.\" into klp-dev\n\n* commit \u0027854395add8ceaa2b80a14e063567f1292eb91c4d\u0027:\n  UI tweaks.\n"
    },
    {
      "commit": "39ad0e559896b45185429ea17cd12f18f7ae842c",
      "tree": "9e8d5d137a467f6ccd3ad6d453014d89f7ca21f7",
      "parents": [
        "596e409ec9703e5071bb9a0de08787cde7745f7a"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Mon Nov 11 17:55:08 2013 -0800"
      },
      "committer": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Mon Nov 11 21:48:53 2013 -0800"
      },
      "message": "UI tweaks.\n\nHide disabled routes from the chooser.\n\nFix layout of chooser dialog when the settings button is visible and\nthe list is very long to prevent truncation of the settings button.\n\nFix an issue when we fake the route connecting status when a route\nis selected.  The route changed notification needs to be propagated\nto apps.  Fake it better.\n\nImmediately disconnect from a route when the connection is lost or\na connection attempt fails.  Added a few new test displays for this\ncase.\n\nBug: 11257292\nChange-Id: I360ab5dc937ad60d97592eab54b19f034519645e\n"
    },
    {
      "commit": "bf687484573ef63c5b54adfc0325a41115fb49fa",
      "tree": "a193fba5483e3d166a50af76213ef5bb65564f04",
      "parents": [
        "bb3adc44dfdb02c087a79df85ddeceb770e9cfb2",
        "0259c010221c73db11ee52b4b0758a179e5c0db1"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 11 18:05:10 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 11 18:05:10 2013 -0800"
      },
      "message": "am 0259c010: am 596e409e: Merge \"Work on issue #11634365: Leaking restarting services\" into klp-dev\n\n* commit \u00270259c010221c73db11ee52b4b0758a179e5c0db1\u0027:\n  Work on issue #11634365: Leaking restarting services\n"
    },
    {
      "commit": "596e409ec9703e5071bb9a0de08787cde7745f7a",
      "tree": "7eddefbedcec1657f86e2df42f60a77f51c0575b",
      "parents": [
        "778eaf4bece18d08e91df1d405337a18c3abcd57",
        "d6f5b629216a2566883ccc6f2506fee198b07f99"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Tue Nov 12 01:36:10 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Nov 12 01:36:10 2013 +0000"
      },
      "message": "Merge \"Work on issue #11634365: Leaking restarting services\" into klp-dev"
    },
    {
      "commit": "d6f5b629216a2566883ccc6f2506fee198b07f99",
      "tree": "f991c4897e2c7930a5474185eb02090f6f90808c",
      "parents": [
        "55d12486df5e801dc8e74d96abdf87a250bc0ba1"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 11 17:25:37 2013 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 11 17:25:37 2013 -0800"
      },
      "message": "Work on issue #11634365: Leaking restarting services\n\nTighten up some flows to try to avoid any chance of leaving\na restarting service on the list, add a log to the only remaining\nplace I could find that we could get in to trouble for some\nreason.\n\nChange-Id: Iffb9be9d97deefc6cf0c5790eedfeb6e4e8a36bc\n"
    },
    {
      "commit": "9a55d60b996dc50fbad8eba114ef69e652a1407d",
      "tree": "617844b6cf6160df5005b6667da638f7afc3c6f2",
      "parents": [
        "cb623a8d44cfef63133c3c8d1d8a31aa48ba57d2",
        "64234cfc1e0e74774492c2b8208da38ab0250469"
      ],
      "author": {
        "name": "Jatin Lodhia",
        "email": "jlodhia@google.com",
        "time": "Mon Nov 11 15:57:19 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 11 15:57:19 2013 -0800"
      },
      "message": "am 64234cfc: am 09e7e0ef: Delegate existence of account check to Authenticator.\n\n* commit \u002764234cfc1e0e74774492c2b8208da38ab0250469\u0027:\n  Delegate existence of account check to Authenticator.\n"
    },
    {
      "commit": "09e7e0ef8bcd8b7b78b79fb570de2032871f0c97",
      "tree": "81591bab813d74f1026d3e69d3d9360a08786c93",
      "parents": [
        "fed822cb8e17579dfa792b40ebe82683088e7779"
      ],
      "author": {
        "name": "Jatin Lodhia",
        "email": "jlodhia@google.com",
        "time": "Thu Nov 07 00:14:25 2013 -0800"
      },
      "committer": {
        "name": "Jatin Lodhia",
        "email": "jlodhia@google.com",
        "time": "Mon Nov 11 23:48:53 2013 +0000"
      },
      "message": "Delegate existence of account check to Authenticator.\n\nCurrent AccountManager code for getAuthToken checks if the account\nin the request exists. If the account does not exist then it throws\nan exception which leads to a runtime exception being thrown by\nAccountManager in the client. In perticular, Checkin client code\nhits this issue when accounts are deleted by user. As the exception\nis thrown from the getAuthToken method call and is a RuntimeException\nit is not caught by the client. Futhermore, Checkin runs in one of the\nimportant processes and this exception makes the process crash.\n\nThis cl, does the following:\n1) Delegates the account exists check to Authentictor which in turn\nwould cause an AuthenticatorException which is a checked exception.\n2) Replaces some of the runtime exceptions thrown by AccountManagerService\nwith calling AccountManagerResponse.onError() which causes more graceful\nfailure on the client.\n3) Correctly passes on the error returned by Authenticator to\nAccountManager. Earlier if Authenticator returned an error code to\nthe AccountManager, it ignored the error and returned null token to the\nclient which was incorrect.\n\nBug: 10856295\nChange-Id: Ie250fec601d46f6dfecd74677b478bfd4e9dcfad\n"
    },
    {
      "commit": "f65c0a99583cfaa8119836b8691d3a79db21dbbf",
      "tree": "d207f658297e11058ba699ba6d1cfd2c51c7fd3b",
      "parents": [
        "e8c51298a43f607fea7418ced7cc783e6065fe87"
      ],
      "author": {
        "name": "Amith Yamasani",
        "email": "yamasani@google.com",
        "time": "Mon Nov 11 11:44:37 2013 -0800"
      },
      "committer": {
        "name": "Amith Yamasani",
        "email": "yamasani@google.com",
        "time": "Mon Nov 11 11:44:37 2013 -0800"
      },
      "message": "Fix inconsistency in reporting device admin active state.\n\nWhen a device admin goes away due to a package change, only one of two lists\nwas being updated, causing an inconsistency in the query for active admins\ndepending on which API was being called.\n\nThis makes sure that mAdminMap stays in sync with mAdminList so that\nisActiveAdmin() and getActiveAdmins() returns the same results.\n\nBug: 11588094\nChange-Id: I232608738249492d9fca7e4d7aa7566d96fccf46\n"
    },
    {
      "commit": "f488cd3b77c064c29040edc5af1fc98d6faa994e",
      "tree": "4ee45334961ab4c79820d37768d0018a091e2564",
      "parents": [
        "fa0d9c2fa8e5c2c73bd36688784f1e44eb08635b",
        "7e40e3176399e0609051e5f0bfcb5149e78c2ea6"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 11 11:37:19 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 11 11:37:19 2013 -0800"
      },
      "message": "am 7e40e317: am c85a1143: Merge \"Fix issue #11630188: Still seeing some processes not on LRU list errors\" into klp-dev\n\n* commit \u00277e40e3176399e0609051e5f0bfcb5149e78c2ea6\u0027:\n  Fix issue #11630188: Still seeing some processes not on LRU list errors\n"
    },
    {
      "commit": "c85a1143aa7be1cef40cba72f83c71e81fe5c86e",
      "tree": "301a3f1256d62f0dc0b70ce815c9378572bbf594",
      "parents": [
        "1cdbbb1e73bff05f5dd1679bae2e3502d4f82368",
        "bc72dce07546063c3512138634d5abd84fe99915"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 11 19:31:59 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 11 19:31:59 2013 +0000"
      },
      "message": "Merge \"Fix issue #11630188: Still seeing some processes not on LRU list errors\" into klp-dev"
    },
    {
      "commit": "bc72dce07546063c3512138634d5abd84fe99915",
      "tree": "4c5fedbb8e103391ffc1bc66b6e1db51527fe2f3",
      "parents": [
        "45bf2815158cb98130fff120b34ad05f5a54b8f8"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 11 10:43:38 2013 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Mon Nov 11 10:55:42 2013 -0800"
      },
      "message": "Fix issue #11630188: Still seeing some processes not on LRU list errors\n\nThis happened:\n\nandroid.util.Log$TerribleFailure: Adding dependent process ProcessRecord{43c7a120 0:com.google.android.gms/u0a7} not on LRU list: service connection ConnectionRecord{437c16e0 u0 CR ACT com.google.android.gms/.icing.impl.IndexService:@436ba7f8} from ProcessRecord{43c64208 4908:com.google.android.googlequicksearchbox:search/u0a19}\n\tat android.util.Log.wtf(Log.java:290)\n\tat android.util.Slog.wtf(Slog.java:82)\n\tat com.android.server.am.ActivityManagerService.updateLruProcessInternalLocked(ActivityManagerService.java:2290)\n\tat com.android.server.am.ActivityManagerService.updateLruProcessLocked(ActivityManagerService.java:2508)\n\tat com.android.server.am.ActiveServices.updateServiceClientActivitiesLocked(ActiveServices.java:636)\n\tat com.android.server.am.ActiveServices.removeConnectionLocked(ActiveServices.java:1656)\n\tat com.android.server.am.ActiveServices.unbindServiceLocked(ActiveServices.java:860)\n\tat com.android.server.am.ActivityManagerService.unbindService(ActivityManagerService.java:12773)\n\tat android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:869)\n\tat com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2071)\n\tat android.os.Binder.execTransact(Binder.java:404)\n\tat dalvik.system.NativeStart.run(Native Method)\n\nBecause of this earlier:\n\n11-09 18:02:19.126 W/ActivityManager(  809): Exception when starting service com.google.android.gms/.icing.impl.IndexService\n11-09 18:02:19.126 W/ActivityManager(  809): android.os.DeadObjectException\n11-09 18:02:19.126 W/ActivityManager(  809): \tat android.os.BinderProxy.transact(Native Method)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat android.app.ApplicationThreadProxy.scheduleCreateService(ApplicationThreadNative.java:850)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat com.android.server.am.ActiveServices.realStartServiceLocked(ActiveServices.java:1384)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat com.android.server.am.ActiveServices.bringUpServiceLocked(ActiveServices.java:1294)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat com.android.server.am.ActiveServices.bindServiceLocked(ActiveServices.java:755)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat com.android.server.am.ActivityManagerService.bindService(ActivityManagerService.java:12766)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:859)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2071)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat android.os.Binder.execTransact(Binder.java:404)\n11-09 18:02:19.126 W/ActivityManager(  809): \tat dalvik.system.NativeStart.run(Native Method)\n\nNot clearing the service\u0027s app pointer.\n\nAlso fix this wtf where we were not clearing the started state of\na ServiceTracker when its process goes away.  (This was like this\nbecause we used to want to leave the started state so that we can\nknow the process is trying to restart.  But now that have a new\nexplicit restarting strate, there is no need to leave it.)\n\nandroid.util.Log$TerribleFailure: Service owner ServiceRecord{436f5168 u0 com.dirtywaterlabs.uberhype/com.dirtywaterlabs.musichype.MDService} cleared while started: pkg\u003dcom.dirtywaterlabs.uberhype service\u003dcom.dirtywaterlabs.musichype.MDService proc\u003dProcessState{42bf4bb8 com.dirtywaterlabs.uberhype:remote/10115 pkg\u003dcom.dirtywaterlabs.uberhype}\n\tat android.util.Log.wtf(Log.java:290)\n\tat android.util.Slog.wtfStack(Slog.java:86)\n\tat com.android.internal.app.ProcessStats$ServiceState.clearCurrentOwner(ProcessStats.java:2989)\n\tat com.android.server.am.ActiveServices.serviceDoneExecutingLocked(ActiveServices.java:1821)\n\tat com.android.server.am.ActiveServices.serviceProcessGoneLocked(ActiveServices.java:1779)\n\tat com.android.server.am.ActiveServices.removeConnectionLocked(ActiveServices.java:1693)\n\tat com.android.server.am.ActiveServices.killServicesLocked(ActiveServices.java:2028)\n\tat com.android.server.am.ActivityManagerService.cleanUpApplicationRecordLocked(ActivityManagerService.java:12424)\n\tat com.android.server.am.ActivityManagerService.handleAppDiedLocked(ActivityManagerService.java:3605)\n\tat com.android.server.am.ActivityManagerService.appDiedLocked(ActivityManagerService.java:3750)\n\tat com.android.server.am.ActivityManagerService$AppDeathRecipient.binderDied(ActivityManagerService.java:1026)\n\tat android.os.BinderProxy.sendDeathNotice(Binder.java:493)\n\tat dalvik.system.NativeStart.run(Native Method)\n\nChange-Id: I25a3fb678b5365254490cd5509b558348655b589\n"
    },
    {
      "commit": "fa0d9c2fa8e5c2c73bd36688784f1e44eb08635b",
      "tree": "01e2d6dfc775bba9af24edbdf529b160285e7374",
      "parents": [
        "c1c5e37cf62db04cb029f1ff339f9192ae43e3c0",
        "02b775755105a956456cb193b60d765e1a4690b6"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Mon Nov 11 10:23:57 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 11 10:23:57 2013 -0800"
      },
      "message": "am 02b77575: am 1cdbbb1e: Merge \"Changes to support new screen cast settings screen.\" into klp-dev\n\n* commit \u002702b775755105a956456cb193b60d765e1a4690b6\u0027:\n  Changes to support new screen cast settings screen.\n"
    },
    {
      "commit": "1cdbbb1e73bff05f5dd1679bae2e3502d4f82368",
      "tree": "1f4ed5753a58fa274f9fdad6f90db715b12894bf",
      "parents": [
        "45bf2815158cb98130fff120b34ad05f5a54b8f8",
        "75af171006ee80aaf7cfb56ded1378afe0084cca"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Mon Nov 11 18:19:25 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 11 18:19:26 2013 +0000"
      },
      "message": "Merge \"Changes to support new screen cast settings screen.\" into klp-dev"
    },
    {
      "commit": "c1c5e37cf62db04cb029f1ff339f9192ae43e3c0",
      "tree": "6459df2c351064abcd7db8120edd414a0de82e8c",
      "parents": [
        "6492c0f3af881c070170a00212e5e034f74436ae",
        "86b06976e7d93772422c85c15d08ec1f00ebbcfc"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Mon Nov 11 10:07:25 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 11 10:07:25 2013 -0800"
      },
      "message": "am 86b06976: am 45bf2815: Merge \"Fix a couple of issues with mOpeningApps.\" into klp-dev\n\n* commit \u002786b06976e7d93772422c85c15d08ec1f00ebbcfc\u0027:\n  Fix a couple of issues with mOpeningApps.\n"
    },
    {
      "commit": "6492c0f3af881c070170a00212e5e034f74436ae",
      "tree": "522bf25df5bfe58b52fac3809c1f6a7f2eaa0173",
      "parents": [
        "35631bccd4f58cc1fbb4d79d1890fbf1ff59dbc2",
        "22a9710608d47747f9b834aa2a6b377bf529ad33"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Mon Nov 11 10:07:21 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Nov 11 10:07:21 2013 -0800"
      },
      "message": "am 22a97106: am 8cfa6d08: Merge \"Use old task info when creating new task.\" into klp-dev\n\n* commit \u002722a9710608d47747f9b834aa2a6b377bf529ad33\u0027:\n  Use old task info when creating new task.\n"
    },
    {
      "commit": "45bf2815158cb98130fff120b34ad05f5a54b8f8",
      "tree": "03f2aa48194a618e3116da9c115ec3347cec4583",
      "parents": [
        "8cfa6d083bc5638801fa6d1b2dfccbc460c88bb9",
        "a8ee262c04749db4f32f73d2b9e7f58989c4638b"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Mon Nov 11 18:02:08 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 11 18:02:08 2013 +0000"
      },
      "message": "Merge \"Fix a couple of issues with mOpeningApps.\" into klp-dev"
    },
    {
      "commit": "8cfa6d083bc5638801fa6d1b2dfccbc460c88bb9",
      "tree": "caadc2d32db5980e8d84ead1ab497c4b94b8a43b",
      "parents": [
        "e45d8b2dab33de18bef5cc5ae7db37b890b22d8d",
        "8862929e2a5ae4936083b6d7ac7e908df256a885"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Mon Nov 11 18:01:36 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Nov 11 18:01:36 2013 +0000"
      },
      "message": "Merge \"Use old task info when creating new task.\" into klp-dev"
    },
    {
      "commit": "75af171006ee80aaf7cfb56ded1378afe0084cca",
      "tree": "d26fe83b1d36b8afe4709b80fcd8897bd0db28c8",
      "parents": [
        "dd4f9e8b61c0a5639aa82480b7fdd760a2ed609c"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Sun Nov 10 18:54:03 2013 -0800"
      },
      "committer": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Sun Nov 10 22:51:15 2013 -0800"
      },
      "message": "Changes to support new screen cast settings screen.\n\nFixed the Preference ordering code to consider the case where\ntwo preferences might have the same order.  In that case, it\nfalls back on the title to disambiguate.  Previous behavior was\nundefined (and technically not stable).\n\nExpose the wifi display device address.\n\nPerform wifi display scans every 10 seconds instead of every 15\nto improve reponsiveness.\n\nMake sure to define routes for wifi displays that we are connecting\nto even if they are not yet paired.  Simplified the logic for\nadding and removing these routes to avoid possibly getting out\nof sync and leaving stale routes behind.\n\nFix wifi display notification icon.\n\nBug: 11257292\nChange-Id: I8ac15fb17d83758c0bdce80399e12723c367b83c\n"
    },
    {
      "commit": "8862929e2a5ae4936083b6d7ac7e908df256a885",
      "tree": "04dadd7d8fcf9368f59e0b3912c5fb098087493d",
      "parents": [
        "105b9b05041ea6f1109d961d548f3dde2bd69501"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Sun Nov 10 20:39:05 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Sun Nov 10 20:39:05 2013 -0800"
      },
      "message": "Use old task info when creating new task.\n\nWhen a new task is being created solely to protect the system from an\nold task going away, save the info from the old task and use it when\ncreating a new task.\n\nFixes bug 11615548.\n\nChange-Id: Ibc3fd15ec4b0d76bce30381fbd83b6899f6a9023\n"
    },
    {
      "commit": "7aa535a8633ec93426381c68dc061cd951ab5832",
      "tree": "92723a13d4a62235cf10f7675c759e046fda7d93",
      "parents": [
        "73d15db0f03cadbb54bf13400218191fb009a8d4",
        "01edb22617a96502dfb5297eff1cdf5f265299e2"
      ],
      "author": {
        "name": "Jim Miller",
        "email": "jaggies@google.com",
        "time": "Fri Nov 08 16:27:38 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Nov 08 16:27:38 2013 -0800"
      },
      "message": "am 01edb226: am ed7376fc: Merge \"Restore permission check in keyguard.\" into klp-dev\n\n* commit \u002701edb22617a96502dfb5297eff1cdf5f265299e2\u0027:\n  Restore permission check in keyguard.\n"
    },
    {
      "commit": "a8ee262c04749db4f32f73d2b9e7f58989c4638b",
      "tree": "a42dc5ce74eaba10c5022aa1905204a2ef44d4e1",
      "parents": [
        "105b9b05041ea6f1109d961d548f3dde2bd69501"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Fri Nov 08 15:24:22 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Fri Nov 08 15:36:23 2013 -0800"
      },
      "message": "Fix a couple of issues with mOpeningApps.\n\nIn setAppVisibility add wtoken to mOpeningApps even if the requested\nvisibility already matches requestedHidden. When Keyguard hides an app\nrequestedHidden will mismatch and mOpeningApps will end up empty where\nit should have the app that will become visible.\n\nAdd mAnimateWallpaperWithTarget \u003d true to another situation where\nwallpaper animation needs it.\n\nFixes bug 11570753.\n\nChange-Id: I70b93bbb580386eb912613f0ce11e582eff8c449\n"
    },
    {
      "commit": "505329b21b743c6e74e0d1b14bea78a22f7b4145",
      "tree": "de6e2e814ab04e443f1f95afcc4447fc8aad8e3b",
      "parents": [
        "b6d3c1cecadb50263c2682a89f9f0b2936bfcd19"
      ],
      "author": {
        "name": "Jim Miller",
        "email": "jaggies@google.com",
        "time": "Fri Nov 08 13:25:36 2013 -0800"
      },
      "committer": {
        "name": "Jim Miller",
        "email": "jaggies@google.com",
        "time": "Fri Nov 08 14:08:10 2013 -0800"
      },
      "message": "Restore permission check in keyguard.\n\nFixes bug 11584685\n\nChange-Id: I80621f5608505bdc365930e0276c297c0d5bff67\n"
    },
    {
      "commit": "eb544c338c39f3e9435ad1098d559b618d287cf2",
      "tree": "213cadc2f5c9baeb4a3eafb8c4d663ce7806bb38",
      "parents": [
        "913c0e38a1316f4a653563ba401a0095c54b71d0",
        "ca39478f33977ba6ba278fb9e3913144d7a5d0c2"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Fri Nov 08 11:16:17 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Nov 08 11:16:17 2013 -0800"
      },
      "message": "am ca39478f: am f99b017e: Merge \"Allow keyguard dialogs to show on secondary displays.\" into klp-dev\n\n* commit \u0027ca39478f33977ba6ba278fb9e3913144d7a5d0c2\u0027:\n  Allow keyguard dialogs to show on secondary displays.\n"
    },
    {
      "commit": "4fd791735b21162bc573ece564144fa4f0e2ed29",
      "tree": "9e34f83f6d33ca7abcd4207e8a7b76cfd8d464de",
      "parents": [
        "52277428d54cc71f0cde3f1efa035f1e6742b900"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Thu Nov 07 17:58:15 2013 -0800"
      },
      "committer": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Fri Nov 08 09:53:56 2013 -0800"
      },
      "message": "Allow keyguard dialogs to show on secondary displays.\n\nWhen the keyguard or a dream is visible, we usually block content\nfrom showing on secondary displays by mirroring the primary display\ncontents to them.  However, the keyguard may wish to show a\npresentation on a secondary display in which case we should not\nmirror.\n\nThis change adds an exemption for keyguard dialogs when the full\nscreen is obscured.  The keyguard can then create presentations with\nthe TYPE_KEYGUARD_DIALOG window type in order to show special\ncontent on other displays selectively.\n\nThe old code used to cause all secondary displays to mirror, which\nisn\u0027t quite what we want.\n\nBug: 11257292\nChange-Id: I55429002b2233ae25fe80db149636d6f41f2a112\n"
    },
    {
      "commit": "c2b652fd4d386b79dc99af249b6ad3844e53fdf1",
      "tree": "a2b18b14080224edefb19550266a341e2090b836",
      "parents": [
        "84d760257f46232601e5f47411fb4e59f57f1872",
        "5182ea4bb20ec8fbe9562d0eaae8135d433ea0b6"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Thu Nov 07 17:44:14 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 07 17:44:14 2013 -0800"
      },
      "message": "am 5182ea4b: am d40a4d74: Merge \"Add media router service and integrate with remote displays.\" into klp-dev\n\n* commit \u00275182ea4bb20ec8fbe9562d0eaae8135d433ea0b6\u0027:\n  Add media router service and integrate with remote displays.\n"
    },
    {
      "commit": "d40a4d74c623175c96a2e9d865a99826e56d1132",
      "tree": "8fcb8823aab60b909ff4962d5b00fdd5681ad806",
      "parents": [
        "1f7a8a06256907e03405f89108f081289c23e97a",
        "69b07161bebdb2c726e3a826c2268866f1a94517"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Fri Nov 08 01:36:55 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Nov 08 01:36:55 2013 +0000"
      },
      "message": "Merge \"Add media router service and integrate with remote displays.\" into klp-dev"
    },
    {
      "commit": "25f6d3e6e0d341239fc9ef56a6310e92bc5f21ce",
      "tree": "f2a8794f37ccb85f587723878a7282d43e0b86e1",
      "parents": [
        "bf98c0ccd9cab77ec06f7553c6bae317afcd6077",
        "f7dea15b8275dd012b1b00b9d781711eff82105a"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 07 12:58:20 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 07 12:58:20 2013 -0800"
      },
      "message": "am f7dea15b: am c9ffd746: Merge \"Don\\\u0027t call setTask twice.\" into klp-dev\n\n* commit \u0027f7dea15b8275dd012b1b00b9d781711eff82105a\u0027:\n  Don\u0027t call setTask twice.\n"
    },
    {
      "commit": "bf98c0ccd9cab77ec06f7553c6bae317afcd6077",
      "tree": "4a9be44fa811918dab8ecb11bb13aee2159ffeca",
      "parents": [
        "0be8fa713f67a873fbc73635e8f62bd30c297110",
        "c0eb7e7b545822dfb3cd43175886f2c97069e122"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 07 12:53:37 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 07 12:53:37 2013 -0800"
      },
      "message": "am c0eb7e7b: am 20409674: Merge \"If home activity is not fullscreen keep drilling.\" into klp-dev\n\n* commit \u0027c0eb7e7b545822dfb3cd43175886f2c97069e122\u0027:\n  If home activity is not fullscreen keep drilling.\n"
    },
    {
      "commit": "c9ffd74659fac6f30f3f4653586af2069b903899",
      "tree": "b92033444a8bb41611a4d5e65c9039e40de1d614",
      "parents": [
        "2040967478790f67e286b203d5397159ac34006e",
        "329f4129a5114af353477b999453ffdcedcbbc25"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 07 20:51:29 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 07 20:51:30 2013 +0000"
      },
      "message": "Merge \"Don\u0027t call setTask twice.\" into klp-dev"
    },
    {
      "commit": "2040967478790f67e286b203d5397159ac34006e",
      "tree": "8d3aebf155aad61e6760af80143f88975bac78cc",
      "parents": [
        "ff49e2d9d811db916190f61cc3cc03d4359d4952",
        "f41bcd47eac4c40fd51fac43c66fb2b5f754a9da"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 07 20:49:01 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 07 20:49:02 2013 +0000"
      },
      "message": "Merge \"If home activity is not fullscreen keep drilling.\" into klp-dev"
    },
    {
      "commit": "f41bcd47eac4c40fd51fac43c66fb2b5f754a9da",
      "tree": "315c7b59855abf907553c13a86d9338fdb3b25bc",
      "parents": [
        "7791b84c153463431635d2a8aa0fda7f1d8763a7"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 07 11:51:29 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 07 11:51:29 2013 -0800"
      },
      "message": "If home activity is not fullscreen keep drilling.\n\nWhen the home activity launches a non-fullscreen activity as part of\nits own task then ensureActivitiesVisibleLocked() must continue past\nthe launched activity when determining activities to show and hide.\nStopping at the non-fullscreen activity leaves the fullscreen home\nactivity hidden.\n\nFixes bug 11555762.\n\nChange-Id: I9058d8cde3a41cb7f9b1f97e5c0cb32e9b0f5af7\n"
    },
    {
      "commit": "c3eef19047b897bfb6e3cf42220d5146b187c66e",
      "tree": "d790ba2a57195512e0c264ff77e950a12cbe51f0",
      "parents": [
        "03be79b35ca7060f383075a43ff19c8a9d63a7c0",
        "f1612bcfdd2cb517948f14369fd0977ceb55d19c"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Thu Nov 07 10:39:43 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 07 10:39:43 2013 -0800"
      },
      "message": "am f1612bcf: am e8c51298: Merge \"Add BatteryStats for Wifi Batched Scanning.\" into klp-dev\n\n* commit \u0027f1612bcfdd2cb517948f14369fd0977ceb55d19c\u0027:\n  Add BatteryStats for Wifi Batched Scanning.\n"
    },
    {
      "commit": "e8c51298a43f607fea7418ced7cc783e6065fe87",
      "tree": "60229394e1992ac2fcdc5e2b50bd1bb50290c5f6",
      "parents": [
        "9882d3889957200c3db62f47142988dea99a7291",
        "a029ea131836725b050e1a7550aa171b68171522"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Thu Nov 07 18:30:49 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 07 18:30:49 2013 +0000"
      },
      "message": "Merge \"Add BatteryStats for Wifi Batched Scanning.\" into klp-dev"
    },
    {
      "commit": "03be79b35ca7060f383075a43ff19c8a9d63a7c0",
      "tree": "838ad704884042e15290a514c45403c518d7e7ed",
      "parents": [
        "d17f5a546bf8f610a4373bd8c74b9b74170887ac",
        "fbf4888d19b0c68d8004f9ad2423a583dc01178e"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Nov 07 10:21:34 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Nov 07 10:21:34 2013 -0800"
      },
      "message": "am fbf4888d: am 9882d388: Merge \"Fix issue #11223338: Not retaining service started state while restarting\" into klp-dev\n\n* commit \u0027fbf4888d19b0c68d8004f9ad2423a583dc01178e\u0027:\n  Fix issue #11223338: Not retaining service started state while restarting\n"
    },
    {
      "commit": "9882d3889957200c3db62f47142988dea99a7291",
      "tree": "959ae7957f7fde2eba1e253e419f980cdf32b697",
      "parents": [
        "41c2f04e2a7f48c88f59e91d4b2b130dbfb2fce5",
        "daa0d5c9296515fe05cae65926a66dee609f382a"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Nov 07 18:16:10 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 07 18:16:10 2013 +0000"
      },
      "message": "Merge \"Fix issue #11223338: Not retaining service started state while restarting\" into klp-dev"
    },
    {
      "commit": "329f4129a5114af353477b999453ffdcedcbbc25",
      "tree": "5f3b81c4d215a0fed151ac8fce1a57c2ae15230e",
      "parents": [
        "7791b84c153463431635d2a8aa0fda7f1d8763a7"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 07 09:10:42 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Thu Nov 07 09:10:42 2013 -0800"
      },
      "message": "Don\u0027t call setTask twice.\n\nThe method ActivityRecord.setTask() removes the ActivityRecord from\nits old task\u0027s mActivities ArrayList. In jb-mr2 it did not have this\nside effect (there was no mActivities) so calling it twice was not a\nproblem. This fix causes setTask to only be called once for the target\nactivity.\n\nFixes bug 11557835.\n\nChange-Id: If2b6d4b297e86130009713efe6891a24fad3dd15\n"
    },
    {
      "commit": "69b07161bebdb2c726e3a826c2268866f1a94517",
      "tree": "8d9c94f32a045a8f5c48ca0f1380abc760eac807",
      "parents": [
        "f3c99e883f46c56e5e2877e844b902b6eb45545b"
      ],
      "author": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Thu Nov 07 00:30:16 2013 -0800"
      },
      "committer": {
        "name": "Jeff Brown",
        "email": "jeffbrown@google.com",
        "time": "Thu Nov 07 03:25:37 2013 -0800"
      },
      "message": "Add media router service and integrate with remote displays.\n\nThis change adds a new media router service whose purpose is to track\nglobal state information associated with media routes.  This service\npublishes routes to the media router instance in application processes\nand handles requested state changes such as selecting or unselecting\nglobal routes.  The service also binds to remote display provider\nservices which can offer new remote display routes to the system.\n\nIncludes a test application for manually verifying certain aspects\nof the operation of the media router service.\n\nThe remote display provider interface is essentially a stripped down\nmedia route provider interface as defined in the support library\nmedia router implementation.  For now, it is designed to be used only\nby first parties to publish remote display routes to the system so\nit is not exposed as public API in the SDK.  In the future, the remote\ndisplay provider interface will most likely be deprecated and replaced\nwith a more featureful media route provider interface for third\nparty integration, similar to what is in the support library today.\n\nFurther patch sets integrate these new capabilities into the System UI\nand Settings for connecting remote displays.\n\nBug: 11257292\nChange-Id: I31109f23f17b474d17534d0f5f4503e388b081c2\n"
    },
    {
      "commit": "a029ea131836725b050e1a7550aa171b68171522",
      "tree": "8b1f76071b3bb23e9b949635b679c8b7306366fd",
      "parents": [
        "c157cac9b2827a4eeb0ea29209fbb879a6076de4"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Wed Sep 25 16:38:12 2013 -0700"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "rgreenwalt@google.com",
        "time": "Wed Nov 06 17:43:18 2013 -0800"
      },
      "message": "Add BatteryStats for Wifi Batched Scanning.\n\nbug:10690989\nChange-Id: Ia39b715ee6d5733970095bc76de0ed40ff8208c0\n"
    },
    {
      "commit": "90be73457e0a5e526db99dc6c9d35798d87067ca",
      "tree": "7d5ff7f0deac491d70853f72a50c9a3fd791915f",
      "parents": [
        "2f70da2bc5ce9f4766395cc9d848f0afe8f6a2a9",
        "aa719e92ffc2193db68c86b97fce291c27d5d4dd"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Wed Nov 06 16:59:18 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 06 16:59:18 2013 -0800"
      },
      "message": "am aa719e92: am c157cac9: Merge \"System package permission decls take precedence over 3rd party apps\\\u0027\" into klp-dev\n\n* commit \u0027aa719e92ffc2193db68c86b97fce291c27d5d4dd\u0027:\n  System package permission decls take precedence over 3rd party apps\u0027\n"
    },
    {
      "commit": "c157cac9b2827a4eeb0ea29209fbb879a6076de4",
      "tree": "470463774445643d1271c86ff8d9189b40b630ed",
      "parents": [
        "2942053c25b577f4ecdd431072cc438b16d2778b",
        "3aeea1f25a901b2c8d41aee35af91cf415908f64"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Thu Nov 07 00:54:54 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Nov 07 00:54:55 2013 +0000"
      },
      "message": "Merge \"System package permission decls take precedence over 3rd party apps\u0027\" into klp-dev"
    },
    {
      "commit": "daa0d5c9296515fe05cae65926a66dee609f382a",
      "tree": "9d4d92cd8e5466312df6180eaf88fae7eed9ec74",
      "parents": [
        "d64744cc764eb970df263aaebc44474d465686cb"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Wed Nov 06 16:30:29 2013 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Wed Nov 06 16:42:17 2013 -0800"
      },
      "message": "Fix issue #11223338: Not retaining service started state while restarting\n\nWhen I cleaned up how we maintained the lifecycle of the tracker with a\nservice, I broke most tracking of the service restart state.  (Since at\nthat point the service is no longer associated with a process, so I\nmust clean up the tracker state).  This change introduces a new special\ncase for interacting with a service tracker to explicitly tell it when\na service is being restarted.  It also fixes how we update the process\nstate when services are attached to it, so it goes in and out of the\nrestarting state correctly.\n\nIn addition:\n\n- Maybe fix issue #11224000 (APR: Dependent processes not getting added\n  to LRU list).  We were not clearing ServiceRecord.app when bringing\n  down a service, so if for some reason there were still connections to\n  it at that point (which could happen for example for non-create bindings),\n  then we would so it when updating the LRU state of that client process.\n- dumpsys procstats\u0027s package argument can now be a package or process\n  name, and we will dump all relevent information we can find about that\n  name.\n- Generally improved the quality of the dumpsys procstats output with its\n  various options.\n- Fixed a bug in ActivityManager.dumpPackageState() where it would hang if\n  the service was dumping too much, added meminfo to the set of things\n  dumped, and tweaked command line options to include more data.\n- Added some more cleaning code to ActiveServices.killServices() to make\n  sure we clean out any restarting ServiceRecord entries when a process is\n  being force stopped.\n- Re-arranged ActiveServices.killServices() to do the main killing of the\n  service first, to avoid some wtf() calls that could happen when removing\n  connections.\n\nBug: 11223338\nBug: 11224000\n\nChange-Id: I5db28561c2c78aa43561e52256ff92c02311c56f\n"
    },
    {
      "commit": "e5bdd85a99839e1d557c924d5396d510151da42e",
      "tree": "6c5d753d15582aacaaa59cbd95a22ab8f128b8f6",
      "parents": [
        "a2dad41e757b8de097491aedecca80387ba3af09",
        "ea18624ae557a06e49748964f951a81fd6c48370"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 06 15:30:23 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 06 15:30:23 2013 -0800"
      },
      "message": "am ea18624a: am c9d0ee5e: Merge \"Tweak test for layout.\" into klp-dev\n\n* commit \u0027ea18624ae557a06e49748964f951a81fd6c48370\u0027:\n  Tweak test for layout.\n"
    },
    {
      "commit": "c9d0ee5e8476bbe0d50b726f9cb4cf173d6f6952",
      "tree": "b301df6152ec2018c2b97be9b651fd9b1b5fd3de",
      "parents": [
        "def34eb775caf8eb56248d536ec56b39c47e4431",
        "f961b3c5b69da7a71382de65633aede3e16b661d"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 06 23:22:12 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Nov 06 23:22:12 2013 +0000"
      },
      "message": "Merge \"Tweak test for layout.\" into klp-dev"
    },
    {
      "commit": "f961b3c5b69da7a71382de65633aede3e16b661d",
      "tree": "22a696a3f910efe8e2a8380c502d1e69c0f8f440",
      "parents": [
        "db5c4fb8641061735b6b2971e74362761aeca970"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 06 14:52:36 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 06 14:52:36 2013 -0800"
      },
      "message": "Tweak test for layout.\n\nReturn to old way of only laying out Keyguard on configuration change\nand add a new qualifier that does a layout if a window is part of an\nopening app. This qualifier allows apps that handle their own\nconfiguration changes to be notified of screen changes after the\nconfiguration has changed. Apps that do not handle their own\nconfiguration changes find their way into this code because their\nsurfaces are recreated by default and mHaveFrame is false.\n\nThis fixes bug 11544694 and passes the test of all bugs listed in CL\nag/383579.\n\nChange-Id: I3a679b27eb4a2c5210957bcd4ae2f10b46f6e076\n"
    },
    {
      "commit": "f6744886f2dba3865beb2b3dff33d7bf747fe772",
      "tree": "055c6895fefff62f098118b19ffce031eb6720de",
      "parents": [
        "cd6258b50f94d69a3ba677c2d17bed824c10cdd2",
        "b9132543b02e76e7ca8f043ed68667a189b64cc0"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 06 14:25:32 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 06 14:25:32 2013 -0800"
      },
      "message": "am b9132543: am a724d865: Merge \"Fix incorrect looping limits.\" into klp-dev\n\n* commit \u0027b9132543b02e76e7ca8f043ed68667a189b64cc0\u0027:\n  Fix incorrect looping limits.\n"
    },
    {
      "commit": "a724d865372530e01e4bb14751e0305da9bc377b",
      "tree": "f8cb09cfbf08f2aedc0077a9f5c79c6b1efae4ba",
      "parents": [
        "10b9ac807f7cc0817e8dd4b96d587ccd41f8f177",
        "db5c4fb8641061735b6b2971e74362761aeca970"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 06 22:20:24 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Nov 06 22:20:25 2013 +0000"
      },
      "message": "Merge \"Fix incorrect looping limits.\" into klp-dev"
    },
    {
      "commit": "db5c4fb8641061735b6b2971e74362761aeca970",
      "tree": "322fabfd80e2fb731745c08cace2db3346c3f95c",
      "parents": [
        "7791b84c153463431635d2a8aa0fda7f1d8763a7"
      ],
      "author": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 06 13:55:08 2013 -0800"
      },
      "committer": {
        "name": "Craig Mautner",
        "email": "cmautner@google.com",
        "time": "Wed Nov 06 13:55:08 2013 -0800"
      },
      "message": "Fix incorrect looping limits.\n\nOne cannot iterate across an entire list if one both removes an entry\nand increments the index into the list. Do one or the other or you\nwill end up with bugs like 11556768 which is now fixed.\n\nChange-Id: I57f1ad13075a005cae3c1cbfae10e230d9af143a\n"
    },
    {
      "commit": "09bfaa7991066703d1dca87b4ab8e68a30076990",
      "tree": "e3afa31b5b888415b5c7e936f7045b2d309b00c7",
      "parents": [
        "dd3776d673776785f32aa7d813871a38de906c5d",
        "ce89135a53b1f5c0e7f34dbae12794f4421d9390"
      ],
      "author": {
        "name": "Michael Wright",
        "email": "michaelwr@google.com",
        "time": "Wed Nov 06 12:36:41 2013 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Nov 06 12:36:41 2013 -0800"
      },
      "message": "am ce89135a: am 6a29778e: Merge \"Continue synthesizing data even after brightness adjustment\" into klp-dev\n\n* commit \u0027ce89135a53b1f5c0e7f34dbae12794f4421d9390\u0027:\n  Continue synthesizing data even after brightness adjustment\n"
    },
    {
      "commit": "6a29778eeb836fe01993b6dbd3734d8085f48015",
      "tree": "0515135777576f5d61a2f8137afe351d631c98f1",
      "parents": [
        "c89eaf916ad7e88565d2a15991432b22cd9099ff",
        "65031a29132e50a7e233d61c1fedc99b88604c6e"
      ],
      "author": {
        "name": "Michael Wright",
        "email": "michaelwr@google.com",
        "time": "Wed Nov 06 20:33:08 2013 +0000"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Nov 06 20:33:08 2013 +0000"
      },
      "message": "Merge \"Continue synthesizing data even after brightness adjustment\" into klp-dev"
    },
    {
      "commit": "3aeea1f25a901b2c8d41aee35af91cf415908f64",
      "tree": "10a5b39d47701e41bbf778e371076b9f324a6b96",
      "parents": [
        "8869d6f3537b323d1c9d1339d057a4866520e649"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Tue Nov 05 12:28:10 2013 -0800"
      },
      "committer": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Tue Nov 05 16:27:07 2013 -0800"
      },
      "message": "System package permission decls take precedence over 3rd party apps\u0027\n\nIn particular, if a 3rd party app tries to define a permission that\nturns out to be defined by system packages following an upgrade,\nthe system package gets ownership and grants are re-evaluated\non that basis.\n\nBug 11242510\n\nChange-Id: Id3a2b53d52750c629414cd8226e33e5e03dd0c54\n"
    }
  ],
  "next": "65031a29132e50a7e233d61c1fedc99b88604c6e"
}
