init [skip ci]

This commit is contained in:
codecrafters-bot 2024-05-24 20:03:55 +00:00
commit b1c6c383cd
7 changed files with 99 additions and 0 deletions

1
.gitattributes vendored Normal file
View File

@ -0,0 +1 @@
* text=auto

38
README.md Normal file
View File

@ -0,0 +1,38 @@
[![progress-banner](https://backend.codecrafters.io/progress/http-server/6d10943a-e02a-40f9-9e3b-e2461bba402a)](https://app.codecrafters.io/users/codecrafters-bot?r=2qF)
This is a starting point for Go solutions to the
["Build Your Own HTTP server" Challenge](https://app.codecrafters.io/courses/http-server/overview).
[HTTP](https://en.wikipedia.org/wiki/Hypertext_Transfer_Protocol) is the
protocol that powers the web. In this challenge, you'll build a HTTP/1.1 server
that is capable of serving multiple clients.
Along the way you'll learn about TCP servers,
[HTTP request syntax](https://www.w3.org/Protocols/rfc2616/rfc2616-sec5.html),
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 HTTP server implementation is in `app/server.go`. 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 `go (1.19)` installed locally
1. Run `./your_server.sh` to run your program, which is implemented in
`app/server.go`.
1. Commit your changes and run `git push origin master` to submit your solution
to CodeCrafters. Test output will be streamed to your terminal.

27
app/server.go Normal file
View File

@ -0,0 +1,27 @@
package main
import (
"fmt"
// Uncomment this block to pass the first stage
// "net"
// "os"
)
func main() {
// You can use print statements as follows for debugging, they'll be visible when running tests.
fmt.Println("Logs from your program will appear here!")
// Uncomment this block to pass the first stage
//
// l, err := net.Listen("tcp", "0.0.0.0:4221")
// if err != nil {
// fmt.Println("Failed to bind to port 4221")
// os.Exit(1)
// }
//
// _, err = l.Accept()
// if err != nil {
// fmt.Println("Error accepting connection: ", err.Error())
// os.Exit(1)
// }
}

11
codecrafters.yml Normal file
View File

@ -0,0 +1,11 @@
# Set this to true if you want debug logs.
#
# These can be VERY verbose, so we suggest turning them off
# unless you really need them.
debug: false
# Use this to change the Go version used to run your code
# on Codecrafters.
#
# Available versions: go-1.22
language_pack: go-1.22

11
go.mod Normal file
View File

@ -0,0 +1,11 @@
// DON'T EDIT THIS!
//
// Codecrafters relies on this file being intact to run tests successfully. Any changes
// here will not reflect when CodeCrafters tests your code, and might even cause build
// failures.
//
// DON'T EDIT THIS!
module github.com/codecrafters-io/http-server-starter-go
go 1.22

0
go.sum Normal file
View File

11
your_server.sh Executable file
View File

@ -0,0 +1,11 @@
#!/bin/sh
#
# DON'T EDIT THIS!
#
# CodeCrafters uses this file to test your code. Don't make any changes here!
#
# DON'T EDIT THIS!
set -e
tmpFile=$(mktemp)
go build -o "$tmpFile" app/*.go
exec "$tmpFile" "$@"