Revise the deprecation strategy
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 23 Nov 2016 16:26:13 +0000 (17:26 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 23 Nov 2016 16:26:13 +0000 (17:26 +0100)
Git users and theme authors two Hugo releases to fix:

1. With a visible warning
2. Then with an ERROR that exits with -1

Fixes #2726

helpers/general.go
hugolib/page.go
hugolib/page_test.go
hugolib/site.go

index 4bacf3b38b1a30a10af50834835080f86f695248..1ea08eb25ed18711afe6721044c941806967c9a5 100644 (file)
@@ -250,19 +250,32 @@ func NewDistinctFeedbackLogger() *DistinctLogger {
        return &DistinctLogger{m: make(map[string]bool), logger: &jww.FEEDBACK}
 }
 
-// DistinctErrorLog cann be used to avoid spamming the logs with errors.
-var DistinctErrorLog = NewDistinctErrorLogger()
+var (
+       // DistinctErrorLog can be used to avoid spamming the logs with errors.
+       DistinctErrorLog = NewDistinctErrorLogger()
+
+       // DistinctFeedbackLog can be used to avoid spamming the logs with info messages.
+       DistinctFeedbackLog = NewDistinctFeedbackLogger()
+)
 
 // InitLoggers sets up the global distinct loggers.
 func InitLoggers() {
        DistinctErrorLog = NewDistinctErrorLogger()
 }
 
-// Deprecated logs ERROR logs about a deprecation, but only once for a given set of arguments' values.
-func Deprecated(object, item, alternative string) {
-       //      deprecatedLogger.Printf("%s's %s is deprecated and will be removed in Hugo %s. Use %s instead.", object, item, NextHugoReleaseVersion(), alternative)
-       DistinctErrorLog.Printf("%s's %s is deprecated and will be removed in a future release. Use %s instead.", object, item, alternative)
+// Deprecated informs about a deprecation, but only once for a given set of arguments' values.
+// If the err flag is enabled, it logs as an ERROR (will exit with -1) and the text will
+// point at the next Hugo release.
+// The idea is two remove an item in two Hugo releases to give users and theme authors
+// plenty of time to fix their templates.
+func Deprecated(object, item, alternative string, err bool) {
+       if err {
+               DistinctErrorLog.Printf("%s's %s is deprecated and will be removed in Hugo %s. Use %s instead.", object, item, NextHugoReleaseVersion(), alternative)
 
+       } else {
+               // Make sure the users see this while avoiding build breakage. This will not lead to an os.Exit(-1)
+               DistinctFeedbackLog.Printf("WARNING: %s's %s is deprecated and will be removed in a future release. Use %s instead.", object, item, alternative)
+       }
 }
 
 // SliceToLower goes through the source slice and lowers all values.
index ed333deb9221d2a435a55e5056e58556d92a4afd..e94b6c9428401681d5831315412e4b90109032e3 100644 (file)
@@ -242,18 +242,18 @@ type PageMeta struct {
 }
 
 func (*PageMeta) WordCount() int {
-       helpers.Deprecated("PageMeta", "WordCount", ".WordCount (on Page)")
+       helpers.Deprecated("PageMeta", "WordCount", ".WordCount (on Page)", true)
        return 0
 }
 
 func (*PageMeta) FuzzyWordCount() int {
-       helpers.Deprecated("PageMeta", "FuzzyWordCount", ".FuzzyWordCount (on Page)")
+       helpers.Deprecated("PageMeta", "FuzzyWordCount", ".FuzzyWordCount (on Page)", true)
        return 0
 
 }
 
 func (*PageMeta) ReadingTime() int {
-       helpers.Deprecated("PageMeta", "ReadingTime", ".ReadingTime (on Page)")
+       helpers.Deprecated("PageMeta", "ReadingTime", ".ReadingTime (on Page)", true)
        return 0
 }
 
@@ -1565,7 +1565,7 @@ func (p *Page) Hugo() *HugoInfo {
 
 func (p *Page) RSSlink() template.HTML {
        // TODO(bep) we cannot have two of these
-       helpers.Deprecated(".Page", "RSSlink", "RSSLink")
+       helpers.Deprecated(".Page", "RSSlink", "RSSLink", false)
        return p.RSSLink
 }
 
index a2e75c7ecefb7910f32d5f45d3cc3398963771f8..70659f27255abacdeadb561eb5ec04092b9f7f15 100644 (file)
@@ -1270,6 +1270,7 @@ func TestIndexPageSimpleMethods(t *testing.T) {
        } {
 
                n := &Page{pageInit: &pageInit{}, Kind: KindHome}
+
                n.RSSLink = "rssLink"
 
                if !this.assertFunc(n) {
index 8c40393cc024f725988172edf8cacc146be82f39..24a7f95cd5b16e495385c591cc3835160017f085 100644 (file)
@@ -245,7 +245,7 @@ func (s *SiteInfo) Param(key interface{}) (interface{}, error) {
 
 // GetParam gets a site parameter value if found, nil if not.
 func (s *SiteInfo) GetParam(key string) interface{} {
-       helpers.Deprecated("SiteInfo", ".GetParam", ".Param")
+       helpers.Deprecated("SiteInfo", ".GetParam", ".Param", false)
        v := s.Params[strings.ToLower(key)]
 
        if v == nil {