Commit message (Collapse) | Author | Age | |
---|---|---|---|
* | fix unnecessary #include-s | Egor Tensin | 2023-05-13 |
| | |||
* | ci_queue -> run_queue | Egor Tensin | 2023-05-13 |
| | | | | Also, some minor refactoring. | ||
* | cmake: document _GNU_SOURCE usage | Egor Tensin | 2023-05-13 |
| | |||
* | use -std=c17 -Wpedantic | Egor Tensin | 2023-05-13 |
| | |||
* | command: refactoring | Egor Tensin | 2023-05-13 |
| | |||
* | best practices & coding style fixes | Egor Tensin | 2023-05-13 |
| | | | | | | | | * I don't really need to declare all variables at the top of the function anymore. * Default-initialize variables more. * Don't set the output parameter until the object is completely constructed. | ||
* | add command module to handle request-response communications | Egor Tensin | 2023-05-13 |
| | |||
* | ci_queue: fix a broken getter | Egor Tensin | 2023-05-13 |
| | | | | | | Everything was broken starting from the "making struct ci_queue_entry opaque" commit. Damn, I really wish I'd have some kind of automated testing to catch errors like this... | ||
* | ci_queue: rename a couple of functions | Egor Tensin | 2023-05-12 |
| | |||
* | cmake: don't install() valgrind.sh | Egor Tensin | 2023-05-07 |
| | | | | Turns out, I don't really need to install it for the tests. | ||
* | valgrind: quiet mode | Egor Tensin | 2023-05-07 |
| | |||
* | add tests to run binaries under Valgrind | Egor Tensin | 2023-05-07 |
| | | | | | | | | | | | This was quite a bit of refactoring in test/; everything should be more maintainable and robust in theory. Also, valgrind.sh was fixed to use exec (so that signals are passed to the underlying process); Valgrind command line options have also been tweaked. ./ci.sh fails now, but that should be fixable. | ||
* | add a cimple-valgrind executable | Egor Tensin | 2023-05-06 |
| | |||
* | add a TODO note | Egor Tensin | 2023-05-06 |
| | |||
* | shut down server/workers gracefully on SIGTERM | Egor Tensin | 2023-05-06 |
| | |||
* | get rid of __attribute__((constructor)) | Egor Tensin | 2023-05-06 |
| | | | | Explicit is better than implicit. | ||
* | add a default SQLite database path | Egor Tensin | 2023-04-29 |
| | |||
* | cmd_line: read executable name from /proc/self/exe | Egor Tensin | 2023-04-29 |
| | |||
* | dedupe command line routines | Egor Tensin | 2023-04-29 |
| | |||
* | make struct storage_settings_sqlite opaque | Egor Tensin | 2023-04-29 |
| | |||
* | make struct ci_queue_entry opaque | Egor Tensin | 2023-04-29 |
| | |||
* | net: use size instead of length for variable names | Egor Tensin | 2023-04-29 |
| | |||
* | net: add struct buf | Egor Tensin | 2023-04-29 |
| | |||
* | make struct client opaque | Egor Tensin | 2023-04-29 |
| | |||
* | make struct worker opaque | Egor Tensin | 2023-04-29 |
| | |||
* | make struct server opaque | Egor Tensin | 2023-04-29 |
| | |||
* | make struct tcp_server opaque | Egor Tensin | 2023-04-29 |
| | |||
* | fix a typo | Egor Tensin | 2023-04-27 |
| | |||
* | rename commands | Egor Tensin | 2023-04-27 |
| | |||
* | sqlite: fix error handling | Egor Tensin | 2023-04-11 |
| | |||
* | put SQL headers to a separate directory | Egor Tensin | 2023-04-11 |
| | |||
* | sqlite: create indices | Egor Tensin | 2023-04-11 |
| | |||
* | actually create some tables in SQLite database | Egor Tensin | 2023-04-11 |
| | |||
* | add copyright notices | Egor Tensin | 2022-12-02 |
| | |||
* | create SQLite database on startup | Egor Tensin | 2022-09-11 |
| | |||
* | log: refactoring | Egor Tensin | 2022-09-08 |
| | |||
* | log: prepend timestamps | Egor Tensin | 2022-09-08 |
| | |||
* | sanitize #include-s | Egor Tensin | 2022-09-08 |
| | |||
* | ci: set some environment variables | Egor Tensin | 2022-09-07 |
| | |||
* | net: removed unused API | Egor Tensin | 2022-08-30 |
| | |||
* | net: error out unless net_recv_all receives all bytes | Egor Tensin | 2022-08-30 |
| | |||
* | net: more portable | Egor Tensin | 2022-08-30 |
| | | | | Use a predefined byte order, integers with fixed width, etc. | ||
* | net: bind to IPv6 | Egor Tensin | 2022-08-30 |
| | | | | | This makes sure we use the dual-stack feature to support both IPv4 and IPv6. | ||
* | update command names | Egor Tensin | 2022-08-28 |
| | |||
* | docker: shorten command values | Egor Tensin | 2022-08-28 |
| | |||
* | server: notify workers about requeued jobs | Egor Tensin | 2022-08-28 |
| | | | | This allows free workers to pick up jobs after dead workers. | ||
* | worker: fix a crash | Egor Tensin | 2022-08-28 |
| | | | | Found when running in Docker. | ||
* | server: notify all threads about shutting down | Egor Tensin | 2022-08-28 |
| | | | | | | | The problem is pthread_cond_destroy is unsafe to call if there're threads waiting in pthread_cond_wait. I'm not sure this fix is enough: what if the "broadcast" doesn't reach the threads until we call pthread_cond_destroy? Does it even work that way? Idk | ||
* | make proper "error" messages | Egor Tensin | 2022-08-28 |
| | | | | | Previously, the client had no way to distinguish errors from succesful calls. | ||
* | fix Alpine builds | Egor Tensin | 2022-08-28 |
| |