{"schema":"libjg2-1",
"vpath":"/git/",
"avatar":"/git/avatar/",
"alang":"",
"gen_ut":1761317068,
"reponame":"libwebsockets",
"desc":"libwebsockets lightweight C networking library",
"owner": { "name": "Andy Green", "email": "andy@warmcat.com", "md5": "c50933ca2aa61e0fe2c43d46bb6b59cb" },"url":"https://libwebsockets.org/repo/libwebsockets",
"f":3,
"items": [
{"schema":"libjg2-1",
"cid":"779947a4dbfc69146ded3b616e73d190",
"commit": {"type":"commit",
"time": 1505954756,
"time_ofs": 480,
"oid_tree": { "oid": "b07a3d630a08763ac46b1f1a56a876738d5ac8c4", "alias": []},
"oid":{ "oid": "f85a1d42d8386b349527eefceb59ab3eaadb2cad", "alias": []},
"msg": "docs: README.coding.md: add explicit note about external poll loop forced service",
"sig_commit": { "git_time": { "time": 1505954756, "offset": 480 }, "name": "Andy Green", "email": "andy@warmcat.com", "md5": "c50933ca2aa61e0fe2c43d46bb6b59cb" },
"sig_author": { "git_time": { "time": 1505862455, "offset": 480 }, "name": "Andy Green", "email": "andy@warmcat.com", "md5": "c50933ca2aa61e0fe2c43d46bb6b59cb" }},
"body": "docs: README.coding.md: add explicit note about external poll loop forced service"
,
"diff": "diff --git a/README.coding.md b/README.coding.md\nindex 34ce55c..03dc6bf 100644\n--- a/README.coding.md\n+++ b/README.coding.md\n@@ -278,6 +278,26 @@ reflecting the real event:\n - use LWS_POLLHUP / LWS_POLLIN / LWS_POLLOUT from libwebsockets.h to avoid\n losing windows compatibility\n \n+You also need to take care about \u0022forced service\u0022 somehow... these are cases\n+where the network event was consumed, incoming data was all read, for example,\n+but the work arising from it was not completed. There will not be any more\n+network event to trigger the remaining work, Eg, we read compressed data, but\n+we did not use up all the decompressed data before returning to the event loop\n+because we had to write some of it.\n+\n+Lws provides an API to determine if anyone is waiting for forced service,\n+`lws_service_adjust_timeout(context, 1, tsi)`, normally tsi is 0. If it returns\n+0, then at least one connection has pending work you can get done by calling\n+`lws_service_tsi(context, -1, tsi)`, again normally tsi is 0.\n+\n+For eg, the default poll() event loop, or libuv/ev/event, lws does this\n+checking for you and handles it automatically. But in the external polling\n+loop case, you must do it explicitly. Handling it after every normal service\n+triggered by the external poll fd should be enough, since the situations needing\n+it are initially triggered by actual network events.\n+\n+An example of handling it is shown in the test-server code specific to\n+external polling.\n \n @section cpp Using with in c++ apps\n \n","s":{"c":1761317068,"u": 975}}
],"g": 1653,"chitpc": 0,"ehitpc": 0,"indexed":0
,
"ab": 0, "si": 0, "db":0, "di":0, "sat":0, "lfc": "0000"}