Commit Graph

366 Commits

Author SHA1 Message Date
6b52c4289c Prevent queueing of messages on connection after it will be closed 2025-09-15 15:25:40 -04:00
7ee5ca2a9b Remove dead code, use proper send_ordered_response
And prepare to try to close a connection gracefully
2025-09-15 15:08:19 -04:00
9120c05847 Use spend_cpu_cycles instead of volatile loop 2025-09-15 14:07:38 -04:00
528a467518 Make test names match binary names 2025-09-15 13:06:15 -04:00
a67d7a8531 Consolidate into one send_ordered_response 2025-09-15 13:01:56 -04:00
6717b70772 Remove HttpConnectionState::response_queue_mutex 2025-09-15 12:32:19 -04:00
34accb9d80 Move GetVersion to commit pipeline 2025-09-15 12:30:02 -04:00
f3c3f77a24 Extract commit pipeline to its own module 2025-09-15 11:51:01 -04:00
afd240dba7 Remove vestigial "round-robin" code 2025-09-15 11:22:14 -04:00
1cb7a4c301 Remove has_pending_responses_ 2025-09-15 11:10:47 -04:00
1b220d0d1c WIP 2025-09-15 10:28:17 -04:00
ec2ad27e33 Add explanatory comments 2025-09-15 00:07:44 -04:00
eb98e51867 We expect to get valid fds to close in ~Connection in ~Server 2025-09-15 00:07:09 -04:00
022a79bf5b Separate HttpRequestState and HttpConnectionState
Now HttpConnectionState has a queue of HttpRequestState
2025-09-14 23:49:32 -04:00
fac6b8de88 Add test that shows parsing issue
It's meant to show the pipelining issue. I guess we'll solve the
newly-discovered parsing issue first.
2025-09-14 22:24:02 -04:00
1f61f91bf5 Reset connection state after finishing with it in http_handler 2025-09-14 21:16:41 -04:00
632113f792 Add test for pipeline request parsing bug 2025-09-14 20:53:19 -04:00
f62770c4ab Add copying utility methods to Arena 2025-09-14 20:38:54 -04:00
147edf5c93 More cleanup 2025-09-14 20:27:14 -04:00
f39149d516 Update documentation with new networking model 2025-09-14 19:03:56 -04:00
0389fd2c9f Consistently use state->arena for http handling 2025-09-14 17:16:05 -04:00
7ef54a2d08 Call epoll_ctl in release stage 2025-09-14 16:28:12 -04:00
16c7ee0408 Separate Connection and Request lifetimes 2025-09-14 15:04:37 -04:00
cf0c1b7cc2 Add echo test for server 2025-09-14 12:56:22 -04:00
bd06798fd3 Remove test_http_handler and test_server_connection_return 2025-09-14 11:38:43 -04:00
e96a493835 Remove release_back_to_server 2025-09-14 09:03:05 -04:00
e887906da8 Remove some unused/indirectly used headers 2025-09-13 17:25:46 -04:00
de6f38694f std::unique_ptr<Connection> -> Ref<Connection> 2025-09-13 17:25:46 -04:00
1fa3381e4b Use send/sendmsg and don't ignore SIGPIPE 2025-09-13 17:25:20 -04:00
cd2e15677a Remove epoll instances config 2025-09-12 18:05:07 -04:00
2b8f095d27 Fix minor issues 2025-09-12 12:13:50 -04:00
543447971f Fix polymorphic WeakRef bug 2025-09-12 12:08:46 -04:00
f89868058a Require explicit copies for Ref/WeakRef 2025-09-12 11:59:56 -04:00
674ff581e7 Update comments/docs to match code 2025-09-12 11:40:38 -04:00
be5a0c6d8e Update some inaccuracies in markdown files 2025-09-12 11:31:22 -04:00
bf90b8856a Add mdformat pre-commit hook 2025-09-12 11:24:16 -04:00
9d48caca76 add end-of-file-fixer 2025-09-12 11:21:00 -04:00
0561d951d4 Finish std::shared_ptr -> Ref migration 2025-09-11 15:06:04 -04:00
a2da7fba84 Explicitly support having a WeakRef to self 2025-09-11 14:54:42 -04:00
5d932bf36c Add polymorphism support to Ref 2025-09-11 14:15:52 -04:00
9a8d4feedd Add documentation 2025-09-11 13:54:00 -04:00
9cd83fc426 Call ~ControlBlock
It's trivially destructible, but just in case. Compiler should optimize it out
2025-09-11 13:18:19 -04:00
10e382f633 Used biased weak count, cache T* pointer
Logically, the strong pointer that destroys T owns +1 weak count too
2025-09-11 13:15:03 -04:00
f83e21b5a0 Defeat shared_ptr's single-threaded optimizations
WeaselDB is always going to start multiple threads, so we don't care
about single-threaded performance
2025-09-11 13:13:05 -04:00
5adbf8eee2 Organize bench_reference.cpp with doctest 2025-09-11 12:32:25 -04:00
2bc17cbfe6 Add bench_reference.cpp
Also update snake case script for nanobench symbols
2025-09-11 12:22:56 -04:00
89c5a2f165 Strengthen language instructing reading the style guide 2025-09-11 12:02:44 -04:00
d35a4fa4db Update multi-threaded tests/benchmarks guidance 2025-09-11 12:01:18 -04:00
994e31032f Fix data race in freeing control block 2025-09-11 11:32:59 -04:00
0f179eed88 Switch to two separate atomic counters
It's faster and still correct. I was confused remembering something
about atomic shared pointer ideas before.
2025-09-11 10:53:25 -04:00