changeset 4171:5a650cde0574

Move warning limiter to common package to flesh up the misc package. The remaining stuff in misc has dependencies to the config and cannot be removed from there easily w/o introducing cyclic imports. I have to rethink this.
author Sascha L. Teichmann <sascha.teichmann@intevation.de>
date Mon, 05 Aug 2019 16:43:31 +0200
parents afabd52212d2
children 9cbed444b8a4 d3fb2f37380b
files pkg/common/warn.go pkg/imports/agm.go pkg/imports/sr.go pkg/misc/warn.go
diffstat 4 files changed, 41 insertions(+), 36 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/pkg/common/warn.go	Mon Aug 05 16:43:31 2019 +0200
@@ -0,0 +1,39 @@
+// This is Free Software under GNU Affero General Public License v >= 3.0
+// without warranty, see README.md and license for details.
+//
+// SPDX-License-Identifier: AGPL-3.0-or-later
+// License-Filename: LICENSES/AGPL-3.0.txt
+//
+// Copyright (C) 2019 by via donau
+//   – Österreichische Wasserstraßen-Gesellschaft mbH
+// Software engineering by Intevation GmbH
+//
+// Author(s):
+//  * Sascha L. Teichmann <sascha.teichmann@intevation.de>
+
+package common
+
+// WarningLimiter limits outputs with Log to a maximal number
+// of MaxWarnings outputs.
+type WarningLimiter struct {
+	Log         func(format string, args ...interface{})
+	MaxWarnings int
+	Warnings    int
+}
+
+// Warn is a wrapper around the Log function with the
+// same signature as the Log function so it can be used
+// instead.
+func (w *WarningLimiter) Warn(format string, args ...interface{}) {
+	if w.Warnings++; w.Warnings <= w.MaxWarnings {
+		w.Log(format, args...)
+	}
+}
+
+// Close can be called to write a final message if the limit
+// was reached.
+func (w *WarningLimiter) Close() {
+	if w.Warnings > w.MaxWarnings {
+		w.Log("Too many warnings. %d ignored.", w.Warnings-w.MaxWarnings)
+	}
+}
--- a/pkg/imports/agm.go	Mon Aug 05 16:30:55 2019 +0200
+++ b/pkg/imports/agm.go	Mon Aug 05 16:43:31 2019 +0200
@@ -32,7 +32,6 @@
 	"time"
 
 	"gemma.intevation.de/gemma/pkg/common"
-	"gemma.intevation.de/gemma/pkg/misc"
 	"gemma.intevation.de/gemma/pkg/models"
 )
 
@@ -308,7 +307,7 @@
 
 	checkedGauges := map[models.Isrs]bool{}
 
-	warnLimiter := misc.WarningLimiter{Log: feedback.Warn, MaxWarnings: 100}
+	warnLimiter := common.WarningLimiter{Log: feedback.Warn, MaxWarnings: 100}
 	warn := warnLimiter.Warn
 	defer warnLimiter.Close()
 
--- a/pkg/imports/sr.go	Mon Aug 05 16:30:55 2019 +0200
+++ b/pkg/imports/sr.go	Mon Aug 05 16:43:31 2019 +0200
@@ -35,7 +35,6 @@
 	shp "github.com/jonas-p/go-shp"
 
 	"gemma.intevation.de/gemma/pkg/common"
-	"gemma.intevation.de/gemma/pkg/misc"
 	"gemma.intevation.de/gemma/pkg/models"
 	"gemma.intevation.de/gemma/pkg/octree"
 )
@@ -733,7 +732,7 @@
 	mpz := make(octree.MultiPointZ, 0, 250000)
 	s := bufio.NewScanner(r)
 
-	warnLimiter := misc.WarningLimiter{Log: feedback.Warn, MaxWarnings: 100}
+	warnLimiter := common.WarningLimiter{Log: feedback.Warn, MaxWarnings: 100}
 	warn := warnLimiter.Warn
 	defer warnLimiter.Close()
 
--- a/pkg/misc/warn.go	Mon Aug 05 16:30:55 2019 +0200
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,32 +0,0 @@
-// This is Free Software under GNU Affero General Public License v >= 3.0
-// without warranty, see README.md and license for details.
-//
-// SPDX-License-Identifier: AGPL-3.0-or-later
-// License-Filename: LICENSES/AGPL-3.0.txt
-//
-// Copyright (C) 2019 by via donau
-//   – Österreichische Wasserstraßen-Gesellschaft mbH
-// Software engineering by Intevation GmbH
-//
-// Author(s):
-//  * Sascha L. Teichmann <sascha.teichmann@intevation.de>
-
-package misc
-
-type WarningLimiter struct {
-	Log         func(format string, args ...interface{})
-	MaxWarnings int
-	Warnings    int
-}
-
-func (w *WarningLimiter) Warn(format string, args ...interface{}) {
-	if w.Warnings++; w.Warnings <= w.MaxWarnings {
-		w.Log(format, args...)
-	}
-}
-
-func (w *WarningLimiter) Close() {
-	if w.Warnings > w.MaxWarnings {
-		w.Log("Too many warnings. %d ignored.", w.Warnings-w.MaxWarnings)
-	}
-}