)]}'
{
  "log": [
    {
      "commit": "b6c886c940ff307a824b876c995676a894edb032",
      "tree": "04e2fe46ddd366a17770407f2739d17599e38ab5",
      "parents": [
        "a8770a9dd2f8d50cd0e67e18d7da69c45e5bd606"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Sat Oct 24 10:01:35 2020 +0800"
      },
      "committer": {
        "name": "Zezeng Wang",
        "email": "51382517@qq.com",
        "time": "Fri Nov 20 09:19:45 2020 +0800"
      },
      "message": "FixDownLoadErrorInAppveyorCi\n"
    },
    {
      "commit": "a8770a9dd2f8d50cd0e67e18d7da69c45e5bd606",
      "tree": "4bc659965da5d206e8d6326ed43d22225a75ddc5",
      "parents": [
        "384a29616eb01854f85b353cd30d57cb5b83c4fc"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Sat Oct 24 09:53:53 2020 +0800"
      },
      "committer": {
        "name": "Zezeng Wang",
        "email": "51382517@qq.com",
        "time": "Fri Nov 20 09:19:45 2020 +0800"
      },
      "message": "rollback\n"
    },
    {
      "commit": "384a29616eb01854f85b353cd30d57cb5b83c4fc",
      "tree": "59f45bd9661410b49fdba485ba7a60cb6d334cef",
      "parents": [
        "6e6bb84be9d8ace4be9744d5637fbb59f58db463"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Sat Oct 24 09:49:54 2020 +0800"
      },
      "committer": {
        "name": "Zezeng Wang",
        "email": "51382517@qq.com",
        "time": "Fri Nov 20 09:19:45 2020 +0800"
      },
      "message": "FixDownLoadErrorInCi\n"
    },
    {
      "commit": "6e6bb84be9d8ace4be9744d5637fbb59f58db463",
      "tree": "4bc659965da5d206e8d6326ed43d22225a75ddc5",
      "parents": [
        "47e4923a9967b6ba3bbb5377809075c1940ecfc1"
      ],
      "author": {
        "name": "David Mollitor",
        "email": "dmollitor@apache.org",
        "time": "Fri Oct 02 21:10:50 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Nov 19 22:35:37 2020 +0100"
      },
      "message": "THRIFT-5288: Move Support for ByteBuffer into TTransport\nClient: Java\nPatch: David Mollitor\n\nThis closes #2254\n"
    },
    {
      "commit": "47e4923a9967b6ba3bbb5377809075c1940ecfc1",
      "tree": "cf10876945cc6fbac43b9a40052bfda5901ae7e0",
      "parents": [
        "6cd5366b5fe10940d28baff9c7067e3045c3c019"
      ],
      "author": {
        "name": "Mario Emmenlauer",
        "email": "mario@emmenlauer.de",
        "time": "Tue Apr 07 18:43:46 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Nov 19 22:23:35 2020 +0100"
      },
      "message": "Minor whitespace changes for netstd\nPatch: Mario Emmenlauer\nClient: netstd\n\nThis closes #2282\n"
    },
    {
      "commit": "6cd5366b5fe10940d28baff9c7067e3045c3c019",
      "tree": "56c56cfae429c112e07f580eba590517ff38a279",
      "parents": [
        "20205b85fa4541a4276328fc31b1cd2ff8310d42",
        "7ddbcc07ec98349da59bb023d0fed8db37097c18"
      ],
      "author": {
        "name": "Allen George",
        "email": "allengeorge@apache.org",
        "time": "Wed Nov 18 10:24:41 2020 -0500"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Wed Nov 18 10:24:41 2020 -0500"
      },
      "message": "Merge pull request #2273 from allengeorge/allen/clippy_clean\n\nTHRIFT-5306: Rust code and generated code no longer has clippy warnings (Rust 1.40)"
    },
    {
      "commit": "7ddbcc07ec98349da59bb023d0fed8db37097c18",
      "tree": "80a46fb7f940e8626bfd8f38346f0b85cce368a7",
      "parents": [
        "22671db01f5c349f2fa54b393581cb4d61bdd895"
      ],
      "author": {
        "name": "Allen George",
        "email": "allengeorge@apache.org",
        "time": "Sun Nov 08 09:51:19 2020 -0500"
      },
      "committer": {
        "name": "Allen George",
        "email": "allengeorge@apache.org",
        "time": "Thu Nov 12 08:47:42 2020 -0500"
      },
      "message": "THRIFT-5306: Rust code and generated code no longer has clippy warnings (Rust 1.40)\n\nClient: rs\n\nNOTE: Also properly update the min/max supported Rust versions\n"
    },
    {
      "commit": "20205b85fa4541a4276328fc31b1cd2ff8310d42",
      "tree": "d748f8a6137c0cde2d6314945b8b51efb1ded760",
      "parents": [
        "05bb55148608b4324a8c91c21cf9a6a0dff282fa"
      ],
      "author": {
        "name": "PoojaChandak",
        "email": "poojachandak002@gmail.com",
        "time": "Fri Nov 06 11:33:40 2020 +0100"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Nov 10 21:34:43 2020 +0100"
      },
      "message": "Grammatical/Typo changes\nPatch: Pooja Chandak\n\nThis closes #2271\n"
    },
    {
      "commit": "05bb55148608b4324a8c91c21cf9a6a0dff282fa",
      "tree": "187c6dcc7e81638746d9e15850ce441adaf290b7",
      "parents": [
        "196254ba393a7e70e91fcf3c35026c82fb64f7fa"
      ],
      "author": {
        "name": "stiga-huang",
        "email": "huangquanlong@gmail.com",
        "time": "Fri Oct 30 20:07:31 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Nov 01 18:17:18 2020 +0100"
      },
      "message": "THRIFT-5303 Fix missing error handling in using PyUnicode_DecodeUTF8\nClient: py\nPatch: stiga-huang\n\nThis closes #2269\n"
    },
    {
      "commit": "196254ba393a7e70e91fcf3c35026c82fb64f7fa",
      "tree": "1a356099f5d54670706c58e39d674b95c8b1e188",
      "parents": [
        "dca58db2b0bd101d4c2ea83bd6cd8eca0e886751"
      ],
      "author": {
        "name": "wangliming07",
        "email": "wangliming07@58.com",
        "time": "Thu Oct 29 13:50:25 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Nov 01 18:12:34 2020 +0100"
      },
      "message": "THRIFT-5302 Add recursive function name uniqueness check\nPatch: wangliming07 \u003cwangliming07@58.com\u003e\n\nThis closes #2268\n"
    },
    {
      "commit": "dca58db2b0bd101d4c2ea83bd6cd8eca0e886751",
      "tree": "93016c7e04ca6be32150b28c4f44b3bd49a7ba71",
      "parents": [
        "997e2d42db27e606bd67be6c91af5e6ef11434aa"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Nov 01 18:06:52 2020 +0100"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Nov 01 18:08:38 2020 +0100"
      },
      "message": "THRIFT-5290 Adjusting cpp *.cproj options according to LEGAL-538\n"
    },
    {
      "commit": "997e2d42db27e606bd67be6c91af5e6ef11434aa",
      "tree": "61af23190f684ad687493d15f0730ac5657572ec",
      "parents": [
        "6762cad25cad7997d09931ba942212d2d0ef61f1"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Tue Sep 29 14:43:18 2020 +0800"
      },
      "committer": {
        "name": "Zezeng Wang",
        "email": "51382517@qq.com",
        "time": "Sat Oct 31 09:13:37 2020 +0800"
      },
      "message": "fix warning in c_glib from add max_message_size code\n"
    },
    {
      "commit": "6762cad25cad7997d09931ba942212d2d0ef61f1",
      "tree": "e8e9e87f4f6e37ced40e4d674ad6102058a6b157",
      "parents": [
        "22671db01f5c349f2fa54b393581cb4d61bdd895"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Fri Oct 30 17:15:18 2020 +0100"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Fri Oct 30 18:26:21 2020 +0100"
      },
      "message": "THRIFT-5304 TWinHTTPClientImpl may incorrectly report that the message size is reached\nClient: Delphi\nPatch: Jens Geyer\n"
    },
    {
      "commit": "22671db01f5c349f2fa54b393581cb4d61bdd895",
      "tree": "e634d0a95bf676263ce58bf4a2dac5c89221d407",
      "parents": [
        "2676327f6ea7851459081047c21138e192b0de65"
      ],
      "author": {
        "name": "Mark Raynsford",
        "email": "code@io7m.com",
        "time": "Wed Oct 21 20:01:40 2020 +0000"
      },
      "committer": {
        "name": "Zezeng Wang",
        "email": "51382517@qq.com",
        "time": "Sat Oct 24 10:55:27 2020 +0800"
      },
      "message": "Add an Automatic-Module-Name entry\n\nThis adds an Automatic-Module-Name entry to the Thrift jar manifest\nin order to provide Thrift with a stable module name when used in a\nJPMS modular context. The name chosen here is \"org.apache.thrift\",\nwhich matches the symbolic name used for OSGi.\n\nSee: http://branchandbound.net/blog/java/2017/12/automatic-module-name/\n"
    },
    {
      "commit": "2676327f6ea7851459081047c21138e192b0de65",
      "tree": "df548a884cb831a4020b7fa57f5fe35261d0f115",
      "parents": [
        "64c2a4b87ab356e05033045492e51f1ad73a795b"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Wed Oct 14 11:16:09 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Mon Oct 19 14:21:44 2020 -0700"
      },
      "message": "Add DuplicateTo protocol to go\u0027s TDebugProtocol\n\nThis also comes from the discussion of\nhttps://github.com/apache/thrift/pull/1992#issuecomment-705903922.\nI think TDebugProtocol is a better fit for this feature than creating a\nnew TProtocol implementation.\n\nThe DuplicateTo field is not added to TDebugProtocolFactory because I\ndon\u0027t think it makes sense from the factory setup. In vast majority\ncases users would need direct access to the underlying TMemoryBuffer to\nmake it useful, which is easier this way than an additional\nTTransportFactory plus TProtocolFactory to make TDebugProtocolFactory\nway too complicated.\n"
    },
    {
      "commit": "64c2a4b87ab356e05033045492e51f1ad73a795b",
      "tree": "926e9f08771156659c8cf3aa2c086d7592241300",
      "parents": [
        "daf620915714b76fce517b376b963440d1f34089"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Sat Oct 10 18:39:32 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Wed Oct 14 10:14:03 2020 -0700"
      },
      "message": "THRIFT-5294: Fix panic in go TSimpleJSONProtocol\n\nClient: go\n\nIn go library\u0027s TSimpleJSONProtocol and TJSONProtocol implementations,\nwe use slices as stacks for context info, but didn\u0027t do proper boundary\ncheck when peeking/popping, result in it might panic with using -1 as\nslice index in certain cases of calling Write*End without matching\nWrite*Begin before.\n\nRefactor the code to properly implement the stack, and return a\nTProtocolException instead on those cases.\n\nAlso add unit tests for all protocols. The unit tests shown that\nTCompactProtocol.[Read|Write]StructEnd would also panic with unmatched\nBegin calls, so fix them as well.\n"
    },
    {
      "commit": "daf620915714b76fce517b376b963440d1f34089",
      "tree": "ac053a27de9d04da48c6dd2093945c6cb1931cbd",
      "parents": [
        "6d570260caa550741f4da9615cae1b14f328a553"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Wed Oct 07 16:28:38 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Wed Oct 07 22:25:19 2020 -0700"
      },
      "message": "THRIFT-5240: Tweak the default go server connectivity check interval\n\nClient: go\n\nThis is a follow up to 4db7a0af13ac9614e3e9758d42b2791040f4dc7e.\n\nBecause of the Go runtime bug [1], the previous default value of 1ms is\nnot a great default as it could cause excessive cpu usage. Use 5ms\ninstead as a balance between being useful and not causing too much cpu\noverhead.\n\nIt\u0027s still configurable.\n\n[1]: https://github.com/golang/go/issues/27707\n"
    },
    {
      "commit": "6d570260caa550741f4da9615cae1b14f328a553",
      "tree": "6f2c1740409b80ce5d69fdefbcf8e6f64150e280",
      "parents": [
        "d89b427d19a07d556c8a6193e81bd1ed948ac5b5"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Oct 01 21:48:07 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Oct 06 22:17:42 2020 +0200"
      },
      "message": "THRIFT-5290 Adjusting cpp *.cproj options according to LEGAL-538\nClient: cpp\nPatch: Jens Geyer\n\nThis closes #2250\n"
    },
    {
      "commit": "d89b427d19a07d556c8a6193e81bd1ed948ac5b5",
      "tree": "e2a40526680a4085368ad5719830e9a75e067b00",
      "parents": [
        "5751ddf2ac8df7845c88154a9cc498c46402730d"
      ],
      "author": {
        "name": "David Mollitor",
        "email": "dmollitor@apache.org",
        "time": "Fri Oct 02 11:44:59 2020 -0400"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Oct 04 22:18:13 2020 +0200"
      },
      "message": "THRIFT-5287: Log When Client Connections are Dropped\nClient: java\nPatch: David Mollitor\n\nThis closes #2253\n"
    },
    {
      "commit": "5751ddf2ac8df7845c88154a9cc498c46402730d",
      "tree": "54f3b1490a17e841a0e9fdcd3b3d364d56884fc4",
      "parents": [
        "330482b02e14955b7a760c59214de3e1b6d03dce"
      ],
      "author": {
        "name": "Jeffrey Han",
        "email": "jeffreyhan@fb.com",
        "time": "Thu Oct 01 16:17:17 2020 -0700"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Fri Oct 02 22:02:56 2020 +0200"
      },
      "message": "THRIFT-5286: Fix Lua library readBool() in TCompactProtocol\nClient: Lua\nPatch: Jeffrey Han\n\nThis closes #2252\n"
    },
    {
      "commit": "330482b02e14955b7a760c59214de3e1b6d03dce",
      "tree": "245c62283a614e18304d00a4b31ad7764e479db1",
      "parents": [
        "1d68bfe3c4b72370e3db50f164c5241f15fc119c"
      ],
      "author": {
        "name": "Kashirin Alex",
        "email": "kashirin.alex@gmail.com",
        "time": "Tue Sep 22 05:38:52 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Fri Oct 02 21:52:43 2020 +0200"
      },
      "message": "markdown compiler added\nClient: md\nPatch: Kashirin Alex\n\nThis closes #2241\n"
    },
    {
      "commit": "1d68bfe3c4b72370e3db50f164c5241f15fc119c",
      "tree": "4e8200f976e1b1fda6b6bfb003a167712452dbce",
      "parents": [
        "44b0b5d3c9b2bcaae43470bfe98721d0281958e5"
      ],
      "author": {
        "name": "guanjialin",
        "email": "1406147701@qq.com",
        "time": "Thu Sep 03 16:31:18 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Oct 01 23:11:11 2020 +0200"
      },
      "message": "Rust compiler generates invalid code when using typedef with union\nClient: rs\nPatch: guanjialin \u003c1406147701@qq.com\u003e\n\nThis closes #2228\n"
    },
    {
      "commit": "44b0b5d3c9b2bcaae43470bfe98721d0281958e5",
      "tree": "449ba6477286a35b847b33e009d99c568afa7e37",
      "parents": [
        "fa22f34e7466d0654dd207ab2e593c5337a1eac5"
      ],
      "author": {
        "name": "Stoyan Markov",
        "email": "stoyan.markov@modix.eu",
        "time": "Fri Sep 04 12:49:38 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Oct 01 23:02:51 2020 +0200"
      },
      "message": "THRIFT-5103: Fix for PHP7.4 deprecated syntax\nClient: php\nPatch: Stoyan Markov\n\nThis closes #2230\n"
    },
    {
      "commit": "fa22f34e7466d0654dd207ab2e593c5337a1eac5",
      "tree": "02155522cdb8cddfa201fd903df83fa2c5b8346f",
      "parents": [
        "03f01fba18979128cc80cfc03ccdb0f4ffece47b"
      ],
      "author": {
        "name": "wangyunjian",
        "email": "wangyunjian@huawei.com",
        "time": "Sun Jul 26 23:13:56 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Oct 01 23:00:11 2020 +0200"
      },
      "message": "THRIFT-5256: Fix some compile warnings\nClient: c_glib\nPatch: wangyunjian\n\nThis closes #2207\n\nSigned-off-by: wangyunjian \u003cwangyunjian@huawei.com\u003e\n"
    },
    {
      "commit": "03f01fba18979128cc80cfc03ccdb0f4ffece47b",
      "tree": "c7108a9a7078a7a7d4fe92f3a72a26a686a0a2bc",
      "parents": [
        "b1a5cd6542f4591563d39ed2021be9fc4690528f"
      ],
      "author": {
        "name": "Christopher Chavez",
        "email": "chrischavez@gmx.us",
        "time": "Thu Oct 01 11:53:41 2020 -0500"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Oct 01 22:43:54 2020 +0200"
      },
      "message": "Fix c_glib implicit function declarations\nClient: c_glib\nPatch: Christopher Chavez\n\nThis closes #2249\n"
    },
    {
      "commit": "b1a5cd6542f4591563d39ed2021be9fc4690528f",
      "tree": "e092d2139105226fc793f604b4464be2b6c9ae28",
      "parents": [
        "077b5fce825e79d84592fff893639b92b637eec7"
      ],
      "author": {
        "name": "Tom Wieczorek",
        "email": "t.wieczorek@yieldlab.de",
        "time": "Wed Sep 30 17:43:16 2020 +0200"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Wed Sep 30 10:20:19 2020 -0700"
      },
      "message": "Fix typo\n"
    },
    {
      "commit": "077b5fce825e79d84592fff893639b92b637eec7",
      "tree": "71b623e3085c1d77d53a6189a0658f86a9b5e7ed",
      "parents": [
        "062521f3b6f578d2b78f0ba189cf5d7968074cb1"
      ],
      "author": {
        "name": "Duru Can Celasun",
        "email": "dcelasun@apache.org",
        "time": "Wed Sep 30 07:25:51 2020 +0100"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Wed Sep 30 07:25:51 2020 +0100"
      },
      "message": "go: Use sync.Pool for gzip in HTTP transport\n\nb67cad4 introduced transparent gzip support for the HTTP transport but\r\ncalling gzip.NewWriter() with every request causes a large number of\r\nmemory allocations [1] and can create GC pressure.\r\n\r\nAvoid this by using a sync.Pool for gzip writers.\r\n\r\n[1] https://old.reddit.com/r/golang/comments/9uejp4/usage_of_syncpool_for_gzipwriter_in_http_handlers/e94jh8c/"
    },
    {
      "commit": "062521f3b6f578d2b78f0ba189cf5d7968074cb1",
      "tree": "5e31fc257454214b75590dd636170e4aa100a543",
      "parents": [
        "6fd830d69024435290ff0e92936b89ebc9603678"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Tue Sep 22 11:33:52 2020 +0800"
      },
      "committer": {
        "name": "Zezeng Wang",
        "email": "51382517@qq.com",
        "time": "Mon Sep 28 14:31:07 2020 +0800"
      },
      "message": "add the test case into cmake\n"
    },
    {
      "commit": "6fd830d69024435290ff0e92936b89ebc9603678",
      "tree": "ce270e0a6315593e4e83a0537d0a0ce09f63a2a0",
      "parents": [
        "c553155af8330a54212eefefaf877b1725a449bc"
      ],
      "author": {
        "name": "Dedipyaman Das",
        "email": "30053071+2DSharp@users.noreply.github.com",
        "time": "Sun Sep 27 02:29:23 2020 +0530"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Sep 27 12:04:43 2020 +0200"
      },
      "message": "THRIFT-4942 Set PHP struct generated field values as private with getters and setters\nClient: php\nPatch: Das Dedipyaman\n\nThis closes #2245\n\nUpdate field access for getters_setters flag. FFields are private if getters_setters are set, otherwise, public.\n"
    },
    {
      "commit": "c553155af8330a54212eefefaf877b1725a449bc",
      "tree": "80d1783f7e31e9ec84a52e9d3d4d97fd6fce2cda",
      "parents": [
        "6dcd64ee5c0886697b38278956335ae4e945341b"
      ],
      "author": {
        "name": "Dedipyaman Das",
        "email": "30053071+2DSharp@users.noreply.github.com",
        "time": "Sat Sep 19 23:20:46 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Fri Sep 25 22:04:41 2020 +0200"
      },
      "message": "THRIFT-4942 Set PHP struct generated field values as private with getters and setters\nClient: php\nPatch: Das Dedipyaman\n\nThis closes #1859\nThis closes #2238\n"
    },
    {
      "commit": "6dcd64ee5c0886697b38278956335ae4e945341b",
      "tree": "38986b372d8a2d806d11ec6c0f96593c8e3f0e8c",
      "parents": [
        "a2c44665b416522477cffa6752c2f323768d0507"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Tue Sep 22 15:03:57 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Wed Sep 23 09:16:42 2020 -0700"
      },
      "message": "THRIFT-5279: Go serializer/deserializer cleanups\n\nClient: go\n\nCleanup the default NewTSerializer and NewTDeserializer implementations\nto save an unnecessary allocation, and provide\nNewTSerializerPoolSizeFactory and NewTDeserializerPoolSizeFactory for\neasier non-default pool usages.\n"
    },
    {
      "commit": "a2c44665b416522477cffa6752c2f323768d0507",
      "tree": "9942f7d24637c0ee3b4e51b8c8e26e6b3f56c640",
      "parents": [
        "03f4729f7c19abb206fae439e27c1dda7250fdcd"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Mon Sep 21 12:33:26 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Tue Sep 22 16:48:38 2020 -0700"
      },
      "message": "THRIFT-5278: Allow set protoID in go THeader transport/protocol\n\nClient: go\n\nIn Go library code, allow setting the underlying protoID to a\nnon-default (TCompactProtocol) one for THeaderTransport/THeaderProtocol.\n"
    },
    {
      "commit": "03f4729f7c19abb206fae439e27c1dda7250fdcd",
      "tree": "c68efb374b900052d7a4e4e9a43bc3d491982180",
      "parents": [
        "e29c39f921a45ecb87d0f628e2a9babbbc5adbf2",
        "4750f361c88a8e7d2fc204d139684b5547ee0425"
      ],
      "author": {
        "name": "Zezeng Wang",
        "email": "zeshuai007@apache.org",
        "time": "Tue Sep 22 09:35:39 2020 +0800"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Tue Sep 22 09:35:39 2020 +0800"
      },
      "message": "Merge pull request #2235 from deiv/fix-abstract-unix-socket-name\n\nFix abstract unix socket name"
    },
    {
      "commit": "4750f361c88a8e7d2fc204d139684b5547ee0425",
      "tree": "9737a89de551a1ab3c070b1d7e9ae4c5a5e407ad",
      "parents": [
        "b0d14133d5071370905a1b54b37a1a7c86d50e6d"
      ],
      "author": {
        "name": "David Suárez",
        "email": "david.sephirot@gmail.com",
        "time": "Wed Sep 09 15:49:37 2020 +0200"
      },
      "committer": {
        "name": "David Suárez",
        "email": "david.sephirot@gmail.com",
        "time": "Mon Sep 21 11:36:36 2020 +0200"
      },
      "message": "Fix abstract unix socket name\n\nFor the abstract unix socket address type, the string in the\n\u0027sun_path\u0027 field of the \u0027sockaddr_un\u0027 struct, is a not null-terminated\nstring (see unix(7)).\n\nFix the lentgh calculation of the \u0027sun_path\u0027 field to not add\nthe termination null byte.\n"
    },
    {
      "commit": "e29c39f921a45ecb87d0f628e2a9babbbc5adbf2",
      "tree": "cb1599526ffd62f369af60a4557b5d811bc048ac",
      "parents": [
        "25f8d5385f4f972fc125273c05e92592116c4606"
      ],
      "author": {
        "name": "David Mollitor",
        "email": "dmollitor@apache.org",
        "time": "Mon May 11 15:50:32 2020 -0400"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Sep 20 19:11:39 2020 +0200"
      },
      "message": "THRIFT-5203: Remove Unused toString Method in TSerializer\nClient: cpp\nPatch: David Mollitor\n\nThis closes #2138\n"
    },
    {
      "commit": "25f8d5385f4f972fc125273c05e92592116c4606",
      "tree": "c5565d3d317e6f6442d2030ff579378fe21d7693",
      "parents": [
        "d5e5fd0c54891e9225a2ce5becd8d8b683f32f06"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Sep 20 19:05:39 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Sep 20 19:07:04 2020 +0200"
      },
      "message": "fix CI: add Erlang crashes to known failures\n"
    },
    {
      "commit": "d5e5fd0c54891e9225a2ce5becd8d8b683f32f06",
      "tree": "00e71d3b0fd20f6c78ab4d8ecdbdb74ffff68d7f",
      "parents": [
        "119030848c4296ddef43d66ffa0cca1354fb357b",
        "e6d97c0f66118c43f43bb71644c18d330a3ae522"
      ],
      "author": {
        "name": "Zezeng Wang",
        "email": "zeshuai007@apache.org",
        "time": "Sat Sep 19 11:59:11 2020 +0800"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Sat Sep 19 11:59:11 2020 +0800"
      },
      "message": "Merge pull request #2221 from zeshuai007/THRIFT-5249\n\nTHRIFT-5249 Fix Failed to run FastbinaryTest.py"
    },
    {
      "commit": "e6d97c0f66118c43f43bb71644c18d330a3ae522",
      "tree": "89ba0b08df62eba0edd4f0e5727ed8a1a4dc3e07",
      "parents": [
        "c80b8bbe703f593d1aa47941bd6b61f7726068bd"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Tue Aug 25 09:53:39 2020 +0800"
      },
      "committer": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Sat Sep 19 09:23:58 2020 +0800"
      },
      "message": "test ci fix\n"
    },
    {
      "commit": "119030848c4296ddef43d66ffa0cca1354fb357b",
      "tree": "5861c617491cf94b83b48f9f4412dd7a1aa6622f",
      "parents": [
        "c77941c60da01f466827ff619d571055ff76351f",
        "63213c17ad3fece91fdaaca8f59165ca3f41c5c1"
      ],
      "author": {
        "name": "Zezeng Wang",
        "email": "51382517@qq.com",
        "time": "Fri Sep 18 16:05:44 2020 +0800"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Fri Sep 18 16:05:44 2020 +0800"
      },
      "message": "Merge pull request #2191 from zeshuai007/Implements_TConfig\n\nTHRIFT-5237 Implement MAX_MESSAGE_SIZE and consolidate limits into a TConfiguration class(JAVA)"
    },
    {
      "commit": "c77941c60da01f466827ff619d571055ff76351f",
      "tree": "23775871b3ad030c0cdb430d3d6c6dd6d4051bbf",
      "parents": [
        "0d6a2d36ea02839313e63421fb1ba4a9de2604ea"
      ],
      "author": {
        "name": "wangyunjian",
        "email": "wangyunjian@huawei.com",
        "time": "Fri Mar 06 22:28:16 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Sep 17 11:34:17 2020 +0200"
      },
      "message": "THRIFT-5134: Fix memory leak when the handler method return FALSE\nClient: c_glib\nPatch: wangyunjian\n\nThis closes #2049\n\nSigned-off-by: wangyunjian \u003cwangyunjian@huawei.com\u003e\n"
    },
    {
      "commit": "0d6a2d36ea02839313e63421fb1ba4a9de2604ea",
      "tree": "75d5b73814ba8ec292e836180851d97df28bd16b",
      "parents": [
        "dbc4fbf4fe43ba8effd8e4d7cc5c993625cb1d11"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Tue Mar 24 18:31:37 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Sep 17 11:30:32 2020 +0200"
      },
      "message": "THRIFT-4272: warnings in glibc library\nClient: c_glib\nPatch: Zezeng Wang\n\nThis closes #2067\n"
    },
    {
      "commit": "dbc4fbf4fe43ba8effd8e4d7cc5c993625cb1d11",
      "tree": "7574c5ea203fd2c4d398a98c250ec6d8b4e2dab3",
      "parents": [
        "dd6c8c1069d74f47e81f47dc89285edf906a464e"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Sep 17 09:55:07 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Sep 17 09:55:07 2020 +0200"
      },
      "message": "fix CI: add Erlang crashes to known failures\n"
    },
    {
      "commit": "63213c17ad3fece91fdaaca8f59165ca3f41c5c1",
      "tree": "bbc363ae873a334e643ff9bb64863b5d76311b92",
      "parents": [
        "dd6c8c1069d74f47e81f47dc89285edf906a464e"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Wed Sep 16 16:56:51 2020 +0800"
      },
      "committer": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Wed Sep 16 18:37:40 2020 +0800"
      },
      "message": "Implements TConfiguration for java\n"
    },
    {
      "commit": "dd6c8c1069d74f47e81f47dc89285edf906a464e",
      "tree": "c0092bc0000b2d55e7088c294b851e8f4147ad0f",
      "parents": [
        "40cd0215f15ccbd2462bb855389467b0fd05b66a"
      ],
      "author": {
        "name": "Mario Emmenlauer",
        "email": "memmenlauer@biodataanalysis.de",
        "time": "Wed Sep 09 13:43:15 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Sep 15 20:39:44 2020 +0200"
      },
      "message": "TServerSocket.cpp: Ensure the server is really listening (via helper variable listening_)\nClient: cpp\nPatch: Mario Emmenlauer\n\nThis closes #2232\n"
    },
    {
      "commit": "40cd0215f15ccbd2462bb855389467b0fd05b66a",
      "tree": "d55dc0da383d601fda508355de4f5cf5a5059470",
      "parents": [
        "304f50b39fbb1f6a66c1bb76cf88a135d015fda9"
      ],
      "author": {
        "name": "Mario Emmenlauer",
        "email": "memmenlauer@biodataanalysis.de",
        "time": "Wed Sep 09 13:53:31 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Sep 15 09:03:56 2020 +0200"
      },
      "message": "Added getter and setter for domain socket path, and minor fix for printing abstract domain socket paths\nClient: cpp\nPatch: Mario Emmenlauer\n\nThis closes #2233\n"
    },
    {
      "commit": "304f50b39fbb1f6a66c1bb76cf88a135d015fda9",
      "tree": "3b2eba96cc850b1968419da3baa94b88306ffb91",
      "parents": [
        "413377bbbcacbf0b8db5ff456d71ef5fe3a9c2e3"
      ],
      "author": {
        "name": "Jonathan Mackenzie",
        "email": "jonmac1@gmail.com",
        "time": "Tue Sep 15 01:41:07 2020 +0930"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Mon Sep 14 09:11:07 2020 -0700"
      },
      "message": "Fixed double newline at end of generated python service files (#2236)\n\nGenerated python files have a blank line at the end of files, except for\r\nservice files where there are two blank lines, this change makes these\r\nservice files consistent.\r\n\r\nThis change is trivial and thus does not require a ticket."
    },
    {
      "commit": "413377bbbcacbf0b8db5ff456d71ef5fe3a9c2e3",
      "tree": "a0f1da0200b60fba681e4f599f98773ad93a5d20",
      "parents": [
        "6b1cb30f48713f11c0b485d08f494d8cf607a05e"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sat Sep 12 19:18:06 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sat Sep 12 19:18:36 2020 +0200"
      },
      "message": "fix CI: add Erlang crashes to known failures\n"
    },
    {
      "commit": "6b1cb30f48713f11c0b485d08f494d8cf607a05e",
      "tree": "12c5fbe9cc7707d4f13dc12f7b8f76509cc19e86",
      "parents": [
        "03715899d280c834f8cccbb0435fdedcc456c0e1"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Wed May 27 12:08:01 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sat Sep 12 19:07:28 2020 +0200"
      },
      "message": "THRIFT-5217 Deprecated boost header\nClient: cpp\nPatch: Zezeng Wang\n\nThis closes #2158\n"
    },
    {
      "commit": "03715899d280c834f8cccbb0435fdedcc456c0e1",
      "tree": "5972cd2316bb19f45969b205a6ac90c48fe07bf8",
      "parents": [
        "47d4a00f51de56d409fe016c5aa78d763128cbca"
      ],
      "author": {
        "name": "longzhiri",
        "email": "persistentsnail@gmail.com",
        "time": "Tue Aug 04 22:01:09 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sat Sep 12 19:01:36 2020 +0200"
      },
      "message": "THRIFT-5260 Fix the thrift compiler generate problematic lua code for the oneway method\nClient: lua\nPatch: longzhiri \u003cpersistentsnail@gmail.com\u003e\n\nThis closes #2212\n\nThe oneway method\u0027s processor has no need to write the result to client, but it is necessary to return values of each handler\u0027s return.\n"
    },
    {
      "commit": "47d4a00f51de56d409fe016c5aa78d763128cbca",
      "tree": "9feec995ab65897125c3f281c8e3260de731001d",
      "parents": [
        "b0d14133d5071370905a1b54b37a1a7c86d50e6d"
      ],
      "author": {
        "name": "Mario Emmenlauer",
        "email": "mario@emmenlauer.de",
        "time": "Thu May 21 19:45:48 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sat Sep 12 18:52:22 2020 +0200"
      },
      "message": "Deprecated WinXP and Server2003 methods\nClient: cpp\nPatch: Mario Emmenlauer\n\nThis closes #2165\n"
    },
    {
      "commit": "b0d14133d5071370905a1b54b37a1a7c86d50e6d",
      "tree": "517583f4bb61da82195f237c3663cac3f259e1bc",
      "parents": [
        "935770c6b077fd96430684049078bdb9bdff50c5"
      ],
      "author": {
        "name": "Allen George",
        "email": "allen.george@gmail.com",
        "time": "Sun Mar 29 11:48:55 2020 -0400"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Sep 02 09:03:40 2020 +0200"
      },
      "message": "THRIFT-5158 Update Rust generator and Rust lib,test,tutorial to only support 2018 edition\nClient: rs\nPatch: Allen George\n\nThis closes #2078\n"
    },
    {
      "commit": "935770c6b077fd96430684049078bdb9bdff50c5",
      "tree": "124d39ef5293e40c68e8cf90c89b27fb3117281c",
      "parents": [
        "073166f2c4b99b5ab4b425dd2dfc137b00a2e260"
      ],
      "author": {
        "name": "wangyunjian",
        "email": "wangyunjian@huawei.com",
        "time": "Sun Mar 08 17:31:21 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Sep 02 08:54:35 2020 +0200"
      },
      "message": "THRIFT-5136: Fix memory leak in thrift_multiplexed_processor_process_impl()\nClient: c_glib\nPatch: wangyunjian \u003cwangyunjian@huawei.com\u003e\n\nThis closes #2052\n\nSigned-off-by: wangyunjian \u003cwangyunjian@huawei.com\u003e\n"
    },
    {
      "commit": "073166f2c4b99b5ab4b425dd2dfc137b00a2e260",
      "tree": "e6e3e48a99ac7bb1146aedb88647285fd9e083f2",
      "parents": [
        "021cb2707086a926ae49dcb9c1b7929472d0daa9"
      ],
      "author": {
        "name": "wangyunjian",
        "email": "wangyunjian@huawei.com",
        "time": "Sun Jul 26 21:25:50 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Sep 02 08:49:42 2020 +0200"
      },
      "message": "THRIFT-5255: Fix stack overflow in framed transport\nClient: c_glib\nPatch: wangyunjian \u003cwangyunjian@huawei.com\u003e\n\nThis closes #2206\n\nSigned-off-by: wangyunjian \u003cwangyunjian@huawei.com\u003e\n"
    },
    {
      "commit": "021cb2707086a926ae49dcb9c1b7929472d0daa9",
      "tree": "b06f41eec9e6ad3f5b4480b009852922bcab20d0",
      "parents": [
        "21b3e46993005e86b05714e3806ee9eb53a1d0af"
      ],
      "author": {
        "name": "Zero",
        "email": "longzhiri@gmail.com",
        "time": "Mon Aug 03 20:44:00 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Mon Aug 31 22:52:39 2020 +0200"
      },
      "message": "THRIFT-5259 Fix \"Transport endpoint is not connected \" error when running lua test server accepts a connection\nClient: lua\nPatch: Zero \u003clongzhiri@gmail.com\u003e\n\nThis closes #2211\n"
    },
    {
      "commit": "21b3e46993005e86b05714e3806ee9eb53a1d0af",
      "tree": "f812aaf9cca1714ae611327fb03161287a96f854",
      "parents": [
        "cc41c29c08be3830104ef7bec2c181c99d40b1a3"
      ],
      "author": {
        "name": "longzhiri",
        "email": "persistentsnail@gmail.com",
        "time": "Sat Aug 08 15:24:10 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Mon Aug 31 22:46:43 2020 +0200"
      },
      "message": "THRIFT-5262 Fix a encoding struct bug in the compact protocol implementation to lua\nClient: lua\nPatch: longzhiri \u003cpersistentsnail@gmail.com\u003e\n\nThis closes #2214\n"
    },
    {
      "commit": "cc41c29c08be3830104ef7bec2c181c99d40b1a3",
      "tree": "c6a56e10b9acc272176adcfdded1b5972e802a10",
      "parents": [
        "3a03da53af6969354d541bf225d9f670978c4118"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Sat Aug 22 15:08:22 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Mon Aug 31 22:41:45 2020 +0200"
      },
      "message": "Fix appveryor check\nPatch: Zezeng Wang\n\nThis closes #2220\n"
    },
    {
      "commit": "3a03da53af6969354d541bf225d9f670978c4118",
      "tree": "913c4928ee1ce2f54cbed268841427cdfc1b1fc4",
      "parents": [
        "22b6c0c8bbc7089ce714f782366c2914c5e9eac5"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Sat Aug 22 12:15:46 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Mon Aug 31 22:37:01 2020 +0200"
      },
      "message": "THRIFT-5268 Fix some file loss \")\" in define\nClient: c_glib\nPatch: Zezeng Wang\n\nThis closes #2218\n"
    },
    {
      "commit": "22b6c0c8bbc7089ce714f782366c2914c5e9eac5",
      "tree": "c663ad84228397462b114aeb761d399ba5d63f51",
      "parents": [
        "0503fc0112728bd17d9b5163716265c2a879404f"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Fri Aug 28 17:20:31 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Sat Aug 29 09:38:13 2020 -0700"
      },
      "message": "THRIFT-5270: Fix wrong int to string conversions\n\nClient: go\n\nStarting from go 1.15, go test starts to complain about wrongly used int\nto string conversions:\n\n    ./field.go:58:83: conversion from int to string yields a string of one rune, not a string of digits (did you mean fmt.Sprint(x)?)\n    ./numeric.go:72:12: conversion from int64 to string yields a string of one rune, not a string of digits (did you mean fmt.Sprint(x)?)\n    ./json_protocol_test.go:612:92: conversion from int to string yields a string of one rune, not a string of digits (did you mean fmt.Sprint(x)?)\n    ./simple_json_protocol_test.go:685:96: conversion from int to string yields a string of one rune, not a string of digits (did you mean fmt.Sprint(x)?)\n\njson_protocol_test and simple_json_protocol_test usages are actually\nalready in format arg so just remove the conversion is good enough.\nfield is no longer used anywhere so just removed it (there\u0027s one line of\ncommented out code in compact_protocol so remove that line as well). The\none in numeric.go is actually a bug. We didn\u0027t set sValue correctly in\nNewNumericFromI64 and NewNumericFromI32 functions.\n"
    },
    {
      "commit": "0503fc0112728bd17d9b5163716265c2a879404f",
      "tree": "9ac0ade6918ac2a3d3783f61151aa5d9ee8e7e92",
      "parents": [
        "c80b8bbe703f593d1aa47941bd6b61f7726068bd"
      ],
      "author": {
        "name": "panivko",
        "email": "vladimir.panivko@together.com",
        "time": "Fri May 29 08:17:16 2020 +0300"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Aug 25 21:58:10 2020 +0200"
      },
      "message": "THRIFT-5132 Warning in TSocket when using ssl connection\nClient: PHP\nPatch: Vladimir Panivko\n\nThis closes #2160\n"
    },
    {
      "commit": "c80b8bbe703f593d1aa47941bd6b61f7726068bd",
      "tree": "ed77589840f5c4c64d09465270edba1c5d3eb9e1",
      "parents": [
        "01d53f483a7531ad4899b522060e8913dca309fb"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Thu Jul 23 09:43:41 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Fri Aug 07 16:54:14 2020 +0200"
      },
      "message": "THRIFT-5237 Implement MAX_MESSAGE_SIZE and consolidate limits into a TConfiguration class\nClient: c_glib\nPatch: Zezeng Wang\n\nThis closes #2208\n"
    },
    {
      "commit": "01d53f483a7531ad4899b522060e8913dca309fb",
      "tree": "5e0defc327b49ed329aa9022cb6ea884052239a7",
      "parents": [
        "68c1506715d834c5ab274a622a67bab207936ac7"
      ],
      "author": {
        "name": "Neil Williams",
        "email": "neil@reddit.com",
        "time": "Tue Jul 07 07:27:29 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Thu Aug 06 08:27:55 2020 -0700"
      },
      "message": "THRIFT-5248: Python: Make TSocket.isOpen check if server still connected\n\nClient: py\n\nThis is inspired by changes to the Go library (THRIFT-5214) and, by\nproxy, this blog post[1]. The idea is that if the other end of the\nsocket has closed their end of the connection, we can figure that out by\ndoing a non-blocking read on our socket before we waste time serializing\nand sending a message just to find out the socket is closed when we try\nto read the response.\n\n[1]: https://github.blog/2020-05-20-three-bugs-in-the-go-mysql-driver/\n"
    },
    {
      "commit": "68c1506715d834c5ab274a622a67bab207936ac7",
      "tree": "6f51b8289651a568e71fb6611e79de5fef76d87d",
      "parents": [
        "b93fafd327f6de0f4c7496da5dfd5e8c5d8fe499"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Aug 04 23:09:14 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Aug 05 11:55:00 2020 +0200"
      },
      "message": "THRIFT-5261 Support for deprecated methods (via annotation)\nClient: Delphi\nPatch: Jens Geyer\n\nThis closes #2213\n"
    },
    {
      "commit": "b93fafd327f6de0f4c7496da5dfd5e8c5d8fe499",
      "tree": "77f824ac4fb6ae2aed8276465e9d6959cbac1de9",
      "parents": [
        "64f419b5ad40df233d34cc3715c68b8d85712699"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Sun Aug 02 13:36:54 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Mon Aug 03 10:48:24 2020 -0700"
      },
      "message": "THRIFT-5214: Use peek to implement socket connectivity check\n\nClient: go\n\nIn previous implementation of socket connectivity check, we try to read\n1 byte and put it into buffer when succeeded. The buffer complicates\nthe implementation of Read function. Change to use syscall.Recvfrom with\nMSG_PEEK flag instead so that the buffer is no longer needed.\n"
    },
    {
      "commit": "64f419b5ad40df233d34cc3715c68b8d85712699",
      "tree": "223de55598275d97826316e2600fa57100ede006",
      "parents": [
        "86352b4821085d63861deab59c46ef1042fbfe81"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Wed Jul 29 10:12:53 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Wed Jul 29 12:42:37 2020 -0700"
      },
      "message": "THRIFT-5257: Fix Go THeaderTransport endOfFrame handling\n\nClient: go\n\nIn the current implementation, we only call endOfFrame when we hit EOF\nwhen reading from the frameReader. The problem is in go stdlib the Read\ncall finished reading the remaining data from frameReader will not\nreturn EOF, the next Read will. This caused us in most cases only call\nendOfFrame at the beginning of the next frame, which could cause\ntroubles because we didn\u0027t read the beginning of the frame properly.\n"
    },
    {
      "commit": "86352b4821085d63861deab59c46ef1042fbfe81",
      "tree": "6c9c441d4125e4bb115e9989a769c99b36212677",
      "parents": [
        "23c8e52fa0708c53f74958944ecf04b293d1db73"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Mon Jun 15 17:00:33 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sat Jul 25 12:13:53 2020 +0200"
      },
      "message": "THRIFT-5237 Implement MAX_MESSAGE_SIZE and consolidate limits into a TConfiguration class\nClient: cpp\nPatch: Zezeng Wang\n\nThis closes #2185\n"
    },
    {
      "commit": "23c8e52fa0708c53f74958944ecf04b293d1db73",
      "tree": "2488715cb1d846e8c57a2b8629beac2761dd203c",
      "parents": [
        "363ee0001f45118067249ed75ddc348195bf5734"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Jul 15 23:46:23 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jul 16 08:51:36 2020 +0200"
      },
      "message": "THRIFT-5254 Member name cannot be Isset (unless it is an \"required\" member)\nClient: netstd\nPatch: Jens Geyer\n\nThis closes #2203\n"
    },
    {
      "commit": "363ee0001f45118067249ed75ddc348195bf5734",
      "tree": "cf9848dd8ed758abd3690fed98a7475d7525b8f7",
      "parents": [
        "58e655e4b99e97a733057be78f614b4d9ddea560"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Jul 15 23:44:56 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jul 16 08:51:20 2020 +0200"
      },
      "message": "THRIFT-5253 using Result in result name generates wrong IAsync interface\nClient: netstd\nPatch: Jens Geyer\n\nThis closes #2202\n"
    },
    {
      "commit": "58e655e4b99e97a733057be78f614b4d9ddea560",
      "tree": "cdf37d1f919b1456ea099a0bd5d7933197b30c3c",
      "parents": [
        "ec57271d5b90ba06eaad99dda26dc0af9bd2af71"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Jul 14 15:34:44 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Jul 14 21:41:36 2020 +0200"
      },
      "message": "THRIFT-5252 Make CreateHttpClientHandler() method virtual\nClient: netstd\nPatch: Jens Geyer\n\nThis closes #2201\n"
    },
    {
      "commit": "ec57271d5b90ba06eaad99dda26dc0af9bd2af71",
      "tree": "bc7073638437650c1203e8612104e3e8f7deacb8",
      "parents": [
        "eb45c2a1e48cc50f70298a34702fb365c61b489d"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Mon Jul 13 21:15:31 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Mon Jul 13 23:42:45 2020 +0200"
      },
      "message": "THRIFT-5251 StringUtils\u003cT\u003e.ToString() raises an exception for enum values outside range\nClient: Delphi\nPatch: Jens Geyer\n"
    },
    {
      "commit": "eb45c2a1e48cc50f70298a34702fb365c61b489d",
      "tree": "53fcab0c8ebbdafe72ee483ea37ecd92ba288649",
      "parents": [
        "dd0918713d8b5db0a2cf9c3bd7141c2e252bd7e4"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Mon Jul 06 16:53:47 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Jul 07 22:18:07 2020 +0200"
      },
      "message": "THRIFT-5247 Avoiding meaningless System.copy\nClient: java\nPatch: Zezeng Wang\n\nThis closes #2196\n"
    },
    {
      "commit": "dd0918713d8b5db0a2cf9c3bd7141c2e252bd7e4",
      "tree": "467aa993e108167b035343ed0c4f662e721f20b6",
      "parents": [
        "761a869e0508d2cf7975b040a6da54ae62a889b6"
      ],
      "author": {
        "name": "dugenkui",
        "email": "dugenkui@meituan.com",
        "time": "Sat Jul 04 01:33:39 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Fri Jul 03 23:36:13 2020 +0200"
      },
      "message": "Fix FrameWriter.java typo\nClient: java\nPatch: dugenkui \u003cdugenkui@meituan.com\u003e\n\nThis closes #2193\n"
    },
    {
      "commit": "761a869e0508d2cf7975b040a6da54ae62a889b6",
      "tree": "e8f64a8a77b45b45434bb733210d648315f82533",
      "parents": [
        "6c5f5c8a94b9f8b697d5bd51f9a4fcb70e96c248"
      ],
      "author": {
        "name": "wangyunjian",
        "email": "wangyunjian@huawei.com",
        "time": "Thu Feb 27 00:02:19 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Jul 01 23:18:03 2020 +0200"
      },
      "message": "THRIFT-5118: Fix memory leak when the handler method return a exception\nClient: c_glib\nPatch: wangyunjian\n\nThis closes #2035\n\nSigned-off-by: wangyunjian \u003cwangyunjian@huawei.com\u003e\n"
    },
    {
      "commit": "6c5f5c8a94b9f8b697d5bd51f9a4fcb70e96c248",
      "tree": "c7310714f51e9afc4d8173303ee488ccac462ddc",
      "parents": [
        "4db7a0af13ac9614e3e9758d42b2791040f4dc7e"
      ],
      "author": {
        "name": "ResDiaryLewis",
        "email": "lewis.jackson@resdiary.com",
        "time": "Fri Jun 26 10:37:49 2020 +0100"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Jul 01 22:59:16 2020 +0200"
      },
      "message": "THRIFT-5329: Add THttpTransport constructor with HttpClient\nClient: netstd\nPatch: Lewis Jackson\n\nThis closes #2188\n"
    },
    {
      "commit": "4db7a0af13ac9614e3e9758d42b2791040f4dc7e",
      "tree": "6ea8c8eafb05706125445cb2865540dc1dc84b87",
      "parents": [
        "5dc1d268f5c63b804d0b185943467cfeb47859d5"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Sat Jun 27 10:13:34 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Wed Jul 01 11:50:44 2020 -0700"
      },
      "message": "THRIFT-5240: Do connectivity check in Go server\n\nClient: go\n\nIn compiler generated TProcessorFunction implementations, add a\ngoroutine after read the request to do connectivity check on the input\ntransport. If the transport is no longer open, cancel the context object\npassed into the handler implementation.\n\nAlso define ErrAbandonRequest error, to help TSimpleServer closing\nclient connections that\u0027s already closed on the other end.\n"
    },
    {
      "commit": "5dc1d268f5c63b804d0b185943467cfeb47859d5",
      "tree": "d57f0316bbfea7d7dfb9e86a3ec0f37c01fa7fe8",
      "parents": [
        "0dd1363931ac1f9a531b48ded7f1178194fa4ef6"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Sat Jun 27 08:34:31 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "fishywang@gmail.com",
        "time": "Tue Jun 30 10:07:48 2020 -0700"
      },
      "message": "THRIFT-5152: Separate timeout in TSSLSocket\n\nClient: go\n\nWe separated timeout in go\u0027s TSocket into connect timeout and socket\ntimeout in 81334cd, this change does the same for TSSLSocket to keep\nthem consistent.\n\nAlso rename the arg in NewTSocketFromConnTimeout from connTimeout to\nsocketTimeout, because in that function we already have a connection,\nso connect timeout is never used again. The timeout passed into that\nfunction is really for socket timeout, not connect timeout. The name of\nthat function actually means \"New TSocket From Conn (with) Timeout\", not\n\"New TSocket From ConnTimeout\" (I guess that\u0027s where the original\nconfusion came from).\n\nAlso add the missing change note for the breaking change.\n"
    },
    {
      "commit": "0dd1363931ac1f9a531b48ded7f1178194fa4ef6",
      "tree": "50bb2f7982572fba20d249ef8f5679035372f4ec",
      "parents": [
        "86cc6f095c5943cb382e5ef0e5cf889c6e09bd86"
      ],
      "author": {
        "name": "dugenkui",
        "email": "dugenkui@meituan.com",
        "time": "Wed Apr 29 02:41:02 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Jun 28 16:55:16 2020 +0200"
      },
      "message": "THRIFT-5190: StringUtils haven\u0027t take `(offset + length) \u003e bytes.length` into account\nClient: java\nPatch: dugenkui \u003cdugenkui@meituan.com\u003e\n\nThis closes #2125\n"
    },
    {
      "commit": "86cc6f095c5943cb382e5ef0e5cf889c6e09bd86",
      "tree": "97061f642591a2f32f7a225bb3f76b63e84cce48",
      "parents": [
        "24ca210fde0ad51769e359ad9f925ae30a6ed061"
      ],
      "author": {
        "name": "wangyunjian",
        "email": "wangyunjian@huawei.com",
        "time": "Sat Mar 21 22:34:02 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sat Jun 27 15:25:06 2020 +0200"
      },
      "message": "THRIFT-5144: Fix memory leak when generate deserialize list element\nClient: c_glib\nPatch: wangyunjian\n\nThis closes #2064\n\nSigned-off-by: wangyunjian \u003cwangyunjian@huawei.com\u003e\n"
    },
    {
      "commit": "24ca210fde0ad51769e359ad9f925ae30a6ed061",
      "tree": "2ff0fd3977be92bc7f835cd0afe45dfa9a384f12",
      "parents": [
        "6e16c2bc542657954966f5fde98d16398853582c"
      ],
      "author": {
        "name": "Salah Ghanim",
        "email": "salah.ghanim@gmail.com",
        "time": "Wed Jun 24 12:21:10 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 25 22:06:13 2020 +0200"
      },
      "message": "Fix README.md typo\nPatch: Salah Ghanim\n\nThis closes #2186\n"
    },
    {
      "commit": "6e16c2bc542657954966f5fde98d16398853582c",
      "tree": "00e0bd8bc1c59efd3f9e5861c6763c842461bee5",
      "parents": [
        "283410126ccb3ac4990045e07cccb5df11ee2a16"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Jun 24 23:51:01 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 25 22:00:52 2020 +0200"
      },
      "message": "THRIFT-5238 GetHashCode can throw NullReferenceException\nClient: netstd\nPatch: Jens Geyer\n\nThis closes #2187\n"
    },
    {
      "commit": "283410126ccb3ac4990045e07cccb5df11ee2a16",
      "tree": "0b673389fe3a02ca5972dfe04ef5a1c16c0ec102",
      "parents": [
        "bcae3bb52f976ce245ad77dfb060e5776d67ce85"
      ],
      "author": {
        "name": "Emmanuel Brard",
        "email": "emmanuel.brard@getyourguide.com",
        "time": "Mon Jun 22 10:40:11 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Mon Jun 22 22:50:45 2020 +0200"
      },
      "message": "THRIFT-2087 Python compiler replace non utf-8 char with default\nClient: py\nPatch: Emmanuel Brard\n\nThis closes #2184\n"
    },
    {
      "commit": "bcae3bb52f976ce245ad77dfb060e5776d67ce85",
      "tree": "6359791188eabd62dc520426c89cc91a4c45bb3b",
      "parents": [
        "8b8633e8d805905868f359adf85d18326204a5d5",
        "e79f764f09afdfe829a06ca721059d34244d7c20"
      ],
      "author": {
        "name": "Duru Can Celasun",
        "email": "dcelasun@apache.org",
        "time": "Thu Jun 18 22:09:33 2020 +0100"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Thu Jun 18 22:09:33 2020 +0100"
      },
      "message": "THRIFT-5233: Handle I/O timeouts in go library (#2181)\n\nClient: go\r\n\r\nAs discussed in the JIRA ticket, this commit changes how we handle I/O\r\ntimeouts in the go library.\r\n\r\nThis is a breaking change that adds context to all Read*, Write*, and\r\nSkip functions to TProtocol, along with the compiler change to support\r\nthat, and also adds context to TStandardClient.Recv, TDeserializer,\r\nTStruct, and a few others.\r\n\r\nAlong with the function signature changes, this commit also implements\r\ncontext cancellation check in the following TProtocol\u0027s ReadMessageBegin\r\nimplementations:\r\n\r\n- TBinaryProtocol\r\n- TCompactProtocol\r\n- THeaderProtocol\r\n\r\nIn those ReadMessageBegin implementations, if the passed in context\r\nobject has a deadline attached, it will keep retrying the I/O timeout\r\nerrors, until the deadline on the context object passed. They won\u0027t\r\nretry I/O timeout errors if the passed in context does not have a\r\ndeadline attached (still return on the first error)."
    },
    {
      "commit": "8b8633e8d805905868f359adf85d18326204a5d5",
      "tree": "ac16ed99161f625778a51c4ee48fa70b7d67792e",
      "parents": [
        "1bed620c5f91cf60fd7c4e54f16714fd50ad807c"
      ],
      "author": {
        "name": "wangyunjian",
        "email": "wangyunjian@huawei.com",
        "time": "Fri May 29 22:29:25 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 18 22:23:05 2020 +0200"
      },
      "message": "THRIFT-5221: Fix stack overflow when reading buffer\nClient: c_glib\nPatch: wangyunjian\n\nThis closes #2161\n\nSigned-off-by: wangyunjian \u003cwangyunjian@huawei.com\u003e\n"
    },
    {
      "commit": "1bed620c5f91cf60fd7c4e54f16714fd50ad807c",
      "tree": "a1d4d0e775bf13177531f1433679c5135dc4505e",
      "parents": [
        "7db2d0fa46fc7724eff9e0d5b85d28010265cf55"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 18 11:22:12 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 18 11:22:33 2020 +0200"
      },
      "message": "THRIFT-5235 Add property setter for isset flags\nClient: delphi\nPatch: Jens Geyer\n"
    },
    {
      "commit": "7db2d0fa46fc7724eff9e0d5b85d28010265cf55",
      "tree": "1b4873c7e39cfaeb5ccaaeaad1c01a7e2c722fb3",
      "parents": [
        "210202e65c4d68303438a42763e5b50a67d44a7d"
      ],
      "author": {
        "name": "Phil Price",
        "email": "philprice@gmail.com",
        "time": "Sun Aug 25 07:27:52 2019 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 18 00:37:40 2020 +0200"
      },
      "message": "THRIFT-5234 Fix a number of js/ts generation issues\nClient: js/ts\nPatch: Phil Price\n"
    },
    {
      "commit": "210202e65c4d68303438a42763e5b50a67d44a7d",
      "tree": "76117243c2004a28e7d18a15181d03cd963ff271",
      "parents": [
        "7b379944efe1f63511831f5555782310a4f3296d"
      ],
      "author": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Jun 14 14:40:04 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Jun 16 22:04:23 2020 +0200"
      },
      "message": "THRIFT-5229 Deprecate as3 support\nClient: as3\nPatch: Jens Geyer\n\nThis closes #2182\n"
    },
    {
      "commit": "7b379944efe1f63511831f5555782310a4f3296d",
      "tree": "1339e49c52ea45d6a4d415ad763a79f6b8c28228",
      "parents": [
        "26681fbdb77f6dfaf2f2613d4ad860a224e84b71"
      ],
      "author": {
        "name": "Marco Schroeter",
        "email": "mschroeter@biodataanalysis.de",
        "time": "Thu Mar 12 10:30:49 2020 +0100"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Mon Jun 15 22:32:43 2020 +0200"
      },
      "message": "Thrift.csproj: Stop writing AssemblyAttributes.cs to /tmp\nClient: netstd\nPatch: Marco Schroeter\n\nThis closes #2167\n"
    },
    {
      "commit": "e79f764f09afdfe829a06ca721059d34244d7c20",
      "tree": "9680d1a399fe1e60a7f399a5a80cf3fb6a6a501a",
      "parents": [
        "3f78c70bbba82c733b1545d39eb5b489ac384e4c"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Fri Jun 12 22:22:35 2020 -0700"
      },
      "committer": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Mon Jun 15 13:28:38 2020 -0700"
      },
      "message": "THRIFT-5233: Handle I/O timeouts in go library\n\nClient: go\n\nAs discussed in the JIRA ticket, this commit changes how we handle I/O\ntimeouts in the go library.\n\nThis is a breaking change that adds context to all Read*, Write*, and\nSkip functions to TProtocol, along with the compiler change to support\nthat, and also adds context to TStandardClient.Recv, TDeserializer,\nTStruct, and a few others.\n\nAlong with the function signature changes, this commit also implements\ncontext cancellation check in the following TProtocol\u0027s ReadMessageBegin\nimplementations:\n\n- TBinaryProtocol\n- TCompactProtocol\n- THeaderProtocol\n\nIn those ReadMessageBegin implementations, if the passed in context\nobject has a deadline attached, it will keep retrying the I/O timeout\nerrors, until the deadline on the context object passed. They won\u0027t\nretry I/O timeout errors if the passed in context does not have a\ndeadline attached (still return on the first error).\n"
    },
    {
      "commit": "26681fbdb77f6dfaf2f2613d4ad860a224e84b71",
      "tree": "b742ea0959bd5e90e1748323a870291ef8ad8e9f",
      "parents": [
        "3f78c70bbba82c733b1545d39eb5b489ac384e4c"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Wed Jun 03 17:24:38 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sun Jun 14 14:17:11 2020 +0200"
      },
      "message": "THRIFT-5225: Use nullptr instead of NULL\nPatch: Zezeng Wang\n\nThis closes #2168\n"
    },
    {
      "commit": "3f78c70bbba82c733b1545d39eb5b489ac384e4c",
      "tree": "34cf2af82e2a76ecd4eb1e6d86c15b38a97d37d2",
      "parents": [
        "dabfea2f98a9ab605748dea55b1efbb1932b361f"
      ],
      "author": {
        "name": "Stanislav Markevic",
        "email": "smarkevic@freelancer.com",
        "time": "Tue Feb 04 12:19:05 2020 +0000"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Jun 09 23:23:02 2020 +0200"
      },
      "message": "THRIFT-5082 Add a Class reference for PHP enum $_TSPEC\nClient: php\nPatch: Stanislav Markevic\n\nThis closes #2000\n"
    },
    {
      "commit": "dabfea2f98a9ab605748dea55b1efbb1932b361f",
      "tree": "ac141f9f985ad0aa540b9b6111b8c9ffcfb39728",
      "parents": [
        "cfbb905034c928f073639af00b30d74951744b61"
      ],
      "author": {
        "name": "max ulidtko",
        "email": "ulidtko@gmail.com",
        "time": "Tue May 19 21:44:46 2020 +0300"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Jun 09 23:09:25 2020 +0200"
      },
      "message": "THRIFT-5186: Rewrite address resolution in T{Nonblocking,}ServerSocket\nClient: cpp\nPatch: Max Ulidtko\n\nThis closes #2151\n"
    },
    {
      "commit": "cfbb905034c928f073639af00b30d74951744b61",
      "tree": "39e689e4941568f5b05892fcfbba02c0573eddeb",
      "parents": [
        "e382275bad2bd11fb5df33dd7db520fd7596f4ac"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Tue Jun 09 13:07:38 2020 -0700"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Tue Jun 09 21:07:38 2020 +0100"
      },
      "message": "THRIFT-5214: Reset read deadline in socketConn\n\nClient: go\r\n\r\nThis is a slightly different, and less error-prone approach from the\r\nfix in e382275b.\r\n\r\nThe previous approach relies on passing the set socket timeout into the\r\nunderlying socketConn from TSocket and TSSLSocket. But since we have so\r\nmany different constructors for TSocket and TSSLSocket, some makes the\r\ninitial connection in the constructor and some does not, there are so\r\nmany different places we would need to remember to pass socketTimeout\r\ninto socketConn. In the future, when we add another constructor to them,\r\nwe could either forget to pass the socket timeout into socketConn, or\r\ntry to pass it while we haven\u0027t constructed socketConn yet (which will\r\ncause panic), both are bad.\r\n\r\nIn this approach we just clear the read deadline in the connectivity\r\ncheck read. Because that\u0027s a non-blocking read, it would work just fine\r\nwithout a read deadline."
    },
    {
      "commit": "e382275bad2bd11fb5df33dd7db520fd7596f4ac",
      "tree": "274cea670a8b8388f62c97b25bd18b5be6933fdb",
      "parents": [
        "c9890cb873f127137abd513a7ebdf0186ee8c88c"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Mon Jun 08 06:06:17 2020 -0700"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Mon Jun 08 14:06:17 2020 +0100"
      },
      "message": "THRIFT-5214: Push read deadline in socketConn\n\nClient: go\r\n\r\nWe added socketConn to go library for connectivity check in\r\nhttps://github.com/apache/thrift/pull/2153, but forgot to push read\r\ndeadline on the socket when doing the connectivity checks. This caused\r\nthe issue of large number of connectivity checks to fail with I/O\r\ntimeout errors."
    },
    {
      "commit": "c9890cb873f127137abd513a7ebdf0186ee8c88c",
      "tree": "ba2ffa394398ea56c21f361d873627264a628c60",
      "parents": [
        "9fd134f269ccadd3a77a198d0c27c0a0d7c9c723"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Mon Jun 08 04:32:21 2020 -0700"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Mon Jun 08 12:32:21 2020 +0100"
      },
      "message": "THRIFT-5214: Partial rewrite of TFramedTransport\n\nClient: go\r\n\r\nWhile debugging the issue in THRIFT-5214, I original thought that was a\r\nbug in TFramedTransport implementation, so I took some time scrutinize\r\nthe TFramedTransport code. Although in the end there\u0027s no bug, the\r\ncurrent implementation of TFramedTransport, especially in the Read\r\nfunction, has some weird handling while at frame boundary, which is both\r\nerror-prone and hard to follow (I did found and fixed one bug there in\r\nhttps://github.com/apache/thrift/pull/1810 before).\r\n\r\nThe new implementation reads the whole frame into a buffer, which would\r\nuse slightly more memory, but it follows the pattern of TFramedTransport\r\nimplementation of other languages (e.g. Java), and also the pattern we\r\nhandle frame in THeaderTransport. It also reduced the complexity and\r\nweirdness of the frame boundary handling in Read implementation.\r\n\r\nThis rewrite also removes the print call from library code."
    },
    {
      "commit": "9fd134f269ccadd3a77a198d0c27c0a0d7c9c723",
      "tree": "620a50a1f1bfb4456a9792fed90b285ccfae8719",
      "parents": [
        "0acf23b7cf39922a2eee9b969e4e73989050f0d6"
      ],
      "author": {
        "name": "Yuxuan \u0027fishy\u0027 Wang",
        "email": "yuxuan.wang@reddit.com",
        "time": "Mon Jun 08 04:30:14 2020 -0700"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Mon Jun 08 12:30:14 2020 +0100"
      },
      "message": "Use io.CopyN to simplify THeaderTransport code\n\nClient: go\r\n\r\nIn THeaderTransport implementation, use io.CopyN instead of\r\nio.Copy+io.LimitReader.\r\n\r\nUnderlying io.CopyN is actually implemented with io.Copy+io.LimitReader\r\n[0], but it also does some extra checks we can take advantage of. It\r\nalso simplifies the code in thrift repo.\r\n\r\n[0]: https://github.com/golang/go/blob/83b181c68bf332ac7948f145f33d128377a09c42/src/io/io.go#L340"
    },
    {
      "commit": "0acf23b7cf39922a2eee9b969e4e73989050f0d6",
      "tree": "56f1d5bcd2df1c52e97e511afcb2ce829a5f9a8f",
      "parents": [
        "b1628cf8bcbe6c87b117004beb3de6316417739c"
      ],
      "author": {
        "name": "zeshuai007",
        "email": "51382517@qq.com",
        "time": "Wed May 13 17:07:37 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 04 21:43:30 2020 +0200"
      },
      "message": "THRIFT-5200 Thrift compiler will generate incorrect code when add \u0027cob_style\u0027 option\nClient: cpp\nPatch: Zezeng Wang\n\nThis closes #2144\n"
    },
    {
      "commit": "b1628cf8bcbe6c87b117004beb3de6316417739c",
      "tree": "472483bb7d5882a5025f514701eed757e698bab5",
      "parents": [
        "bde5cbc0788b936aff516e2c0527ff950cc9b466"
      ],
      "author": {
        "name": "wangyunjian",
        "email": "wangyunjian@huawei.com",
        "time": "Sun Mar 01 16:27:16 2020 +0800"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 04 21:25:58 2020 +0200"
      },
      "message": "THRIFT-5122: Fix memory leak on accept error in thrift_simple_server_serve()\nClient: c_glib\nPatch: wangyunjian\n\nThis closes #2039\n\nSigned-off-by: wangyunjian \u003cwangyunjian@huawei.com\u003e\n"
    },
    {
      "commit": "bde5cbc0788b936aff516e2c0527ff950cc9b466",
      "tree": "dbd75297c718a7ebbf5b36f4dd50f4a73c3ae4a3",
      "parents": [
        "eac4d0c79a5fc550fb61bc18f20d3b5aae8f6e7f"
      ],
      "author": {
        "name": "Mario Emmenlauer",
        "email": "mario@emmenlauer.de",
        "time": "Tue Jun 02 11:06:59 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Thu Jun 04 21:18:01 2020 +0200"
      },
      "message": "Added IsOpen() and GetPort() for netstd transports\nClient: netstd\nPatch: Mario Emmenlauer\n\nThis closes #2166\n"
    },
    {
      "commit": "eac4d0c79a5fc550fb61bc18f20d3b5aae8f6e7f",
      "tree": "df1649a839c3b5ad05c5f4105dfc6ea85e988891",
      "parents": [
        "fa770f61e9fd26af6bd6f0f2f4c3f7815523d0d8"
      ],
      "author": {
        "name": "Mario Emmenlauer",
        "email": "mario@emmenlauer.de",
        "time": "Thu Feb 20 17:12:29 2020 +0100"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Wed Jun 03 23:10:36 2020 +0200"
      },
      "message": "THRIFT-5114 Simplified reallocation of TMemoryBuffer\nClient: cpp\nPatch: Mario Emmenlauer\n\nThis closes #2030\n"
    },
    {
      "commit": "fa770f61e9fd26af6bd6f0f2f4c3f7815523d0d8",
      "tree": "de15459a8e60ffc1291fc982f21a279d9aa4b442",
      "parents": [
        "68f2194dfa3150526445d37afd80ededb7bb4585"
      ],
      "author": {
        "name": "Mario Emmenlauer",
        "email": "mario@emmenlauer.de",
        "time": "Mon May 11 20:45:42 2020 +0200"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Tue Jun 02 13:55:03 2020 +0200"
      },
      "message": "Use correct platform executable suffix for thrift compiler\nPatch: Mario Emmenlauer\n\nThis closes #2139\n"
    },
    {
      "commit": "68f2194dfa3150526445d37afd80ededb7bb4585",
      "tree": "58ba3b062f601eab4f25a64019facd2405b3adde",
      "parents": [
        "36bf0a491e900f09b894b54dbe037262acec73e5"
      ],
      "author": {
        "name": "Anton Filippov",
        "email": "afilippov@ac-sw.com",
        "time": "Tue Mar 31 18:51:16 2020 +0700"
      },
      "committer": {
        "name": "Jens Geyer",
        "email": "jensg@apache.org",
        "time": "Sat May 30 15:07:56 2020 +0200"
      },
      "message": "Fix STRERROR_R_CHAR_P cxx check (remove unused variable warning-\u003eerror)\nClient: cpp\nPatch: Anton Filippov\n\nThis closes #2081\n"
    }
  ],
  "next": "36bf0a491e900f09b894b54dbe037262acec73e5"
}
