Adapt to firecgi API change, add asan target, new Makefile ar merge method
This commit is contained in:
16
Makefile
16
Makefile
@@ -6,13 +6,15 @@ all: firesse.a example_clock
|
||||
|
||||
objects = firesse.o stream.o
|
||||
|
||||
firesse.a: $(objects)
|
||||
_firecgi:
|
||||
$(MAKE) --directory=firecgi
|
||||
ar rcs $@ $^
|
||||
|
||||
example_clock: example_clock.o $(objects)
|
||||
$(MAKE) --directory=firecgi
|
||||
$(FIRE_CXX) $(FIRE_CXXFLAGS) -o $@ $+ firecgi/firecgi.a firecgi/firebuf/firebuf.a $(FIRE_LDLIBS)
|
||||
firesse.a: $(objects) _firecgi
|
||||
ar x firecgi/firecgi.a
|
||||
ar rcs $@ $(objects) $(shell ar t firecgi/firecgi.a)
|
||||
|
||||
example_clock: example_clock.o firesse.a
|
||||
$(FIRE_CXX) $(FIRE_CXXFLAGS) -o $@ $+ $(FIRE_LDLIBS)
|
||||
|
||||
%.o: %.cc *.h Makefile
|
||||
$(FIRE_CXX) $(FIRE_CXXFLAGS) -c -o $@ $<
|
||||
@@ -20,3 +22,7 @@ example_clock: example_clock.o $(objects)
|
||||
clean:
|
||||
$(MAKE) --directory=firecgi clean
|
||||
rm --force example_clock *.o *.a
|
||||
|
||||
asan:
|
||||
$(MAKE) clean
|
||||
FIRE_CXXFLAGS="-O1 -g -fsanitize=address -fno-omit-frame-pointer -std=gnu++2a -Wall -Werror" $(MAKE) all
|
||||
|
||||
2
firecgi
2
firecgi
Submodule firecgi updated: c571e47bae...90ce269869
@@ -5,7 +5,7 @@ namespace firesse {
|
||||
Server::Server(int port, const std::function<void(std::unique_ptr<Stream>)>& callback)
|
||||
: callback_(callback),
|
||||
firecgi_server_(port,
|
||||
[this](std::unique_ptr<firecgi::Request> request) { OnRequest(std::move(request)); },
|
||||
[this](firecgi::Request* request) { OnRequest(request); },
|
||||
1,
|
||||
{"HTTP_ACCEPT"}) {}
|
||||
|
||||
@@ -13,7 +13,7 @@ void Server::Serve() {
|
||||
firecgi_server_.Serve();
|
||||
}
|
||||
|
||||
void Server::OnRequest(std::unique_ptr<firecgi::Request> request) {
|
||||
void Server::OnRequest(firecgi::Request* request) {
|
||||
if (request->GetParam("HTTP_ACCEPT") != "text/event-stream") {
|
||||
LOG(WARNING) << "bad HTTP_ACCEPT: " << request->GetParam("HTTP_ACCEPT");
|
||||
request->WriteHeader("Status", "400 Bad Request");
|
||||
@@ -24,7 +24,7 @@ void Server::OnRequest(std::unique_ptr<firecgi::Request> request) {
|
||||
}
|
||||
request->WriteHeader("Content-Type", "text/event-stream");
|
||||
request->WriteBody("");
|
||||
callback_(std::make_unique<Stream>(std::move(request)));
|
||||
callback_(std::make_unique<Stream>(request));
|
||||
}
|
||||
|
||||
} // namespace firesse
|
||||
|
||||
@@ -11,7 +11,7 @@ class Server {
|
||||
void Serve();
|
||||
|
||||
private:
|
||||
void OnRequest(std::unique_ptr<firecgi::Request> request);
|
||||
void OnRequest(firecgi::Request* request);
|
||||
|
||||
std::function<void(std::unique_ptr<Stream>)> callback_;
|
||||
firecgi::Server firecgi_server_;
|
||||
|
||||
@@ -2,8 +2,8 @@
|
||||
|
||||
namespace firesse {
|
||||
|
||||
Stream::Stream(std::unique_ptr<firecgi::Request> request)
|
||||
: request_(std::move(request)) {}
|
||||
Stream::Stream(firecgi::Request* request)
|
||||
: request_(request) {}
|
||||
|
||||
bool Stream::WriteEvent(const std::string& data, uint64_t id, const std::string& type) {
|
||||
if (id) {
|
||||
|
||||
4
stream.h
4
stream.h
@@ -8,13 +8,13 @@ namespace firesse {
|
||||
|
||||
class Stream {
|
||||
public:
|
||||
Stream(std::unique_ptr<firecgi::Request> request);
|
||||
Stream(firecgi::Request* request);
|
||||
|
||||
[[nodiscard]] bool WriteEvent(const std::string& data, uint64_t id=0, const std::string& type="");
|
||||
bool End();
|
||||
|
||||
private:
|
||||
std::unique_ptr<firecgi::Request> request_;
|
||||
firecgi::Request* request_;
|
||||
};
|
||||
|
||||
} // namespace firesse
|
||||
|
||||
Reference in New Issue
Block a user