[patch] fhem.pl - Konstanten für das Rechnen mit Zeiten

Begonnen von betateilchen, 05 Februar 2019, 08:55:04

Vorheriges Thema - Nächstes Thema

betateilchen

Hallo Rudi,

da man beim Rechnen mit Zeiten bestimmte Multiplikatoren immer wieder benötigt, wäre es schön, wenn diese in FHEM als Konstanten zur Verfügung stünden. In Programmcode finde ich das Arbeiten mit Zahlenwerten immer unübersichtlich (von Speichereffizienz ganz abgesehen)

Deshalb schlage ich folgenden Patch vor.


Index: fhem.pl
===================================================================
--- fhem.pl     (revision 18475)
+++ fhem.pl     (working copy)
@@ -270,6 +270,11 @@
use vars qw(@intAtA);           # Internal timer array
use vars qw(@structChangeHist); # Contains the last 10 structural changes

+use constant {
+  DAYSECONDS  => 86400,
+  HOURSECONDS =>  3600,
+  MINSECONDS  =>    60
+};

$selectTimestamp = gettimeofday();
$cvsid = '$Id$';
-----------------------
Formuliere die Aufgabe möglichst einfach und
setze die Lösung richtig um - dann wird es auch funktionieren.
-----------------------
Lesen gefährdet die Unwissenheit!

CoolTux

Du musst nicht wissen wie es geht! Du musst nur wissen wo es steht, wie es geht.
Support me to buy new test hardware for development: https://www.paypal.com/paypalme/MOldenburg
My FHEM Git: https://git.cooltux.net/FHEM/
Das TuxNet Wiki:
https://www.cooltux.net

justme1968

ich würde MINUTESECONDS statt MINSECONDS vorschlagen.

ist zwar etwas länger aber nicht mit minimum verwechselbar und die anderen beiden sind ja auch ausgeschrieben.
falls das zu lang ist lieber SECONDS bei allen dreien zu SEC verkürzen.
hue, tradfri, alexa-fhem, homebridge-fhem, LightScene, readingsGroup, ...

https://github.com/sponsors/justme-1968

betateilchen

Zitat von: justme1968 am 05 Februar 2019, 09:54:42
ich würde MINUTESECONDS statt MINSECONDS vorschlagen.

nix dagegen, die Länge des Namens ist mir ziemlich egal, solange sie unter 255 Zeichen bleibt  8)
-----------------------
Formuliere die Aufgabe möglichst einfach und
setze die Lösung richtig um - dann wird es auch funktionieren.
-----------------------
Lesen gefährdet die Unwissenheit!

justme1968

hue, tradfri, alexa-fhem, homebridge-fhem, LightScene, readingsGroup, ...

https://github.com/sponsors/justme-1968

Christoph Morrison

Darf ich anmerken, dass Tage nicht immer exakt 86400 Sekunden lang sind?
Wenn man damit leben kann, bietet Time::Seconds (Kernmodul) auch bereits entsprechende Konstanten.

rudolfkoenig

Habs eingecheckt.

ZitatDarf ich anmerken, dass Tage nicht immer exakt 86400 Sekunden lang sind?
Aus Sicht von FHEM ist das aber egal, die Bibliotheken ignorieren die Schaltsekunde, wenn es um das Konvertieren der Zeit seit 1970 geht.

betateilchen

-----------------------
Formuliere die Aufgabe möglichst einfach und
setze die Lösung richtig um - dann wird es auch funktionieren.
-----------------------
Lesen gefährdet die Unwissenheit!