|
|
6f421629aa
|
Add comments to avoid blocking in sequence and resolve stages
|
2025-09-15 22:51:41 -04:00 |
|
|
|
ba59a992dd
|
Document per-connection locking strategy
|
2025-09-15 22:33:52 -04:00 |
|
|
|
0d76c73077
|
Only shut down write side for http
|
2025-09-15 21:42:36 -04:00 |
|
|
|
5e625197aa
|
Fix url accumulation bug
|
2025-09-15 21:36:49 -04:00 |
|
|
|
345d8e21b2
|
Use WaitIfUpstreamIdle
|
2025-09-15 20:48:12 -04:00 |
|
|
|
917066d8c0
|
Move thread local state into stack
|
2025-09-15 20:33:45 -04:00 |
|
|
|
5a88047b9f
|
Two release threads
|
2025-09-15 20:09:15 -04:00 |
|
|
|
1acdc1e753
|
Put Arena destructor and move constructors in header
|
2025-09-15 17:01:38 -04:00 |
|
|
|
ae0c014298
|
Don't clear write interest if pending_response_queue_ non empty
|
2025-09-15 16:35:37 -04:00 |
|
|
|
55f6ebc02b
|
Implement shutting down the write-side only
|
2025-09-15 15:39:28 -04:00 |
|
|
|
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 |
|
|
|
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 |
|
|
|
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 |
|
|
|
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 |
|
|
|
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 |
|
|
|
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 |
|
|
|
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 |
|
|
|
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 |
|