Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/abhaysp95/codecrafters_bittorrent

Excersise done for codecrafters bittorrent primarily focuses on bencoding built on zig
https://github.com/abhaysp95/codecrafters_bittorrent

bencode bencode-parser bittorrent codecrafters codecrafters-bittorrent zig ziglang

Last synced: 3 months ago
JSON representation

Excersise done for codecrafters bittorrent primarily focuses on bencoding built on zig

Awesome Lists containing this project

README

        

[![progress-banner](https://backend.codecrafters.io/progress/bittorrent/63a4d6ec-5514-4322-9f54-dca9c23c3aae)](https://app.codecrafters.io/users/codecrafters-bot?r=2qF)

This is a starting point for Zig solutions to the
["Build Your Own BitTorrent" Challenge](https://app.codecrafters.io/courses/bittorrent/overview).

In this challenge, you’ll build a BitTorrent client that's capable of parsing a
.torrent file and downloading a file from a peer. Along the way, we’ll learn
about how torrent files are structured, HTTP trackers, BitTorrent’s Peer
Protocol, pipelining and more.

**Note**: If you're viewing this repo on GitHub, head over to
[codecrafters.io](https://codecrafters.io) to try the challenge.

# Passing the first stage

The entry point for your BitTorrent implementation is in `app/main.zig`. Study
and uncomment the relevant code, and push your changes to pass the first stage:

```sh
git add .
git commit -m "pass 1st stage" # any msg
git push origin master
```

Time to move on to the next stage!

# Stage 2 & beyond

Note: This section is for stages 2 and beyond.

1. Ensure you have `zig (0.11)` installed locally
1. Run `./your_bittorrent.sh` to run your program, which is implemented in
`app/main.zig`.
1. Commit your changes and run `git push origin master` to submit your solution
to CodeCrafters. Test output will be streamed to your terminal.