Skip to content

Commit

Permalink
all: use bufio.NewWriter to improve writing speed
Browse files Browse the repository at this point in the history
  • Loading branch information
hajimehoshi committed Jul 29, 2024
1 parent ef5ac41 commit 0281ac7
Show file tree
Hide file tree
Showing 8 changed files with 62 additions and 14 deletions.
7 changes: 6 additions & 1 deletion ebitenutil/gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
package main

import (
"bufio"
"fmt"
"image"
"image/color"
Expand Down Expand Up @@ -77,7 +78,11 @@ func run() error {
}
defer f.Close()

if err := png.Encode(f, dst); err != nil {
w := bufio.NewWriter(f)
if err := png.Encode(w, dst); err != nil {
return err
}
if err := w.Flush(); err != nil {
return err
}

Expand Down
5 changes: 4 additions & 1 deletion examples/blocks/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
package main

import (
"bufio"
"flag"
"log"
"os"
Expand All @@ -33,9 +34,11 @@ func main() {
if err != nil {
log.Fatal(err)
}
if err := pprof.StartCPUProfile(f); err != nil {
w := bufio.NewWriter(f)
if err := pprof.StartCPUProfile(w); err != nil {
log.Fatal(err)
}
defer w.Flush()
defer pprof.StopCPUProfile()
}

Expand Down
18 changes: 15 additions & 3 deletions examples/keyboard/keyboard/gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
package main

import (
"bufio"
"bytes"
"image"
"image/png"
Expand Down Expand Up @@ -220,7 +221,11 @@ func outputKeyboardImage() (map[ebiten.Key]image.Rectangle, error) {
}
defer out.Close()

if err := png.Encode(out, img); err != nil {
w := bufio.NewWriter(out)
if err := png.Encode(w, img); err != nil {
return nil, err
}
if err := w.Flush(); err != nil {
return nil, err
}

Expand Down Expand Up @@ -278,10 +283,17 @@ func outputKeyRectsGo(k map[ebiten.Key]image.Rectangle) error {
if err != nil {
return err
}
return tmpl.Execute(f, map[string]any{
w := bufio.NewWriter(f)
if err := tmpl.Execute(w, map[string]any{
"License": license,
"KeyRectsMap": k,
})
}); err != nil {
return err
}
if err := w.Flush(); err != nil {
return err
}
return nil
}

type game struct {
Expand Down
11 changes: 10 additions & 1 deletion examples/shaderprecomp/fxc/gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
package main

import (
"bufio"
"errors"
"fmt"
"os"
Expand Down Expand Up @@ -88,7 +89,15 @@ func generateHSLSFiles(source *shaderprecomp.ShaderSource, index int, tmpdir str
}
defer psf.Close()

if err := shaderprecomp.CompileToHLSL(vsf, psf, source); err != nil {
vsfw := bufio.NewWriter(vsf)
psfw := bufio.NewWriter(psf)
if err := shaderprecomp.CompileToHLSL(vsfw, psfw, source); err != nil {
return "", "", err
}
if err := vsfw.Flush(); err != nil {
return "", "", err
}
if err := psfw.Flush(); err != nil {
return "", "", err
}

Expand Down
6 changes: 4 additions & 2 deletions examples/shaderprecomp/metallib/gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
package main

import (
"bufio"
"fmt"
"os"
"os/exec"
Expand Down Expand Up @@ -68,10 +69,11 @@ func compile(source *shaderprecomp.ShaderSource, index int, tmpdir string) error
}
defer f.Close()

if err := shaderprecomp.CompileToMSL(f, source); err != nil {
w := bufio.NewWriter(f)
if err := shaderprecomp.CompileToMSL(w, source); err != nil {
return err
}
if err := f.Sync(); err != nil {
if err := w.Flush(); err != nil {
return err
}

Expand Down
8 changes: 7 additions & 1 deletion genkeys.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
package main

import (
"bufio"
"log"
"os"
"path/filepath"
Expand Down Expand Up @@ -809,7 +810,8 @@ func main() {
buildConstraints = "//go:build !android && !ios && !js && !nintendosdk && !playstation5"
}
// NOTE: According to godoc, maps are automatically sorted by key.
if err := tmpl.Execute(f, struct {
w := bufio.NewWriter(f)
if err := tmpl.Execute(w, struct {
License string
DoNotEdit string
BuildConstraints string
Expand Down Expand Up @@ -840,5 +842,9 @@ func main() {
}); err != nil {
log.Fatal(err)
}

if err := w.Flush(); err != nil {
log.Fatal(err)
}
}
}
6 changes: 5 additions & 1 deletion internal/gamepaddb/gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,8 @@ func run() error {
}
defer f.Close()

if err := tmpl.Execute(f, struct {
w := bufio.NewWriter(f)
if err := tmpl.Execute(w, struct {
License string
DoNotEdit string
BuildConstraints string
Expand All @@ -170,6 +171,9 @@ func run() error {
}); err != nil {
return err
}
if err := w.Flush(); err != nil {
return err
}
}

return nil
Expand Down
15 changes: 11 additions & 4 deletions internal/png/gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
package main

import (
"bufio"
"fmt"
"go/ast"
"go/format"
Expand Down Expand Up @@ -93,6 +94,8 @@ func run() error {
}
defer out.Close()

w := bufio.NewWriter(out)

// TODO: Remove call of RegisterDecoder

data, err := os.ReadFile(filepath.Join(dir, f))
Expand Down Expand Up @@ -129,21 +132,25 @@ func run() error {
return true
}, nil)

fmt.Fprintln(out, "// Code generated by gen.go. DO NOT EDIT.")
fmt.Fprintln(out)
format.Node(out, fset, tree)
fmt.Fprintln(w, "// Code generated by gen.go. DO NOT EDIT.")
fmt.Fprintln(w)
format.Node(w, fset, tree)

if f == "reader.go" {
// The min function was removed as of Go 1.22, but this is needed for old Go.
// TODO: Remove this when Go 1.21 is the minimum supported version.
fmt.Fprintln(out, `
fmt.Fprintln(w, `
func min(a, b int) int {
if a < b {
return a
}
return b
}`)
}

if err := w.Flush(); err != nil {
return err
}
}
return nil
}
Expand Down

0 comments on commit 0281ac7

Please sign in to comment.