Commit Graph

355 Commits

Author SHA1 Message Date
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
b9106a0d3c Add test_reference.cpp 2025-09-10 22:05:31 -04:00
6aaca4c171 Finish reference.hpp 2025-09-10 21:58:08 -04:00
7c4d928807 Start on Ref/WeakRef 2025-09-10 20:04:32 -04:00
5d289ddd42 Add metric for write EAGAIN failures 2025-09-10 16:48:27 -04:00
962a010724 Simplify process_connection_writes condition
And comment explaining that we there's something more precise but more
complex available.
2025-09-10 16:45:04 -04:00
f56ed2bfbe Rename ArenaAllocator -> Arena 2025-09-05 17:57:04 -04:00
46fe51c0bb Make config.toml comments more descriptive and accessible 2025-09-05 16:36:50 -04:00
b93cc2072a Remove -Wno-vla-cxx-extension from .clangd 2025-09-05 16:29:12 -04:00
0357a41dd8 Implement spend_cpu_cycles in assembly
The compiler was unrolling it previously, so we're doing assembly now for consistency.
2025-09-05 15:16:49 -04:00
ffe7ab0a3e Update default in config.toml 2025-09-05 13:06:10 -04:00
ed3cf25936 Update stale documentation 2025-09-05 13:04:34 -04:00