SHA directory with concurrency

This commit is contained in:
Meutel 2017-07-08 12:05:03 +02:00
parent 5093daa9f6
commit 5df5aa394a
2 changed files with 65 additions and 0 deletions

1
.gitignore vendored
View File

@ -37,3 +37,4 @@ go-financial/go-financial
my-fnv/my-fnv
my-md5/my-md5
shadir/shadir
shadirconcurrent/shadirconcurrent

64
shadirconcurrent/main.go Normal file
View File

@ -0,0 +1,64 @@
package main
import "fmt"
import "crypto/sha256"
import "io"
import "log"
import "os"
import "path/filepath"
import "sync/atomic"
var chan_hash chan string
var running int32
func walk(path string, info os.FileInfo, err error) error {
if err != nil {
log.Fatalln(err)
return err
}
if info.IsDir() {
return nil
} else {
atomic.AddInt32(&running, 1)
go hash(info.Name(), path)
}
return nil
}
func hash(name string, path string) {
h, err := sha256File(path)
if err != nil {
log.Fatalln(err)
}
chan_hash <- fmt.Sprintf("SHA256 (%s) = %x", name, h)
}
func sha256File(path string) ([]byte, error) {
f, err := os.Open(path)
if err != nil {
log.Fatalln(err)
return nil, err
}
defer f.Close()
h := sha256.New()
io.Copy(h, f)
return h.Sum(nil), nil
}
func main() {
if len(os.Args) < 2 {
log.Fatalln("Usage shadir file")
}
chan_hash = make(chan string)
if err := filepath.Walk(os.Args[1], walk); err != nil {
panic(err)
}
for str := range chan_hash {
fmt.Println(str)
atomic.AddInt32(&running, -1)
if running <= 0 {
return
}
}
}