ref: 44f5c1c14cb1f42cc5f01739c289e9cfc83602af
parent: 984a73af9e5b5145297723f26faa38f29ca2918d
author: Daniel Compton <[email protected]>
date: Thu Feb 21 09:34:32 EST 2019
List future and expired dates in CSV format It is useful to see the date that a post will be published, or the date that it has expired, to build tooling around it. This commit writes posts and their publish/expired date as CSV. Fixes #5610
--- a/commands/list.go
+++ b/commands/list.go
@@ -14,7 +14,10 @@
package commands
import (
+ "encoding/csv"
+ "os"
"path/filepath"
+ "time"
"github.com/gohugoio/hugo/hugolib"
"github.com/spf13/cobra"
@@ -101,11 +104,16 @@
return newSystemError("Error Processing Source Content", err)
}
+ writer := csv.NewWriter(os.Stdout)
+ defer writer.Flush()
+
for _, p := range sites.Pages() {
if p.IsFuture() {
- jww.FEEDBACK.Println(filepath.Join(p.File.Dir(), p.File.LogicalName()))
+ err := writer.Write([]string{filepath.Join(p.File.Dir(), p.File.LogicalName()), p.PublishDate.Format(time.RFC3339)})
+ if err != nil {
+ return newSystemError("Error writing future posts to stdout", err)
+ }
}
-
}
return nil
@@ -137,11 +145,16 @@
return newSystemError("Error Processing Source Content", err)
}
+ writer := csv.NewWriter(os.Stdout)
+ defer writer.Flush()
+
for _, p := range sites.Pages() {
if p.IsExpired() {
- jww.FEEDBACK.Println(filepath.Join(p.File.Dir(), p.File.LogicalName()))
+ err := writer.Write([]string{filepath.Join(p.File.Dir(), p.File.LogicalName()), p.ExpiryDate.Format(time.RFC3339)})
+ if err != nil {
+ return newSystemError("Error writing expired posts to stdout", err)
+ }
}
-
}
return nil