diff options
-rw-r--r-- | pkg/datamaps/writer.go | 42 | ||||
-rw-r--r-- | pkg/datamaps/writer_test.go | 7 |
2 files changed, 31 insertions, 18 deletions
diff --git a/pkg/datamaps/writer.go b/pkg/datamaps/writer.go index d1da39f..f0da506 100644 --- a/pkg/datamaps/writer.go +++ b/pkg/datamaps/writer.go @@ -74,34 +74,48 @@ func ExportMaster(opts *Options) error { INNER JOIN datamap_line ON return_data.dml_id=datamap_line.id) INNER JOIN datamap ON datamap_line.dm_id=datamap.id) INNER JOIN return on return_data.ret_id=return.id) - WHERE datamap.name=? AND return.name=? AND datamap_line.key=?;` + WHERE datamap.name=? AND return.name=? AND datamap_line.key=? + ORDER BY return_data.filename;` + + seen := make(map[string]struct{}) // homemade set https://emersion.fr/blog/2017/sets-in-go/ var values = make(map[string][]string) + headerSlice := make([]string, 0) for _, k := range datamapKeys { masterData, err := db.Query(getDataSQL, opts.DMName, opts.ReturnName, k) if err != nil { return err } - var x int64 - for x = 0; x < rowCount; x++ { + for masterData.Next() { var key, filename, value string - if b := masterData.Next(); b { - if err := masterData.Scan(&key, &value, &filename); err != nil { - return err - } - values, err = appendValueMap(key, value, values) - if err != nil { - return err - } + if err := masterData.Scan(&key, &value, &filename); err != nil { + return err + } + values, err = appendValueMap(key, value, values) + if _, ok := seen[filename]; !ok { + headerSlice = append(headerSlice, filename) + seen[filename] = struct{}{} + } + if err != nil { + return err } } } - var masterRow int64 - for masterRow = 1; masterRow <= datamapKeysNumber; masterRow++ { + hdrRow, err := sh.Row(0) + if err != nil { + return fmt.Errorf("cannot create header row in output spreadsheet: %v", err) + } + + log.Printf("Writing slice of %#v to top row\n", headerSlice) + if hdr := hdrRow.WriteSlice(headerSlice, -1); hdr == -1 { + return fmt.Errorf("cannot write header values into header row: %v", err) + } + + for masterRow := 1; masterRow <= int(datamapKeysNumber); masterRow++ { r, err := sh.Row(int(masterRow)) if err != nil { - log.Fatal(err) + return fmt.Errorf("cannot create row %d in output spreadsheet: %v", masterRow, err) } dmlKey := datamapKeys[masterRow-1] if sl := r.WriteSlice(append([]string{dmlKey}, values[dmlKey]...), -1); sl == -1 { diff --git a/pkg/datamaps/writer_test.go b/pkg/datamaps/writer_test.go index 319544c..c4807c8 100644 --- a/pkg/datamaps/writer_test.go +++ b/pkg/datamaps/writer_test.go @@ -2,7 +2,6 @@ package datamaps import ( "os" - "path/filepath" "testing" ) @@ -28,9 +27,9 @@ func TestWriteMaster(t *testing.T) { XLSXPath: "./testdata/", } - defer func() { - os.Remove(filepath.Join(opts.MasterOutPutPath, "master.xlsx")) - }() + // defer func() { + // os.Remove(filepath.Join(opts.MasterOutPutPath, "master.xlsx")) + // }() if err := DatamapToDB(&opts); err != nil { t.Fatalf("Unable to write datamap to database file because %v.", err) |