)]}'
{
  "log": [
    {
      "commit": "b0dcaaf108d70040e4e4e4ac65df1a7eae732d1e",
      "tree": "9f724399126713699cd0ea14338c78ae3985aa6a",
      "parents": [
        "239d5b3638ae486f715f44a8c1a71420f486049c"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Fri Jan 29 16:27:04 2010 -0800"
      },
      "committer": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Fri Jan 29 16:27:04 2010 -0800"
      },
      "message": "Don\u0027t crash on transport unregistration if there is no current transport\n\nChange-Id: Icd0962254ba224a7be27d408dffb25b634f67863\n"
    },
    {
      "commit": "4a20061f341ffaa8531993a851a3dfbfcdc8e38d",
      "tree": "168ec3abef77edfff59360e8fff42187fdea7fc2",
      "parents": [
        "e6c73c2018bcd61aa1f9c1ce735a6813d40fe84d",
        "44a2790374bf27116cbd91060d4f096ca5999709"
      ],
      "author": {
        "name": "Chris Tate",
        "email": "ctate@android.com",
        "time": "Fri Jan 29 15:02:03 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jan 29 15:02:03 2010 -0800"
      },
      "message": "Merge \"Make backup/restore asynchronous and enforce timeouts\""
    },
    {
      "commit": "44a2790374bf27116cbd91060d4f096ca5999709",
      "tree": "562efb45caf90c9f04630ab9e70c7fc7e7fb282d",
      "parents": [
        "4d3cef348b4350abd9d50230376ff8b1d2ac4654"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Wed Jan 27 17:15:49 2010 -0800"
      },
      "committer": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Fri Jan 29 14:07:52 2010 -0800"
      },
      "message": "Make backup/restore asynchronous and enforce timeouts\n\nCallouts to app backup agents are now asynchronous, and timeouts are applied if\nthey take too long, hang, etc.  The initial timeouts are set to 15 seconds on\nbackup, 60 seconds on restore.  These operations typically run at background\npriority, so it\u0027s necessary to give them ample time to run.\n\nAs part of setting up this asynchronicity, the Backup Manager\u0027s internal thread\nmanagement has been overhauled.  It now spins off a single HandlerThread at\nstartup, and runs backup/restore/etc operations *synchronously* in that thread,\napplying timeouts as appropriate.  This means we\u0027re no longer spinning up new\nthreads all the time, and furthermore it ensures that we can never have more\nthan one operation in flight at once.  Later CLs will remove the now-redundant\nlogic that previously ensured that operations didn\u0027t stomp on each other.\n\nBug: 2053560\nChange-Id: Ie4315c219c7ff6dd8f51f2ad6c0872595b18cff1\n"
    },
    {
      "commit": "ef73162887943e16587b8e737b19e59348338e8c",
      "tree": "8a769b3abba1289bd2d6c39cc801c656491f60e2",
      "parents": [
        "3b889f52195cbbc12200ca237e312e825003132d"
      ],
      "author": {
        "name": "Mike Lockwood",
        "email": "lockwood@android.com",
        "time": "Wed Jan 27 17:51:34 2010 -0500"
      },
      "committer": {
        "name": "Mike Lockwood",
        "email": "lockwood@android.com",
        "time": "Fri Jan 29 17:05:04 2010 -0500"
      },
      "message": "Support for triggering the lockscreen while the screen is on:\n\nAdd new ALLOW_LOCK_WHILE_SCREEN_ON window manager flag, which when set\ncauses the window manager to put up the lockscreen after the\nnormal screen timeout has elapsed.\n\nAdd plumbing to pass PowerManager.userActivity() to the window manager policy.\n\nChange-Id: I05adc52bad39c56031a08e8ec3cbcf5c2d9b9827\nSigned-off-by: Mike Lockwood \u003clockwood@android.com\u003e\n"
    },
    {
      "commit": "bd2f531a2836d3ad09755856c9c84cf75eb900d7",
      "tree": "2e5e74a0e2bc5c2aa0a906b591d1de9fc8493ae7",
      "parents": [
        "d425a45f8d7c0e94d2db4c0a5c8157e6c846b853",
        "5fd5bfe942a03a2a0f8b55e78138e5ca7d578c6b"
      ],
      "author": {
        "name": "Suchi Amalapurapu",
        "email": "asuchitra@google.com",
        "time": "Fri Jan 29 08:45:39 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jan 29 08:45:39 2010 -0800"
      },
      "message": "Merge \"Fix StringIndexOutOfBoundsException in PackageManagerService\""
    },
    {
      "commit": "d425a45f8d7c0e94d2db4c0a5c8157e6c846b853",
      "tree": "a2424eebb5622a5542d050a18eed50d27e8a02e2",
      "parents": [
        "b4a162e50a96d2eef5fa3ed686e1418c4fbc8ded"
      ],
      "author": {
        "name": "Daniel Sandler",
        "email": "dsandler@google.com",
        "time": "Fri Jan 29 10:06:53 2010 -0500"
      },
      "committer": {
        "name": "Daniel Sandler",
        "email": "dsandler@google.com",
        "time": "Fri Jan 29 10:09:04 2010 -0500"
      },
      "message": "Fix build.\n\n(Broken in change Ib94f795c.)\n"
    },
    {
      "commit": "77c292d83e70793dcb23677ab60a6c707fc613dd",
      "tree": "0c65c432e70e048e0dbfdb2ded1ef55c3bbbe017",
      "parents": [
        "784d53e79bab67e6b08b4bfc9a2dc75cfcba9772",
        "b94f795c257e32a1d7be1115568b5b6f576dec37"
      ],
      "author": {
        "name": "Daniel Sandler",
        "email": "dsandler@android.com",
        "time": "Fri Jan 29 06:22:33 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jan 29 06:22:33 2010 -0800"
      },
      "message": "Merge \"New full-screen activity for USB mass storage interaction.\""
    },
    {
      "commit": "5fd5bfe942a03a2a0f8b55e78138e5ca7d578c6b",
      "tree": "b2ed5440a50415eb8945387125c631440953b8d2",
      "parents": [
        "784d53e79bab67e6b08b4bfc9a2dc75cfcba9772"
      ],
      "author": {
        "name": "Bjorn Bringert",
        "email": "bringert@android.com",
        "time": "Fri Jan 29 12:11:30 2010 +0000"
      },
      "committer": {
        "name": "Bjorn Bringert",
        "email": "bringert@android.com",
        "time": "Fri Jan 29 12:29:41 2010 +0000"
      },
      "message": "Fix StringIndexOutOfBoundsException in PackageManagerService\n\nThe method packageManagerService.getNextCodePath(String oldCodePath,\nString prefix, String suffix) threw StringIndexOutOfBoundsException if\noldCodePath does not contain prefix, and prefix is longer than\noldCodePath, or if the preix and suffix overlap.\n\nFixes http://b/issue?id\u003d2404232\n\nChange-Id: Ib8abb16f8bfd08f607476d9289f46d170c43a076\n"
    },
    {
      "commit": "784d53e79bab67e6b08b4bfc9a2dc75cfcba9772",
      "tree": "3fe04da1c937d334405ef77d26fd7d823e19b4bd",
      "parents": [
        "a9938c4bf491cdf0df3b6b1fe41e0e3ef5a2dfbb"
      ],
      "author": {
        "name": "Chia-chi Yeh",
        "email": "chiachi@android.com",
        "time": "Fri Jan 29 16:26:28 2010 +0800"
      },
      "committer": {
        "name": "Chia-chi Yeh",
        "email": "chiachi@android.com",
        "time": "Fri Jan 29 16:26:28 2010 +0800"
      },
      "message": "WifiService: allow EAP variables to be unset using empty strings.\n"
    },
    {
      "commit": "c4a0c2744a19a42bd1f5c39a6f1673310c6f9c3a",
      "tree": "c55900746cc0ef90b0d3146f6924dde6de9f52b8",
      "parents": [
        "5e342fa3260044353705c946d3ae62c89df52ee6",
        "0049a1bf3f8bae3a10cfeff38aefce215bf1298b"
      ],
      "author": {
        "name": "Irfan Sheriff",
        "email": "isheriff@google.com",
        "time": "Thu Jan 28 20:46:25 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Jan 28 20:46:25 2010 -0800"
      },
      "message": "Merge \"Blacklist APs instead of disable\""
    },
    {
      "commit": "fbf56dc719a2ee13129fd7049565054370c6ed1d",
      "tree": "1afad344e45b31b4479091086b15738d1a777640",
      "parents": [
        "8cc99938c3e3d1a8cfe29b6826e120dbed15a338",
        "3e229076203cd8cfee0adac44cd3c930dfa0e59c"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Thu Jan 28 14:46:55 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Jan 28 14:46:55 2010 -0800"
      },
      "message": "am 3e229076: am cc4b4016: Fix the reporting of NO_CONNECTIVITY.\n\nMerge commit \u00273e229076203cd8cfee0adac44cd3c930dfa0e59c\u0027\n\n* commit \u00273e229076203cd8cfee0adac44cd3c930dfa0e59c\u0027:\n  Fix the reporting of NO_CONNECTIVITY.\n"
    },
    {
      "commit": "64fe5646c5b2eb5ff58cea4ca4d384b4a5f733dc",
      "tree": "1f03e532dea35a41adf56a089bf35dc6d4ecb667",
      "parents": [
        "e7d9ba249a2b6d155e30c9b76bff8aa1c5ccaecb",
        "6d626d41e9db62a0eadb61ccb2aa4081a8b9f6d0"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Thu Jan 28 13:44:45 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Jan 28 13:44:45 2010 -0800"
      },
      "message": "am 6d626d41: am 5381e4ef: Merge \"Refine fix I53e91db7 to apply only to wifi network\" into eclair\n\nMerge commit \u00276d626d41e9db62a0eadb61ccb2aa4081a8b9f6d0\u0027\n\n* commit \u00276d626d41e9db62a0eadb61ccb2aa4081a8b9f6d0\u0027:\n  Refine fix I53e91db7 to apply only to wifi network\n"
    },
    {
      "commit": "b94f795c257e32a1d7be1115568b5b6f576dec37",
      "tree": "7a97a296b6e6f153c9533486cfed9e7367504766",
      "parents": [
        "5f551ef6a8b6a4f158d8b3ad9591d2f874c89f39"
      ],
      "author": {
        "name": "Daniel Sandler",
        "email": "dsandler@google.com",
        "time": "Thu Jan 28 15:12:04 2010 -0500"
      },
      "committer": {
        "name": "Daniel Sandler",
        "email": "dsandler@google.com",
        "time": "Thu Jan 28 16:18:22 2010 -0500"
      },
      "message": "New full-screen activity for USB mass storage interaction.\n\nStill TODO: patch into forthcoming callbacks from\nMountService so the USB storage activity always shows the\ncorrect state of the device. (Right now it only refreshes\nits display onResume.)\n\nBug: 2299129\n"
    },
    {
      "commit": "254cb446faa7cb13699d8150eb4cc4f44cb61a2d",
      "tree": "1647a7558348a67989c0892b4e5b0350ba4392c5",
      "parents": [
        "2fd75f35158b8347251d18e8ec48585d6e020777"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Wed Jan 27 19:23:59 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Jan 28 13:15:57 2010 -0800"
      },
      "message": "More device admin.\n\n- Clean up device policy manager APIs.\n- Implement lockNow().  For now this just turns the screen off to lock the device.\n"
    },
    {
      "commit": "bdbc925a275b4ba4217ec7ac0ad2ec5f913d4e51",
      "tree": "568aa9c4a713e68a9a9c179326448ea4eb2fc2ea",
      "parents": [
        "5f551ef6a8b6a4f158d8b3ad9591d2f874c89f39",
        "b0903104fd2fe7a69331758fba769c8067e26771"
      ],
      "author": {
        "name": "Kenny Root",
        "email": "kroot@google.com",
        "time": "Thu Jan 28 12:03:49 2010 -0800"
      },
      "committer": {
        "name": "Kenny Root",
        "email": "kroot@google.com",
        "time": "Thu Jan 28 12:03:49 2010 -0800"
      },
      "message": "resolved conflicts for merge of b0903104 to master\n\nChange-Id: Iff20980c44d42b41ae411c4201e0927cee19d415\n"
    },
    {
      "commit": "0049a1bf3f8bae3a10cfeff38aefce215bf1298b",
      "tree": "7153232b780840367b5ca29b08f8d66d3633520d",
      "parents": [
        "5f551ef6a8b6a4f158d8b3ad9591d2f874c89f39"
      ],
      "author": {
        "name": "Irfan Sheriff",
        "email": "isheriff@google.com",
        "time": "Thu Jan 14 12:37:49 2010 -0800"
      },
      "committer": {
        "name": "Irfan Sheriff",
        "email": "isheriff@google.com",
        "time": "Thu Jan 28 11:27:14 2010 -0800"
      },
      "message": "Blacklist APs instead of disable\n\nWe currently disable networks upon too many reconnects. This leads to asking\nthe user input for reconnects. Blacklist it instead.\n\nBug: 2129037\nChange-Id: I23d69daf3964c066ed7f70d32fefb81016f19aa2\n"
    },
    {
      "commit": "f1a0f55f7145bc3c769752395d29b282f1f133f2",
      "tree": "6c1356e498c94d400772119346904e1351c49fc4",
      "parents": [
        "70aaacac8217552ae4def243011c5359075836b0",
        "131c5e0867d542788cf2dab23b17f2f8cc3d0391"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Thu Jan 28 10:09:09 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Jan 28 10:09:09 2010 -0800"
      },
      "message": "am 131c5e08: am a59551ba: Merge \"Fix issue 2388215: Audio not routed to 3.5mm Headset after removal/insertion.\" into eclair\n\nMerge commit \u0027131c5e0867d542788cf2dab23b17f2f8cc3d0391\u0027\n\n* commit \u0027131c5e0867d542788cf2dab23b17f2f8cc3d0391\u0027:\n  Fix issue 2388215: Audio not routed to 3.5mm Headset after removal/insertion.\n"
    },
    {
      "commit": "51e93db9402dc19ed923fa4b586b9b37ff85eafe",
      "tree": "77525c8256eb392c134dd9517c9d5f554062dc33",
      "parents": [
        "9d0f609251ccea1cee0fb32da6d449bdde317604",
        "40b5110e746060ec67307da70f662826c18228a7"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Thu Jan 28 06:50:18 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Jan 28 06:50:18 2010 -0800"
      },
      "message": "Merge \"Remove destroy asec command when mounting secure container\""
    },
    {
      "commit": "8ea25cc1a104bfc95d5742a8c0ab582c7812ee74",
      "tree": "9392c573937d085fedf326955df4e1ab98a875f7",
      "parents": [
        "c58ffe8253ca76160908d153242d8150f668ea32",
        "41a9fd55ac0f50afb3d70b1ba0786dbb316eebce"
      ],
      "author": {
        "name": "Jacek Surazski",
        "email": "jaceks@google.com",
        "time": "Thu Jan 28 00:09:56 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Jan 28 00:09:56 2010 -0800"
      },
      "message": "Merge \"timestamp field in ApplicationErrorReport was not getting intitialized on ANRs\""
    },
    {
      "commit": "40b5110e746060ec67307da70f662826c18228a7",
      "tree": "606838f8a7c6825e21acf08543d5622278db7adb",
      "parents": [
        "a322dfa47eab8d49eeb71b5245de7147c0207137"
      ],
      "author": {
        "name": "Suchi Amalapurapu",
        "email": "asuchitra@google.com",
        "time": "Wed Jan 27 23:46:13 2010 -0800"
      },
      "committer": {
        "name": "Suchi Amalapurapu",
        "email": "asuchitra@google.com",
        "time": "Wed Jan 27 23:46:13 2010 -0800"
      },
      "message": "Remove destroy asec command when mounting secure container\n"
    },
    {
      "commit": "d47c6ed4a9f2b5bd31f6c806b74701428efe458b",
      "tree": "dcaea393c297e01163a4f57e377e295cf3cbe877",
      "parents": [
        "9cf5b455d95ff2024b6d23e3416aca4abf93ff8c"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Wed Jan 27 16:21:20 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Wed Jan 27 17:31:56 2010 -0800"
      },
      "message": "Bite the bullet and add support for multiple device admins.\n"
    },
    {
      "commit": "41a9fd55ac0f50afb3d70b1ba0786dbb316eebce",
      "tree": "73ab0a72e30b713409942fe32c9eca796023b8ec",
      "parents": [
        "3ae6162d187a7166030263f8e9534aac65f3ae47"
      ],
      "author": {
        "name": "Jacek Surazski",
        "email": "jaceks@google.com",
        "time": "Wed Jan 27 16:37:21 2010 -0800"
      },
      "committer": {
        "name": "Jacek Surazski",
        "email": "jaceks@google.com",
        "time": "Wed Jan 27 16:37:21 2010 -0800"
      },
      "message": "timestamp field in ApplicationErrorReport was not getting intitialized on ANRs\n"
    },
    {
      "commit": "3ae6162d187a7166030263f8e9534aac65f3ae47",
      "tree": "1dc8d25a96cc6ac7af2c926988cfd0fdc6f01ee1",
      "parents": [
        "2060b637f793c1ac969aad85ab0b8e27351ab711",
        "492c6ed5b64cfdd72dc270e6b848025a26eff724"
      ],
      "author": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Wed Jan 27 15:06:06 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Jan 27 15:06:06 2010 -0800"
      },
      "message": "Merge \"Report tombstone (native crash) data to the dropbox.\""
    },
    {
      "commit": "492c6ed5b64cfdd72dc270e6b848025a26eff724",
      "tree": "ed54858954d1f51416d2ec331dabf52ca2dd5b42",
      "parents": [
        "ea11654e684cb91252487f697c72e76da507f7be"
      ],
      "author": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Wed Jan 27 14:52:57 2010 -0800"
      },
      "committer": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Wed Jan 27 14:52:57 2010 -0800"
      },
      "message": "Report tombstone (native crash) data to the dropbox.\n\nAlso uses a shared_prefs file to keep track of which files have been\nlogged, instead of polluting Settings.Secure with this data.\n"
    },
    {
      "commit": "8ea138cbf12b140d43fd81f4f12fe1a9234f1f25",
      "tree": "65d820bd65d69af867e4558b1fbd407634309eb2",
      "parents": [
        "2fc1f4a02957de3fdc785ca3dde414fb8e97bc49"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Tue Jan 26 18:01:04 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Wed Jan 27 13:51:53 2010 -0800"
      },
      "message": "More work on device admins:\n\n- You can now show a dynamic message to the user when asking to\n  have your DeviceAdmin added.\n- A DeviceAdmin can now provide a warning message that is displayed\n  before a user disables it.\n- Better ordering (and text) of the policy warnings.\n- New API to set the maximum failed password attempts before the device\n  wipes itself.\n- We now store the number of failed unlock attempts in persistent\n  storage.\n- New managed dialog APIs that will be used by the settings app.\n\nAlso a little bit of cleanup as I was working on this - removed the\nlong unused MailboxNotAvailableException, fixed a java doc in Messenger.\n"
    },
    {
      "commit": "c028be4f3b8c7476b46859f66c3f33d528adf181",
      "tree": "8a740e6207e958572706a636fcb92425dbf13a6e",
      "parents": [
        "aeb4126736c1b93abe5252e1723c568a13da7c81"
      ],
      "author": {
        "name": "Suchi Amalapurapu",
        "email": "asuchitra@google.com",
        "time": "Mon Jan 25 12:19:12 2010 -0800"
      },
      "committer": {
        "name": "Suchi Amalapurapu",
        "email": "asuchitra@google.com",
        "time": "Wed Jan 27 10:26:43 2010 -0800"
      },
      "message": "AppsOnSd feature - Add default container\n\nAdd new remote interface to do temporary copies. The new\nremote stub handling is done on mHandler thread and doesn\u0027t need locking\nfor now.\nAdd new InstallArgs class and subclasses to isolate cases for installation.\nMove resource deletion for failed installs/upgrades to later on in installation\ncycle.\nFix code path for forward locked apps when using scanPackageLI\n\nTODO\u0027s\nFix installation paths to completely use InstallArgs based design later on.\nGet rid of using flags in various install/uninstall code paths.\nIdeally InstallArgs should be created using these flags and used in the\nrest of the code.\nFunction renames.\nRevisit mount api\u0027s.\n"
    },
    {
      "commit": "02735bc9b7686e56957cdec9c10660c4a6dd1090",
      "tree": "748812633f2058e2b0c624f3d25b9110d668edf6",
      "parents": [
        "4539f38aec841cac74b170293d6d921acda96430"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 15:18:08 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Wed Jan 27 06:14:28 2010 -0800"
      },
      "message": "MountService: Introduce new @hide permissions to protect secure containers.\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "78d5ba9dbce20312aca11ae0a6e9366af3a08778",
      "tree": "24f28930b8d8893974f22a015516ec5b64dc6d01",
      "parents": [
        "c597b188bd0cf461231dac008b6e9eb8efde6ada",
        "ea11654e684cb91252487f697c72e76da507f7be"
      ],
      "author": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Tue Jan 26 20:05:20 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Jan 26 20:05:20 2010 -0800"
      },
      "message": "Merge changes Iea11654e,I2242da5a,I66c40e73\n\n* changes:\n  Use six dashes instead of five.\n  Include more verbose device information with kernel dumps (hardware, bootloader, etc.), and separate the device info headers from the actual dump with a blank line.\n  Add package information to dropbox reports for ANR, crash, etc. (Notably including package version codes, to help when we\u0027re shipping out-of-cycle unbundled app updates.)\n"
    },
    {
      "commit": "2242da5a4fadbef936153b4e43218d73033a11cd",
      "tree": "69b42c37c5fe954754d79dc625e70f821e7936da",
      "parents": [
        "66c40e73662d0e3090cd6e7f7e4e6dcb4867b8bd"
      ],
      "author": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Tue Jan 26 17:00:36 2010 -0800"
      },
      "committer": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Tue Jan 26 17:00:36 2010 -0800"
      },
      "message": "Include more verbose device information with kernel dumps\n(hardware, bootloader, etc.), and separate the device info\nheaders from the actual dump with a blank line.\n"
    },
    {
      "commit": "c2a39471642e31d7350910612e40d078b825173a",
      "tree": "8cc55af2b3170b80436b68f1a6f2c94fa1a5fb51",
      "parents": [
        "ec3cad8ec6b18da75b179d0fd279d652ae8fc1aa"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 16:51:35 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 16:52:23 2010 -0800"
      },
      "message": "MountService: Don\u0027t update the storage status when we\u0027re unmounted\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "66c40e73662d0e3090cd6e7f7e4e6dcb4867b8bd",
      "tree": "b6cb95e7f878e3880745e00fcdc14a9d460f4f5a",
      "parents": [
        "ec3cad8ec6b18da75b179d0fd279d652ae8fc1aa"
      ],
      "author": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Tue Jan 26 16:23:11 2010 -0800"
      },
      "committer": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Tue Jan 26 16:23:11 2010 -0800"
      },
      "message": "Add package information to dropbox reports for ANR, crash, etc.\n(Notably including package version codes, to help when we\u0027re shipping\nout-of-cycle unbundled app updates.)\n"
    },
    {
      "commit": "ec3cad8ec6b18da75b179d0fd279d652ae8fc1aa",
      "tree": "aab4d43b1b72f62a53bf9ed7363c5e24b18bce33",
      "parents": [
        "7b04317be85245ec3987421fc5cfa73df9442ae4",
        "5b77dab23469273d41f9c530d947ac055765e6ea"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 14:18:47 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Jan 26 14:18:47 2010 -0800"
      },
      "message": "Merge \"MountService: Explicitly query volume state on startup\""
    },
    {
      "commit": "7b04317be85245ec3987421fc5cfa73df9442ae4",
      "tree": "d49e623ef246f7133652b8e6155dc7ed243ed26d",
      "parents": [
        "b91f4643b66dc263d5c69ced9faf6980edec5583",
        "80120b43745102b3a8c635c796698d748b329222"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 13:38:41 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Jan 26 13:38:41 2010 -0800"
      },
      "message": "Merge \"NativeDaemonConnector: fix doListCommand() to return *all* list elements\""
    },
    {
      "commit": "5b77dab23469273d41f9c530d947ac055765e6ea",
      "tree": "4b9625ce58751940adcd9a2435595aa62d8dd025",
      "parents": [
        "80120b43745102b3a8c635c796698d748b329222"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 13:28:50 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 13:28:50 2010 -0800"
      },
      "message": "MountService: Explicitly query volume state on startup\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "80120b43745102b3a8c635c796698d748b329222",
      "tree": "b765a470284fd3aa694a7cb6f786c58506bd4a94",
      "parents": [
        "03b58bdf0e97f9e3bd247cb731b69fa87a845eeb"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 12:48:39 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 13:18:03 2010 -0800"
      },
      "message": "NativeDaemonConnector: fix doListCommand() to return *all* list elements\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "b91f4643b66dc263d5c69ced9faf6980edec5583",
      "tree": "2a39bc27ee50de7056b4495905070cbb853ed8f4",
      "parents": [
        "8aa2e8939c61d788cbc192098465e79f584e173a",
        "80202c8cb8c8e4ab507079e79b864c61a8eeeee9"
      ],
      "author": {
        "name": "Chris Tate",
        "email": "ctate@android.com",
        "time": "Tue Jan 26 12:29:13 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Jan 26 12:29:13 2010 -0800"
      },
      "message": "Merge \"Move towards a formal public API for backup and restore\""
    },
    {
      "commit": "8aa2e8939c61d788cbc192098465e79f584e173a",
      "tree": "83f2ea06758e1bb3f28a8fabedae29c3a5b89582",
      "parents": [
        "148fea03caed2a082387c45ae12a91561b8e41e5"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Fri Jan 22 11:31:30 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Tue Jan 26 12:28:15 2010 -0800"
      },
      "message": "More device admin work: description, policy control.\n\nThere is now a description attribute associated with all components,\nthat can supply user-visible information about what the component does.\nWe use this to show such information about device admins, and wallpapers\nare also updated to be able to show this in addition to the existing\ndescription in their meta-data.\n\nThis also defines security control for admins, requiring that they\ndeclare the policies they will touch, and enforcing that they do\nso to be able to use various APIs.\n"
    },
    {
      "commit": "508370f0cb5d3e03b1bcf04f1164ea1f384f496f",
      "tree": "a2c873a202605c3245c1fd4aef7e835cc6782d1d",
      "parents": [
        "9903f71b046e29bf6c1a3b7d3dc7facf372aa6f4",
        "1edab2b551995a8df25f4b533405d6003b8b8b66"
      ],
      "author": {
        "name": "David Turner",
        "email": "digit@google.com",
        "time": "Tue Jan 26 11:24:47 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Jan 26 11:24:47 2010 -0800"
      },
      "message": "Merge \"Make PackageManager unpack gdbserver binaries at installation time.\""
    },
    {
      "commit": "09ac3c3cbc6278af127cffedb9d534449e63b683",
      "tree": "bd1a1058521b559c935474cb734af04c054a5ef3",
      "parents": [
        "996dddff64f90d8469e24107c44bfd618cf0c2dd",
        "1f2f23bd16ff798a08d73f4159ddcb621e70fc94"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Tue Jan 26 10:09:52 2010 -0800"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Tue Jan 26 10:09:52 2010 -0800"
      },
      "message": "resolved conflicts for merge of 1f2f23bd to master\n"
    },
    {
      "commit": "d1df8ac6d076ef15ba8857211da2e447b6505fb3",
      "tree": "dc726575cfa963ce7ae3bf9444b0e9c13dea8317",
      "parents": [
        "0c8569f2a345b8321ff842d76191b5d72b4bdb54"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 06:17:26 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 26 07:51:05 2010 -0800"
      },
      "message": "NetworkManagementService: Start service when SystemServer starts up\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "80202c8cb8c8e4ab507079e79b864c61a8eeeee9",
      "tree": "517c775feb878d11f2e10eec0074907cea724574",
      "parents": [
        "da77d0a6e7fe70b7da229077039bcca1f232bd89"
      ],
      "author": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Mon Jan 25 19:37:47 2010 -0800"
      },
      "committer": {
        "name": "Christopher Tate",
        "email": "ctate@google.com",
        "time": "Mon Jan 25 19:41:23 2010 -0800"
      },
      "message": "Move towards a formal public API for backup and restore\n\nThis commit makes a few changes towards establishing a formal application\ninterface for interacting with the backup/restore mechanism:\n\n1. Introduce public wrapper classes around the various binder interfaces; 3rd\nparty code will never see the binders directly.\n\n2. Progress update callbacks during a restore sequence now occur on the main\nthread, not in a binder thread [and not with system-process permissions!].\n\n3. Rename the BackupManagerService\u0027s inner \"RestoreSession\" class to avoid\nambiguity with the new public \"RestoreSession\" class.\n"
    },
    {
      "commit": "3e229076203cd8cfee0adac44cd3c930dfa0e59c",
      "tree": "8d5092ece3522eaa35f9a37e73cd47d32bffdee8",
      "parents": [
        "6d626d41e9db62a0eadb61ccb2aa4081a8b9f6d0",
        "cc4b4016e4b86db012f94bb889e5ca61ff362171"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Mon Jan 25 18:56:32 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Jan 25 18:56:32 2010 -0800"
      },
      "message": "am cc4b4016: Fix the reporting of NO_CONNECTIVITY.\n\nMerge commit \u0027cc4b4016e4b86db012f94bb889e5ca61ff362171\u0027 into eclair-plus-aosp\n\n* commit \u0027cc4b4016e4b86db012f94bb889e5ca61ff362171\u0027:\n  Fix the reporting of NO_CONNECTIVITY.\n"
    },
    {
      "commit": "cc4b4016e4b86db012f94bb889e5ca61ff362171",
      "tree": "07c0ed9947d212533c0db058a642a18da508bfb3",
      "parents": [
        "5381e4ef4ef1a05b25fa39ff942f4a95e0ae4750"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Mon Jan 25 17:54:29 2010 -0800"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Mon Jan 25 17:54:29 2010 -0800"
      },
      "message": "Fix the reporting of NO_CONNECTIVITY.\n\nA refactoring of handleDisconnect instroduced a bug - we were reporting\nNO_CONNECTIVITY after any non-primary network (supl, mms, hipri) was lost.\n\nbug:2395006\n\nChange-Id: Ifa9e008872ec646981a35f2c316120cb9685a6a4\n"
    },
    {
      "commit": "6d626d41e9db62a0eadb61ccb2aa4081a8b9f6d0",
      "tree": "2abe78b970056f4dd2b55b2771f2683a7c6fd5ee",
      "parents": [
        "9985fecaa0bf32e94695f49bb495c9d0cd41e174",
        "5381e4ef4ef1a05b25fa39ff942f4a95e0ae4750"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Mon Jan 25 16:54:28 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Mon Jan 25 16:54:28 2010 -0800"
      },
      "message": "am 5381e4ef: Merge \"Refine fix I53e91db7 to apply only to wifi network\" into eclair\n\nMerge commit \u00275381e4ef4ef1a05b25fa39ff942f4a95e0ae4750\u0027 into eclair-plus-aosp\n\n* commit \u00275381e4ef4ef1a05b25fa39ff942f4a95e0ae4750\u0027:\n  Refine fix I53e91db7 to apply only to wifi network\n"
    },
    {
      "commit": "6e6dec284369238f16ac23497292de5a1a39aca8",
      "tree": "5a7bbda6d45ebf825b09bf2c3633be0fbb37d420",
      "parents": [
        "f904be1659fcc88dd80be2c900ffc89e77b1c737"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Mon Jan 25 16:14:00 2010 -0800"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Mon Jan 25 16:23:56 2010 -0800"
      },
      "message": "Refine fix I53e91db7 to apply only to wifi network\n\nThe original fix eliminated duplicate wifi connectivity changes stemming from\nlocation provder scan\u0027s for APs.  These would generate two DISCONNECTED broadcasts every\ntwo minutes and many apps mis-interpreted them.\n\nThe fix was to ignore notifications where the major state was the same as the previous one\nfor each network.  Unfortunately the state of per-apn notifications on cellular is hacky\nand so the wifi fix was breaking mms (mms when you\u0027re on cellular with a common default+mms apn does\nnot generate a disconnect notification (apn still connected) so subsequent connect notifications\nget dropped as duplicates).\n\nThis change refines the previous change so that it only applies to wifi networks.\n\nbug:2392061\nChange-Id: I05d8a46a4b55f8d28df8af12e05284e5e68bfc02\ndrno: ryanpc\n"
    },
    {
      "commit": "1edab2b551995a8df25f4b533405d6003b8b8b66",
      "tree": "5d6f545170ac5820c19b03e1aea6fd3332084c3d",
      "parents": [
        "8fdd45e1aa26e62fe02b053683624ac2b28bce93"
      ],
      "author": {
        "name": "David \u0027Digit\u0027 Turner",
        "email": "digit@google.com",
        "time": "Thu Jan 21 15:15:23 2010 -0800"
      },
      "committer": {
        "name": "David \u0027Digit\u0027 Turner",
        "email": "digit@google.com",
        "time": "Mon Jan 25 11:27:08 2010 -0800"
      },
      "message": "Make PackageManager unpack gdbserver binaries at installation time.\n\nNative-debuggable packages contain a lib/\u003cabi\u003e/gdbserver executable.\nThis patch ensures that the package manager will copy it to the\nproper location (/data/data/\u003cappname\u003e/lib) at installation time.\n\nNote that such packages are marked with a new ApplicationInfo flag\nnamed FLAG_NATIVE_DEBUGGABLE, to be used later by the Activity\nManager.\n"
    },
    {
      "commit": "45f61040823d8c442838f75cde8760f236603dae",
      "tree": "2c45ee66fd0458b7656bab5c0237fd5ca04950a5",
      "parents": [
        "60e8495c1699f6f4d4046a3394b1eafdeefe6d64"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Sat Jan 23 08:12:43 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Sat Jan 23 08:12:43 2010 -0800"
      },
      "message": "MountService: Add support for renaming secure containers\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "3e3a6430ea49abcdcc645a26a6f1df65acd97345",
      "tree": "72a1f2e39c6eae5dd437bb19814d745147a5f41d",
      "parents": [
        "4d02d001ef6e06583e858e63e48d1aebf54ba28d"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Fri Jan 22 16:46:23 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Fri Jan 22 16:46:23 2010 -0800"
      },
      "message": "Fix whitespace issue causing protocol syntax error\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "4d02d001ef6e06583e858e63e48d1aebf54ba28d",
      "tree": "62bc259feafbea7df30d695e0e00cff9dc0623de",
      "parents": [
        "55434a7999222d89205f32efb03da7e70dd74073"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Fri Jan 22 16:07:46 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Fri Jan 22 16:10:29 2010 -0800"
      },
      "message": "NetworkManagementService: Introduce INetworkManagementEventObserver\n\n  Introduce a callback event observer which can be registered on the\nINetworkManagementService instance to receive events from the service.\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "b0903104fd2fe7a69331758fba769c8067e26771",
      "tree": "78978bbd51db92dbbc92e122f94260383120957c",
      "parents": [
        "97ca28cdd9b12e1c9e9ae57967010b60e61d6bf9",
        "678e66a4ec8bdceafd12f7d82c7d4aa8acf71aa2"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Fri Jan 22 15:51:02 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Jan 22 15:51:02 2010 -0800"
      },
      "message": "am 678e66a4: Merge \"Fix issue #2391429: Crash during boot if fwd locked app is incompletely installed\" into eclair\n\nMerge commit \u0027678e66a4ec8bdceafd12f7d82c7d4aa8acf71aa2\u0027 into eclair-plus-aosp\n\n* commit \u0027678e66a4ec8bdceafd12f7d82c7d4aa8acf71aa2\u0027:\n  Fix issue #2391429: Crash during boot if fwd locked app is incompletely installed\n"
    },
    {
      "commit": "678e66a4ec8bdceafd12f7d82c7d4aa8acf71aa2",
      "tree": "b6af45e3ffd778ddd7943dc4d74172730dc3dc39",
      "parents": [
        "5d14cb34c0e9760340c15ac5faf2d76a64797117",
        "e6620b2d993a8372f63d1c0ca0f1c8be6ab9ad0f"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Fri Jan 22 15:47:08 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jan 22 15:47:08 2010 -0800"
      },
      "message": "Merge \"Fix issue #2391429: Crash during boot if fwd locked app is incompletely installed\" into eclair"
    },
    {
      "commit": "85fd374eabe610ab8213109ae87e2862a4da8985",
      "tree": "0626ee7bc2d4dc8504922e22ea4351b6ac13dca1",
      "parents": [
        "63454ebcc9604407152ee54e29ee91c726374f56",
        "2780e73ae7ec32418a1827671ddf0687a218ed13"
      ],
      "author": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Fri Jan 22 15:24:17 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jan 22 15:24:17 2010 -0800"
      },
      "message": "Merge \"As requested, expand ANR event log entry (and crash/WTF too) to include process flags (including FLAG_SYSTEM, etc).\""
    },
    {
      "commit": "63454ebcc9604407152ee54e29ee91c726374f56",
      "tree": "a24606cfdc3ea2b75f0e84518f10e33714975a5a",
      "parents": [
        "bf81cacc962cdf5befdc0934fbb86008ccc11bae",
        "ed4fc8acc52d89f1d4dec853a29288c6d06717c3"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Fri Jan 22 15:20:18 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jan 22 15:20:18 2010 -0800"
      },
      "message": "Merge \"NetworkManagementService: Introduce API methods for configuring interfaces\""
    },
    {
      "commit": "2780e73ae7ec32418a1827671ddf0687a218ed13",
      "tree": "1e723156c81fe6632d4593baeafc8f2b0a5f5b1e",
      "parents": [
        "264ce3825892e4b5ef6af61d330832f4592130bf"
      ],
      "author": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Fri Jan 22 14:47:35 2010 -0800"
      },
      "committer": {
        "name": "Dan Egnor",
        "email": "egnor@google.com",
        "time": "Fri Jan 22 14:47:35 2010 -0800"
      },
      "message": "As requested, expand ANR event log entry (and crash/WTF too) to include\nprocess flags (including FLAG_SYSTEM, etc).\n"
    },
    {
      "commit": "e6620b2d993a8372f63d1c0ca0f1c8be6ab9ad0f",
      "tree": "ef8e30a13415d93493b5395a35a10dbfb04bfe6e",
      "parents": [
        "b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Fri Jan 22 14:46:21 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Fri Jan 22 14:46:21 2010 -0800"
      },
      "message": "Fix issue #2391429: Crash during boot if fwd locked app is incompletely installed\n\nWe need to remove left-over .apk when cleaning up a partially installed app.\n\nChange-Id: I94264549670a2ad01622f746c40c82c30dd3da8d\n"
    },
    {
      "commit": "ed4fc8acc52d89f1d4dec853a29288c6d06717c3",
      "tree": "2c74edcb02a1e294e161f0e5e039168022a695b8",
      "parents": [
        "353ced79b49269151b056c4b06dc632801b59497"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Fri Jan 22 12:28:36 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Fri Jan 22 12:28:36 2010 -0800"
      },
      "message": "NetworkManagementService: Introduce API methods for configuring interfaces\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "c0cea4857683c83e5b5df370ae1c90cc11ed25ae",
      "tree": "19651d952c8afb9eec07369215efae5948fb2d9d",
      "parents": [
        "f226e9f27baa5a29aacffab87e0c0fc52d59fe13",
        "5f64128568d815f91dcd37db43d4e26a0566b41c"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Fri Jan 22 11:59:41 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Jan 22 11:59:41 2010 -0800"
      },
      "message": "am 5f641285: am b1c4a2a3: Fix issue #2364506: Phone locked up while listening to music and attempting to download an update\n\nMerge commit \u00275f64128568d815f91dcd37db43d4e26a0566b41c\u0027\n\n* commit \u00275f64128568d815f91dcd37db43d4e26a0566b41c\u0027:\n  Fix issue #2364506: Phone locked up while listening to music and attempting to download an update\n"
    },
    {
      "commit": "131c5e0867d542788cf2dab23b17f2f8cc3d0391",
      "tree": "811083201f26fd6bb174d0c5cf1631558497f52f",
      "parents": [
        "64c92f75df7415084aa9f0b304f2a99089b6be9f",
        "a59551bade6a7b0c916c277f044de79c6af1bd22"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Fri Jan 22 10:25:00 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Fri Jan 22 10:25:00 2010 -0800"
      },
      "message": "am a59551ba: Merge \"Fix issue 2388215: Audio not routed to 3.5mm Headset after removal/insertion.\" into eclair\n\nMerge commit \u0027a59551bade6a7b0c916c277f044de79c6af1bd22\u0027 into eclair-plus-aosp\n\n* commit \u0027a59551bade6a7b0c916c277f044de79c6af1bd22\u0027:\n  Fix issue 2388215: Audio not routed to 3.5mm Headset after removal/insertion.\n"
    },
    {
      "commit": "700aab67eb286b44663f885325f8db6b049cb638",
      "tree": "cd2fb91856bda162bfa1c30dfe5035198c3e7d89",
      "parents": [
        "9a400fa4d3e89a3ab3669c0aa2ef6676020646d1"
      ],
      "author": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Fri Jan 22 07:50:58 2010 -0800"
      },
      "committer": {
        "name": "Eric Laurent",
        "email": "elaurent@google.com",
        "time": "Fri Jan 22 09:31:12 2010 -0800"
      },
      "message": "Fix issue 2388215: Audio not routed to 3.5mm Headset after removal/insertion.\n\nThe problem occurs if the delay between the headset removal and insertion is less than one second.\nIn this case, as the headset disconnection intent is broadcast with a 1 second delay to allow music to pause\nbefore updating the route, the connection intent is broadcast before and is ignored, leaving the system\nin a state where the headset is considered disconnected.\n\nThe fix consists in inserting a delay before broadcasting the connection intent if a disconnection\nintent is pending broadcast.\n"
    },
    {
      "commit": "4141d035c7d41f39f023d7a051568dff87c7cd32",
      "tree": "f11e8f74249e199b151dab5f21ebf2cbb4f64862",
      "parents": [
        "051ab623342746b6e25676c740f6104989902de6"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Jan 21 16:29:00 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Jan 21 16:29:00 2010 -0800"
      },
      "message": "Don\u0027t crash when there is no admin.\n"
    },
    {
      "commit": "df83afaf299666e99c519aa86e7e082b7c116e95",
      "tree": "65480fb272324aee6613d0449d40d5e078a700a8",
      "parents": [
        "04ce08f34e39928a5b8e9ea59134f255c9ff08f6"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Wed Jan 20 13:37:26 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Thu Jan 21 14:30:57 2010 -0800"
      },
      "message": "More device policy manager / admin work.\n\nUpdate API with some new features, re-arrange how you check for valid\npasswords, and start hooking up the back-end implementation.\n"
    },
    {
      "commit": "176a88ff14821b07f3c1e67f61ca786c997b9230",
      "tree": "033652ca36a1897e77a32052fedd7d51ee54e9a6",
      "parents": [
        "6efe03b19e0734361b262f9a0be4d225088d7f9e",
        "19563cc278446c2df7a2df6d5f7c89f43228c437"
      ],
      "author": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Thu Jan 21 11:21:25 2010 -0800"
      },
      "committer": {
        "name": "The Android Open Source Project",
        "email": "initial-contribution@android.com",
        "time": "Thu Jan 21 11:21:25 2010 -0800"
      },
      "message": "merge from open-source master\n"
    },
    {
      "commit": "1f2f23bd16ff798a08d73f4159ddcb621e70fc94",
      "tree": "f41d20a8d5feae27e151002e257a556a8eddc082",
      "parents": [
        "d051434773769926671bc6f98e273e385819b653",
        "9fdf82e080ea20086378e751ace245a4a1b022dc"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Thu Jan 21 10:05:13 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Thu Jan 21 10:05:13 2010 -0800"
      },
      "message": "am 9fdf82e0: Merge \"Try to switch to another default net on connection failure.\" into eclair\n\nMerge commit \u00279fdf82e080ea20086378e751ace245a4a1b022dc\u0027 into eclair-plus-aosp\n\n* commit \u00279fdf82e080ea20086378e751ace245a4a1b022dc\u0027:\n  Try to switch to another default net on connection failure.\n"
    },
    {
      "commit": "80ffe5d2fe8288623844c8f6c7ba1305d074a852",
      "tree": "a0974c2dfd0ac7153fbc89e3839b5ad2234eaaa3",
      "parents": [
        "db43099f9ec481afb4f24f1e08f1db720fbd3e3c",
        "670f93283b5e2445c58998153de9c476acddc37b"
      ],
      "author": {
        "name": "Mike Lockwood",
        "email": "lockwood@google.com",
        "time": "Thu Jan 21 08:18:15 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Thu Jan 21 08:18:15 2010 -0800"
      },
      "message": "Merge \"Implement Notification.DEFAULT_LIGHTS flag.\""
    },
    {
      "commit": "670f93283b5e2445c58998153de9c476acddc37b",
      "tree": "6f55352c72e6a31ee30c26afb81b65f5f31d22a0",
      "parents": [
        "867e8eb753422bb9ef83297b72f925b92040daf9"
      ],
      "author": {
        "name": "Mike Lockwood",
        "email": "lockwood@android.com",
        "time": "Wed Jan 20 12:13:36 2010 -0500"
      },
      "committer": {
        "name": "Mike Lockwood",
        "email": "lockwood@android.com",
        "time": "Wed Jan 20 22:43:47 2010 -0500"
      },
      "message": "Implement Notification.DEFAULT_LIGHTS flag.\n\nThis flag was already in the public API but did not do anything until now.\nWe now use it so we can override the default notification LED color on a per device basis.\n\nChange-Id: I0d6e239b7da2fdbeda9608d6d4de3e778aa88e2c\nBUG: 2329568\n\nSigned-off-by: Mike Lockwood \u003clockwood@android.com\u003e\n"
    },
    {
      "commit": "da03c4e4b3d47e6917fdcddecf68f2f52564e3a0",
      "tree": "a08480b57b97e4033f0c2e909bef9d358aa75eb1",
      "parents": [
        "48ef378d01b3ace349cbb6ba564276b854d872c9"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Wed Jan 20 19:29:41 2010 -0800"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Wed Jan 20 19:29:41 2010 -0800"
      },
      "message": "Try to switch to another default net on connection failure.\n\nThis shouldn\u0027t be required, but there seems to be something odd going on\nin wifi and it doesn\u0027t hurt to try other available options.  Makes a\nconnection failure case work like a disconnected case.\n\nbug: 2378462\n"
    },
    {
      "commit": "db43099f9ec481afb4f24f1e08f1db720fbd3e3c",
      "tree": "148581719ef7fe429fc9806a699631dee0553c02",
      "parents": [
        "8ab6135841ca0fede5b99fdd9ff166fbfe0176c0",
        "72759df749bb8557269db86c2e3b2a8a0343cc26"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Wed Jan 20 18:15:43 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Jan 20 18:15:43 2010 -0800"
      },
      "message": "Merge \"INetworkManagementService: Add support for enumerating TTYs and attaching ppp servers to them\""
    },
    {
      "commit": "8ab6135841ca0fede5b99fdd9ff166fbfe0176c0",
      "tree": "7187a066f8aa267340c598af1621146b69f71a7a",
      "parents": [
        "45891e8bfd77bbb55e2568933f490d6512add865"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Wed Jan 20 15:16:42 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Wed Jan 20 18:14:09 2010 -0800"
      },
      "message": "MountService: Codeshrink\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "45891e8bfd77bbb55e2568933f490d6512add865",
      "tree": "2df95f9591aabcda4576814a284e7c761633d983",
      "parents": [
        "703f0614f3111957c0bda4e3595c10c413255894",
        "deba6935c6595c724416cde3368a92c32d8f8683"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Wed Jan 20 18:12:54 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Jan 20 18:12:54 2010 -0800"
      },
      "message": "Merge \"NativeDaemonConnector: Add a convenience method for obtaining lists\""
    },
    {
      "commit": "deba6935c6595c724416cde3368a92c32d8f8683",
      "tree": "42fba642d439ca5d290999d4b69f90917a89d993",
      "parents": [
        "8be346429c18929d4c429b81a4b6fff9dce661b0"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Wed Jan 20 15:14:31 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Wed Jan 20 15:32:02 2010 -0800"
      },
      "message": "NativeDaemonConnector: Add a convenience method for obtaining lists\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "72759df749bb8557269db86c2e3b2a8a0343cc26",
      "tree": "b3894692d3db96f62f3d976a7dbd3fa8e2206504",
      "parents": [
        "8be346429c18929d4c429b81a4b6fff9dce661b0"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 19 13:50:37 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Wed Jan 20 15:17:45 2010 -0800"
      },
      "message": "INetworkManagementService: Add support for enumerating TTYs and attaching ppp servers to them\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n\nUpdated: Refactor out duplicated code\n"
    },
    {
      "commit": "1206b9eb71e0fc0cfeb98677b92f16afb8179a31",
      "tree": "7394a1e5929eeb0b2f48605fc44bb4ed4bd93175",
      "parents": [
        "973fbb1591b94c83fe1d62593c3e26eaf82741f3",
        "31f90b62e8c83270094f5b0b4c75a0e06d72cd75"
      ],
      "author": {
        "name": "Jim Miller",
        "email": "jaggies@google.com",
        "time": "Wed Jan 20 15:12:04 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Jan 20 15:12:04 2010 -0800"
      },
      "message": "Merge \"Fix 2385283: Add DevicePolicyManager calls to LockScreen.\""
    },
    {
      "commit": "31f90b62e8c83270094f5b0b4c75a0e06d72cd75",
      "tree": "5f3cd8d9dfe70cbb5ed607cb4dabf7e46a29c648",
      "parents": [
        "b49d9af7e1205312cc25e23636ef3980bee4c1b0"
      ],
      "author": {
        "name": "Jim Miller",
        "email": "jaggies@google.com",
        "time": "Wed Jan 20 13:35:20 2010 -0800"
      },
      "committer": {
        "name": "Jim Miller",
        "email": "jaggies@google.com",
        "time": "Wed Jan 20 14:48:37 2010 -0800"
      },
      "message": "Fix 2385283: Add DevicePolicyManager calls to LockScreen.\n"
    },
    {
      "commit": "6b32c0a2ffd3fe8bf5c290eeecc78fb2e3521520",
      "tree": "3191fa2c7bd3502b86cd96b3dd18809d7ef202c0",
      "parents": [
        "8c48b4a532b1011a2f76f3565335c77fc5b141b3",
        "48ef378d01b3ace349cbb6ba564276b854d872c9"
      ],
      "author": {
        "name": "Irfan Sheriff",
        "email": "isheriff@google.com",
        "time": "Wed Jan 20 13:30:17 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Jan 20 13:30:17 2010 -0800"
      },
      "message": "am 48ef378d: Merge \"DO NOT MERGE Avoid wifi disable in a UNKNOWN state\" into eclair\n\nMerge commit \u002748ef378d01b3ace349cbb6ba564276b854d872c9\u0027 into eclair-plus-aosp\n\n* commit \u002748ef378d01b3ace349cbb6ba564276b854d872c9\u0027:\n  DO NOT MERGE Avoid wifi disable in a UNKNOWN state\n"
    },
    {
      "commit": "8c48b4a532b1011a2f76f3565335c77fc5b141b3",
      "tree": "3c14e4ebe95f836f1f7c73125dff125795e0ea4f",
      "parents": [
        "70660425c03ac9688d749b13b48bba24d22efabf",
        "1a337547d5377c57dbb10a24d4d73ad6bda829ea"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Wed Jan 20 13:30:11 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Jan 20 13:30:11 2010 -0800"
      },
      "message": "am 1a337547: Merge \"Add bugreport info about network feature use. DO NOT MERGE\" into eclair\n\nMerge commit \u00271a337547d5377c57dbb10a24d4d73ad6bda829ea\u0027 into eclair-plus-aosp\n\n* commit \u00271a337547d5377c57dbb10a24d4d73ad6bda829ea\u0027:\n  Add bugreport info about network feature use. DO NOT MERGE\n"
    },
    {
      "commit": "48ef378d01b3ace349cbb6ba564276b854d872c9",
      "tree": "a2f8b5768d6a9d80e54a4cb2671355d661d21809",
      "parents": [
        "1a337547d5377c57dbb10a24d4d73ad6bda829ea",
        "0fe3f7cbbf769b80cd5ee549bbd0f7723f4d9312"
      ],
      "author": {
        "name": "Irfan Sheriff",
        "email": "isheriff@google.com",
        "time": "Wed Jan 20 13:26:08 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Wed Jan 20 13:26:08 2010 -0800"
      },
      "message": "Merge \"DO NOT MERGE Avoid wifi disable in a UNKNOWN state\" into eclair"
    },
    {
      "commit": "73912ce083a35e0b4cbccd9a364791c3725d9e34",
      "tree": "672a704a496916f1af9c661b20c2d7352db4907f",
      "parents": [
        "8c166512a7e6ffaf87e41cd3a85d55993648fe9b"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Mon Dec 21 18:24:07 2009 -0800"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Wed Jan 20 12:36:09 2010 -0800"
      },
      "message": "Add bugreport info about network feature use. DO NOT MERGE\n\nBackported from master change Ib9285359.\n\nWe\u0027ve had a couple bug reports showing the effects of a left-live feature request.\nWe need a bit more bugreport-time logging.\n\nbug: 2323226\nbug: 2377507\nchange-id: I296b2887101c260aea678bf6db91144535cbad7e\n"
    },
    {
      "commit": "e0ee6efb1e5bc6cf219555e333635ce98531bc85",
      "tree": "c190aeb5e7975cbc4633516840ebf21280068f6e",
      "parents": [
        "918007b75539f5eabfd173a369c2da628c607ba7"
      ],
      "author": {
        "name": "Jacek Surazski",
        "email": "jaceks@google.com",
        "time": "Thu Jan 07 16:23:03 2010 +0100"
      },
      "committer": {
        "name": "Jacek Surazski",
        "email": "jaceks@google.com",
        "time": "Wed Jan 20 12:27:58 2010 -0800"
      },
      "message": "Add systemApp field to ApplicationErrorReport\n"
    },
    {
      "commit": "d2c21c1518631edd798367cf20cbc5434321d266",
      "tree": "cdcd559724466f92ef776f4d6975d10e25e6a4c3",
      "parents": [
        "47d302a001c71f90bee8dc31d868b463a47f2d51",
        "8c166512a7e6ffaf87e41cd3a85d55993648fe9b"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Wed Jan 20 11:12:40 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Wed Jan 20 11:12:40 2010 -0800"
      },
      "message": "am 8c166512: Merge \"Cleanup of process-specific DNS.\" into eclair\n\nMerge commit \u00278c166512a7e6ffaf87e41cd3a85d55993648fe9b\u0027 into eclair-plus-aosp\n\n* commit \u00278c166512a7e6ffaf87e41cd3a85d55993648fe9b\u0027:\n  Cleanup of process-specific DNS.\n"
    },
    {
      "commit": "0fe3f7cbbf769b80cd5ee549bbd0f7723f4d9312",
      "tree": "177f9c11c4af7a4b57d4b641bcbc5cf109d95e9f",
      "parents": [
        "bb79e5fdb52eb86963fc688e6a455451b6e1a867"
      ],
      "author": {
        "name": "Irfan Sheriff",
        "email": "isheriff@google.com",
        "time": "Fri Jan 08 09:36:04 2010 -0800"
      },
      "committer": {
        "name": "Irfan Sheriff",
        "email": "isheriff@google.com",
        "time": "Wed Jan 20 10:08:23 2010 -0800"
      },
      "message": "DO NOT MERGE Avoid wifi disable in a UNKNOWN state\n\nMultiple broadcast receiver unregister calls cause exception.\n\nBug: 2361335\n"
    },
    {
      "commit": "5f64128568d815f91dcd37db43d4e26a0566b41c",
      "tree": "12239bd2a8c29ab0086cabbaf11791ea7919d26c",
      "parents": [
        "60e3c09ec0fa73a3e650f4aec89c763599c2e0b7",
        "b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Tue Jan 19 19:59:04 2010 -0800"
      },
      "committer": {
        "name": "Android Git Automerger",
        "email": "android-git-automerger@android.com",
        "time": "Tue Jan 19 19:59:04 2010 -0800"
      },
      "message": "am b1c4a2a3: Fix issue #2364506: Phone locked up while listening to music and attempting to download an update\n\nMerge commit \u0027b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7\u0027 into eclair-plus-aosp\n\n* commit \u0027b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7\u0027:\n  Fix issue #2364506: Phone locked up while listening to music and attempting to download an update\n"
    },
    {
      "commit": "15abc90147333fccf7c9576cbf90d40d73e5a20f",
      "tree": "7880b6a08134a951316b29de9b8c19209a4fd134",
      "parents": [
        "5910cb53ea7085dff4c8c6b9c1edde5a1b59fa28"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Thu Dec 17 14:54:59 2009 -0800"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Tue Jan 19 18:01:36 2010 -0800"
      },
      "message": "Cleanup of process-specific DNS.\n\nBackport of MR2 change 421c72b6.\n\nRemoves entries sooner.  A bug.\nDoesn\u0027t add one for phone process at all.  This was intended to be removed long ago.\n\nbug: 2329900\nbug: 2377507\n"
    },
    {
      "commit": "77872f76a12c883c163a70a42e347f35c4e9a269",
      "tree": "d71046f1af8c6bd9dd35c92571ed1363b06b7eb8",
      "parents": [
        "b49d9af7e1205312cc25e23636ef3980bee4c1b0",
        "63ce8e817c9b800b4f08b64c343e533783961b6e"
      ],
      "author": {
        "name": "Joe Onorato",
        "email": "joeo@google.com",
        "time": "Tue Jan 19 16:34:58 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Jan 19 16:34:58 2010 -0800"
      },
      "message": "Merge \"Make the space between the time and the AM/PM smaller by putting preceding whitespace inside the span.\""
    },
    {
      "commit": "b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7",
      "tree": "82eaa515232769b237fc3c38cdbacc7b1ba5bd7f",
      "parents": [
        "6866daee6a18992e8f2c9a948e873bbfc2090fb0"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Tue Jan 19 15:36:42 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Tue Jan 19 15:36:42 2010 -0800"
      },
      "message": "Fix issue #2364506: Phone locked up while listening to music and attempting to download an update\n\nMake sure calls into the notification manager are not done with the\nactivity manager lock held.\n\nChange-Id: Ib53c3b9f46160d94ee1e7079b1a5123e0d1225d8\n"
    },
    {
      "commit": "b49d9af7e1205312cc25e23636ef3980bee4c1b0",
      "tree": "d99571e6880423eb6f5a1c43e59f1fc5629e82a4",
      "parents": [
        "56d42582f20efce1ff46ea2b5fff60b26cf2c1f0",
        "fd3530f90562bb7e66edfee39d90fc8beda82f1d"
      ],
      "author": {
        "name": "Suchi Amalapurapu",
        "email": "asuchitra@google.com",
        "time": "Tue Jan 19 14:11:43 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Jan 19 14:11:43 2010 -0800"
      },
      "message": "Merge \"Mount/Unmount secure containers Persist flags in PackageSetting. Flags are relevant to ApplicationInfo.FLAG_SYSTEM, Application.FLAG_ON_SDCARD, ApplicationInfo.FLAG_FORWARD_LOCK. New pm command to simulate mount/unmount in Pm. This will be removed when MountService/vold event generation gets fixed. Calls from MountService into PackageManager when media gets mounted/unmounted. Scan the packages and grant permissions when the sdcard gets mounted. This api might change again.\""
    },
    {
      "commit": "fd3530f90562bb7e66edfee39d90fc8beda82f1d",
      "tree": "3829a74034270ac5434a0863e5dd115172443dfc",
      "parents": [
        "97d1195832829905b07b7680b73bed8af959f430"
      ],
      "author": {
        "name": "Suchi Amalapurapu",
        "email": "asuchitra@google.com",
        "time": "Mon Jan 18 00:15:59 2010 -0800"
      },
      "committer": {
        "name": "Suchi Amalapurapu",
        "email": "asuchitra@google.com",
        "time": "Tue Jan 19 14:04:54 2010 -0800"
      },
      "message": "Mount/Unmount secure containers\nPersist flags in PackageSetting. Flags are relevant to ApplicationInfo.FLAG_SYSTEM, Application.FLAG_ON_SDCARD, ApplicationInfo.FLAG_FORWARD_LOCK.\nNew pm command to simulate mount/unmount in Pm. This will be removed\nwhen MountService/vold event generation gets fixed.\nCalls from MountService into PackageManager when media gets mounted/unmounted.\nScan the packages and grant permissions when the sdcard gets mounted.\nThis api might change again.\n"
    },
    {
      "commit": "f078d058ab6c496480a5d1c805cc4f56ba9f4b0c",
      "tree": "2255efc332d8be1ae9f046b7080e14337a3746f4",
      "parents": [
        "425500913aee9885a0f2de1dc5de82910035091e",
        "873f2145941cc28f6931dc18b5e9987bd22e2e19"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 19 11:21:44 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Tue Jan 19 11:21:44 2010 -0800"
      },
      "message": "Merge \"framework: Introduce INetworkManagementService for communicating with netd\""
    },
    {
      "commit": "0dac8c0f7ec00d94b09f92823fa238142163aba8",
      "tree": "a4d486e209d4de080ba95a740a5d90721b02d8ed",
      "parents": [
        "97d1195832829905b07b7680b73bed8af959f430"
      ],
      "author": {
        "name": "Mike Lockwood",
        "email": "lockwood@android.com",
        "time": "Tue Jan 19 11:48:14 2010 -0500"
      },
      "committer": {
        "name": "Mike Lockwood",
        "email": "lockwood@android.com",
        "time": "Tue Jan 19 14:00:48 2010 -0500"
      },
      "message": "LocationManagerService: Fix bug removing proximity alerts.\n\nAlerts were not being removed from the mProximitiesEntered array.\n\nSigned-off-by: Mike Lockwood \u003clockwood@android.com\u003e\n"
    },
    {
      "commit": "873f2145941cc28f6931dc18b5e9987bd22e2e19",
      "tree": "4793e2bca832a46a0d77eb3ce8072502f4c02661",
      "parents": [
        "97d1195832829905b07b7680b73bed8af959f430"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Thu Jan 14 10:25:07 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Tue Jan 19 10:47:52 2010 -0800"
      },
      "message": "framework: Introduce INetworkManagementService for communicating with netd\n\nThis is the framework-exposed interface for the (future) management of\nall Android network management functions. Initial support is for providing\ntethering.\n\nUpdated: Integrate feedback from review; clean up naming\n\nUpdated: Switch from add/remove/list to get/set for DNS forwarders\n         - allows prioritization / ordering of DNS servers\n\nUpdated: Refactor NAT api\n\nUpdated: Refactor NAT api (last time sorry)\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "19563cc278446c2df7a2df6d5f7c89f43228c437",
      "tree": "448082dec2e5d9fc94dc57f31373124f5ab8d6ee",
      "parents": [
        "8ca2f47e0d8ec526d70c1133c9aba966543b11ff"
      ],
      "author": {
        "name": "Mike Lockwood",
        "email": "lockwood@android.com",
        "time": "Tue Jan 19 11:48:14 2010 -0500"
      },
      "committer": {
        "name": "Mike Lockwood",
        "email": "lockwood@android.com",
        "time": "Tue Jan 19 11:50:13 2010 -0500"
      },
      "message": "LocationManagerService: Fix bug removing proximity alerts.\n\nAlerts were not being removed from the mProximitiesEntered array.\n\nSigned-off-by: Mike Lockwood \u003clockwood@android.com\u003e\n"
    },
    {
      "commit": "2b7ff1c47147e31521a3ef9e7d02252111192cb3",
      "tree": "32ca31462eafb0bdb075ffa47e72a7438c73e1cc",
      "parents": [
        "840e958847f31f835dbf17ce539c9f8317251cc9",
        "9dba709d4439d8cdb464a3dcccbddffdbe4b10ff"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Mon Jan 18 07:14:02 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Mon Jan 18 07:14:02 2010 -0800"
      },
      "message": "Merge \"MountService: Add new \u0027unmountSecureContainer\u0027 API call\""
    },
    {
      "commit": "9dba709d4439d8cdb464a3dcccbddffdbe4b10ff",
      "tree": "07b08f8bee730d8ec59604d6e29287f7cb0f7b88",
      "parents": [
        "5fbf4094f5857ab15801c65a260a5c4b6866d655"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Mon Jan 18 06:47:41 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Mon Jan 18 06:49:19 2010 -0800"
      },
      "message": "MountService: Add new \u0027unmountSecureContainer\u0027 API call\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "63ce8e817c9b800b4f08b64c343e533783961b6e",
      "tree": "36499efa89f6956b58d5594ce997b623589589a3",
      "parents": [
        "ff58b5770514521ebdd48f500d8dc121a42d7eb2"
      ],
      "author": {
        "name": "Joe Onorato",
        "email": "joeo@android.com",
        "time": "Sun Jan 17 19:06:51 2010 -0500"
      },
      "committer": {
        "name": "Joe Onorato",
        "email": "joeo@android.com",
        "time": "Sun Jan 17 19:09:35 2010 -0500"
      },
      "message": "Make the space between the time and the AM/PM smaller by putting preceding whitespace inside the\nspan.\n\nAlso cache the SimpleDateFormat object because those are relatively expensive.\n"
    },
    {
      "commit": "d68478467e3f837511196c80891d7245d0e163df",
      "tree": "598148f587955a89e72017b59df3ba7ba4d8b20b",
      "parents": [
        "5fbf4094f5857ab15801c65a260a5c4b6866d655"
      ],
      "author": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Tue Jan 12 18:14:19 2010 -0800"
      },
      "committer": {
        "name": "Dianne Hackborn",
        "email": "hackbod@google.com",
        "time": "Sun Jan 17 15:10:24 2010 -0800"
      },
      "message": "First pass at new device policy and administration APIs.\n\nThis adds new DevicAdmin, DevicePolicyManager, and DeviceAdminInfo classes.\nSee the java docs for each on documentation on them.  Basically: a DeviceAdmin\nis what you derive from to administer a device; DevicePolicyManager is what you\nuse to apply and check your policy requirements and perform other administration\ntasks.\n"
    },
    {
      "commit": "5fbf4094f5857ab15801c65a260a5c4b6866d655",
      "tree": "16ff4a03f8a332156610d3e6809515e18825ebf2",
      "parents": [
        "ff58b5770514521ebdd48f500d8dc121a42d7eb2"
      ],
      "author": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Fri Jan 15 10:13:59 2010 -0800"
      },
      "committer": {
        "name": "San Mehat",
        "email": "san@google.com",
        "time": "Sat Jan 16 06:11:27 2010 -0800"
      },
      "message": "MountService: Suppress media removed notification when enabling UMS\n\nSigned-off-by: San Mehat \u003csan@google.com\u003e\n"
    },
    {
      "commit": "462f0378280f2c9717ad3bcafd8b9d1827b840b6",
      "tree": "3a2e8dd3dbb4e6ecff86321fe54cef07255769d5",
      "parents": [
        "3fe3ebfaa671d940f9cd571d782c8c95ce5eaec1"
      ],
      "author": {
        "name": "Oscar Montemayor",
        "email": "oam@google.com",
        "time": "Thu Jan 14 16:38:40 2010 -0800"
      },
      "committer": {
        "name": "Oscar Montemayor",
        "email": "oam@google.com",
        "time": "Fri Jan 15 16:34:11 2010 -0800"
      },
      "message": "Apps on SD card.\nAdded support for retrieving and generating keys as Hex Strings.\nUsing keys to mount encrypted FS.\n"
    },
    {
      "commit": "d02546b4151214abb2db1c88bf7debfc70bd2421",
      "tree": "706596caff37b2f9ba6c04da64bf3b98172da00e",
      "parents": [
        "851b2e75e600a7e3f557b46c4c48c11da025d1f4"
      ],
      "author": {
        "name": "Oscar Montemayor",
        "email": "oam@google.com",
        "time": "Thu Jan 14 16:38:40 2010 -0800"
      },
      "committer": {
        "name": "Oscar Montemayor",
        "email": "oam@google.com",
        "time": "Fri Jan 15 15:08:06 2010 -0800"
      },
      "message": "Apps on SD card.\nAdded support for retrieving and generating keys as Hex Strings.\nUsing keys to mount encrypted FS.\n"
    },
    {
      "commit": "7c44220d0b57bd3bbb87f5db00454f9ea9faed9a",
      "tree": "7727834b30e2d7276198d7723c5e67e91b65f060",
      "parents": [
        "3084a6f80180506ce26fe4773d9a19f004b7f625",
        "36e136c2c86f39f03cdd4275f07deb30dc2c95aa"
      ],
      "author": {
        "name": "Eric Fischer",
        "email": "enf@google.com",
        "time": "Fri Jan 15 11:23:00 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jan 15 11:23:00 2010 -0800"
      },
      "message": "Merge \"Make the \"AM\" or \"PM\" in the status bar clock be in a smaller font size.\""
    },
    {
      "commit": "40bbaaac5f0b93de8d8b8164ac8b59583bc0113a",
      "tree": "b3eb1bf2b147b408e4a712a35412a90f99d3866b",
      "parents": [
        "0894498712de1f15b6491fa5fe111b2da7fb7038",
        "90528645ad7d40634737075dc49a9f60bc7a1748"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Fri Jan 15 10:45:11 2010 -0800"
      },
      "committer": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Fri Jan 15 10:45:11 2010 -0800"
      },
      "message": "resolved conflicts for merge of 90528645 to master\n"
    },
    {
      "commit": "0894498712de1f15b6491fa5fe111b2da7fb7038",
      "tree": "380c74d989140d60d3395a06869c04d90ab88a10",
      "parents": [
        "c5dfa70410121c63079ecd7e4945d774562c8998",
        "de8383ca312c03fa8e935ac1549ae31ce668652c"
      ],
      "author": {
        "name": "Robert Greenwalt",
        "email": "robdroid@android.com",
        "time": "Fri Jan 15 10:20:18 2010 -0800"
      },
      "committer": {
        "name": "Android (Google) Code Review",
        "email": "android-gerrit@google.com",
        "time": "Fri Jan 15 10:20:18 2010 -0800"
      },
      "message": "Merge \"Set net.hostname sys property to our unique ID.\""
    }
  ],
  "next": "48c0273eb978d44ee093f514545d4332f034e473"
}
