Compare commits

...

3 Commits

Author SHA1 Message Date
c3fa7d0ff8 upd scaffold and makefile 2024-12-02 02:06:35 +00:00
84312b157c add benchmarks for one and two 2024-12-02 02:06:26 +00:00
d05828154e move flag parsing into /cmd/cli/main.go
solves issue redefined flag when running benchmarks
2024-12-02 02:04:35 +00:00
10 changed files with 84 additions and 20 deletions

1
.gitignore vendored
View File

@ -7,6 +7,7 @@
*.dll
*.so
*.dylib
bin/
# Test binary, built with `go test -c`
*.test

View File

@ -10,8 +10,7 @@ import (
"fmt"
"log"
"github.com/onyx-and-iris/aoc2024/day-01/internal/one"
"github.com/onyx-and-iris/aoc2024/day-01/internal/two"
problems "github.com/onyx-and-iris/aoc2024/day-01"
)
//go:embed testdata
@ -26,15 +25,5 @@ func main() {
log.Fatal(err)
}
val, err := one.Solve(data)
if err != nil {
log.Fatal(err)
}
fmt.Printf("solution one: %d\n", val)
val, err = two.Solve(data)
if err != nil {
log.Fatal(err)
}
fmt.Printf("solution two: %d\n", val)
problems.Solve(data)
}

View File

@ -0,0 +1,6 @@
goos: linux
goarch: amd64
pkg: github.com/onyx-and-iris/aoc2024/day-01/internal/one
cpu: Intel(R) Core(TM) i7-8700K CPU @ 3.70GHz
BenchmarkMain-12 1000000000 0.0006628 ns/op
ok github.com/onyx-and-iris/aoc2024/day-01/internal/one 0.009s

View File

@ -1,11 +1,15 @@
package main
package one
import (
_ "embed"
"os"
"testing"
)
//go:embed testdata/input.txt
var data []byte
func BenchmarkMain(b *testing.B) {
os.Stdout, _ = os.Open(os.DevNull)
main()
Solve(data)
}

View File

@ -0,0 +1,6 @@
goos: linux
goarch: amd64
pkg: github.com/onyx-and-iris/aoc2024/day-01/internal/two
cpu: Intel(R) Core(TM) i7-8700K CPU @ 3.70GHz
BenchmarkMain-12 1000000000 0.001179 ns/op
ok github.com/onyx-and-iris/aoc2024/day-01/internal/two 0.011s

View File

@ -0,0 +1,15 @@
package two
import (
_ "embed"
"os"
"testing"
)
//go:embed testdata/input.txt
var data []byte
func BenchmarkMain(b *testing.B) {
os.Stdout, _ = os.Open(os.DevNull)
Solve(data)
}

View File

@ -16,10 +16,12 @@ vet: fmt
$(GO) vet ./...
build: vet | $(BIN_DIR)
$(GO) build -o $(EXE) .
$(GO) build -o $(EXE) ./cmd/cli/
bench:
$(GO) test . -test.count=10 -bench=. > benchmark
$(GO) test ./internal/one/ -bench=. > internal/one/benchmark
$(GO) test ./internal/two/ -bench=. > internal/two/benchmark
$(GO) test . -count=10 -bench=. > benchmark
$(BIN_DIR):
@mkdir -p $@

23
day-01/solve.go Normal file
View File

@ -0,0 +1,23 @@
package day01
import (
"fmt"
"log"
"github.com/onyx-and-iris/aoc2024/day-01/internal/one"
"github.com/onyx-and-iris/aoc2024/day-01/internal/two"
)
func Solve(data []byte) {
val, err := one.Solve(data)
if err != nil {
log.Fatal(err)
}
fmt.Printf("solution one: %d\n", val)
val, err = two.Solve(data)
if err != nil {
log.Fatal(err)
}
fmt.Printf("solution two: %d\n", val)
}

View File

@ -0,0 +1,15 @@
package day01
import (
_ "embed"
"os"
"testing"
)
//go:embed testdata/input.txt
var data []byte
func BenchmarkMain(b *testing.B) {
os.Stdout, _ = os.Open(os.DevNull)
Solve(data)
}

View File

@ -7,7 +7,8 @@ if [ -d day-"$name" ]; then
exit 1
fi
mkdir -p "$name"/testdata
mkdir -p "$name"/cmd/cli/testdata \
"$name"/testdata "$name"/internal/one/testdata "$name"/internal/two/testdata
touch "$name"/makefile
cat <<EOT >> "$name"/makefile
@ -32,7 +33,9 @@ build: vet | \$(BIN_DIR)
\$(GO) build -o \$(EXE) ./\$(SRC_DIR)
bench:
\$(GO) test . -test.count=10 -bench=. > benchmark
\$(GO) test ./internal/one/ -bench=. > internal/one/benchmark
\$(GO) test ./internal/two/ -bench=. > internal/two/benchmark
\$(GO) test . -count=10 -bench=. > benchmark
\$(BIN_DIR):
@mkdir -p \$@
@ -41,7 +44,7 @@ clean:
@rm -rv \$(BIN_DIR)
EOT
cat <<EOT >> "$name"/solution.go
cat <<EOT >> "$name"/cmd/cli/main.go
/********************************************************************************
Advent of Code 2024 - $name
********************************************************************************/