SwiftNet is a simple and easy to use networking library built using pcap working on ip layer 2. It is designed for developers who value simplicity, readability, and good performance.
- Apple Silicon (macOS arm64)
- Linux arm64 (Disabled, because of TSAN issues)
- 💡 Ease of Use: Simple API designed to get up and running quickly, without needing to deal directly with raw sockets.
- 📂 Lightweight: No dependencies except PCAP and a small footprint.
- Straightforward API: Get up and running with minimal setup.
- Open Source and Collaborative: Contributions are welcome to make it even better.
- Compile time feature choosing Compile only specific features of the library.
- 0.4.0: Somewhat stable version (no data races, almost final API, major internal changes)
- 0.5.0: Performance improvements in critical paths, ready for some real world usage
- Switch from pcap to raw BPF
- Add performance benchmarks
- Optimize the most obvious parts of the codebase
- Stabilize the API to avoid breaking changes in future releases
Follow these steps to install SwiftNet:
vcpkg install morcules-swiftnet
- Clone the repository to your local machine:
git clone https://github.com/morcules/SwiftNet- Navigate to the build directory inside the SwiftNet directory:
cd SwiftNet/build- Compile:
./build_for_release.sh- To use SwiftNet in your project:
- Include the SwiftNet.h header from the
srcdirectory in your main source file (e.g.,main.c). - Link against the static library
libswiftnet.ausing your compiler.
- To run the library successfully, you're required to run the app with sudo.
- Pcap requires sudo
struct SwiftNetClientConnection* const client_conn = swiftnet_create_client("127.0.0.1", 8080, 1000);
if (client_conn == NULL) {
printf("Failed to create client connection\n");
return -1;
}
swiftnet_client_set_message_handler(client_conn, on_client_packet, NULL);
struct SwiftNetPacketBuffer buf = swiftnet_client_create_packet_buffer(sizeof(int));
int code = 0xFF;
swiftnet_client_append_to_packet(&code, sizeof(code), &buf);
swiftnet_client_send_packet(client_conn, &buf);
swiftnet_client_destroy_packet_buffer(&buf);
Contributions are very welcome no matter how small. Every single PR, issue, question, or typo fix is admired and appreciated.
- Check out open issues — Start with those labeled
good first issueorhelp wanted. - Found a bug or have a feature idea? Open an issue to discuss it first (especially for larger changes).
- Want to fix something yourself? Fork the repo, create a branch, and submit a pull request.
- AI - You're free to use anything you want to your advantage, but AI written slop that wasn't even ran locally won't be merged. If you don't understand the code please do not subbmit anything.
This project is licensed under the Apache License 2.0