]> Cypherpunks.ru repositories - goredo.git/blobdiff - dot.go
Binary format and many optimisations
[goredo.git] / dot.go
diff --git a/dot.go b/dot.go
index 0ea2b4ae13fcffb9bd1fc858a329eadb216b8070..a77ec69197fda3e1b2c07daf950de2a542f73d8c 100644 (file)
--- a/dot.go
+++ b/dot.go
@@ -20,13 +20,9 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 package main
 
 import (
-       "errors"
        "fmt"
-       "io"
        "os"
        "path"
-
-       "go.cypherpunks.ru/recfile"
 )
 
 type DotNodes struct {
@@ -35,26 +31,34 @@ type DotNodes struct {
 }
 
 func dotWalker(data map[DotNodes]bool, tgt *Tgt) (map[DotNodes]bool, error) {
-       fdDep, err := os.Open(tgt.Dep())
+       raw, err := os.ReadFile(tgt.dep)
+       if err != nil {
+               return nil, ErrLine(err)
+       }
+       _, raw, err = depHeadParse(raw)
        if err != nil {
                return nil, ErrLine(err)
        }
-       defer fdDep.Close()
+       var typ byte
+       var name string
        var dep *Tgt
-       r := recfile.NewReader(fdDep)
-       for {
-               m, err := r.NextMap()
+       var chunk []byte
+       tgtH, _ := pathSplit(tgt.a)
+       for len(raw) > 0 {
+               typ, chunk, raw, err = chunkRead(raw)
                if err != nil {
-                       if errors.Is(err, io.EOF) {
-                               break
-                       }
                        return nil, ErrLine(err)
                }
-               switch m["Type"] {
+               switch typ {
                case DepTypeIfcreate:
-                       data[DotNodes{tgt.rel, NewTgt(string(chunk)).rel}] = true
-               case DepTypeIfchange:
-                       dep = NewTgt(path.Join(tgt.h, m["Target"]))
+                       data[DotNodes{tgt.rel, NewTgt(path.Join(tgtH, string(chunk))).rel}] = true
+               case DepTypeIfchange, DepTypeIfchangeDummy:
+                       if typ == DepTypeIfchangeDummy {
+                               name = string(chunk)
+                       } else {
+                               name = string(chunk[InodeLen+HashLen:])
+                       }
+                       dep = NewTgt(path.Join(tgtH, name))
                        if dep.a == tgt.a {
                                continue
                        }