mirror of
https://github.com/fhem/fhem-mirror.git
synced 2025-04-16 04:36:02 +00:00
Moved SecondsTillTomorrow from fhem.pl to 90_at.pm
git-svn-id: https://svn.fhem.de/fhem/trunk@3364 2b470e98-0d58-463d-a4d8-8e2adae1ed80
This commit is contained in:
parent
57d765b0f8
commit
7e0b06c4fe
@ -22,6 +22,28 @@ at_Initialize($)
|
||||
|
||||
|
||||
my $oldattr;
|
||||
my $at_stt_sec;
|
||||
my $at_stt_day;
|
||||
|
||||
sub
|
||||
at_SecondsTillTomorrow($) # 86400, if tomorrow is no DST change
|
||||
{
|
||||
my $t = shift;
|
||||
my $day = int($t/86400);
|
||||
|
||||
if(!$at_stt_day || $day != $at_stt_day) {
|
||||
my $t = $day*86400+12*3600;
|
||||
my @l1 = localtime($t);
|
||||
my @l2 = localtime($t+86400);
|
||||
$at_stt_sec = 86400+
|
||||
($l1[2]-$l2[2])*3600+
|
||||
($l1[1]-$l2[1])*60;
|
||||
$at_stt_day = $day;
|
||||
}
|
||||
|
||||
return $at_stt_sec;
|
||||
}
|
||||
|
||||
|
||||
#####################################
|
||||
sub
|
||||
@ -57,7 +79,7 @@ at_Define($$)
|
||||
$nt -= ($lt[2]*3600+$lt[1]*60+$lt[0]) # Midnight for absolute time
|
||||
if($rel ne "+");
|
||||
$nt += ($hr*3600+$min*60+$sec); # Plus relative time
|
||||
$nt += SecondsTillTomorrow($ot) if($ot >= $nt); # Do it tomorrow...
|
||||
$nt += at_SecondsTillTomorrow($ot) if($ot >= $nt); # Do it tomorrow...
|
||||
@lt = localtime($nt);
|
||||
my $ntm = sprintf("%02d:%02d:%02d", $lt[2], $lt[1], $lt[0]);
|
||||
if($rep) { # Setting the number of repetitions
|
||||
@ -110,7 +132,7 @@ at_Exec($)
|
||||
my (undef, $command) = split("[ \t]+", $hash->{DEF}, 2);
|
||||
$command = SemicolonEscape($command);
|
||||
my $ret = AnalyzeCommandChain(undef, $command) if(!$skip && !$disable);
|
||||
Log GetLogLevel($name,3), $ret if($ret);
|
||||
Log GetLogLevel($name,3), "$name: $ret" if($ret);
|
||||
|
||||
return if($hash->{DELETED}); # Deleted in the Command
|
||||
|
||||
|
21
fhem/fhem.pl
21
fhem/fhem.pl
@ -193,8 +193,6 @@ my $namedef =
|
||||
"- a list separated by komma (,)\n" .
|
||||
"- a regexp, if it contains one of the following characters: *[]^\$\n" .
|
||||
"- a range separated by dash (-)\n";
|
||||
my $stt_sec; # Used by SecondsTillTomorrow()
|
||||
my $stt_day; # Used by SecondsTillTomorrow()
|
||||
my @cmdList; # Remaining commands in a chain. Used by sleep
|
||||
my $evalSpecials; # Used by EvalSpecials->AnalyzeCommand parameter passing
|
||||
|
||||
@ -2714,25 +2712,6 @@ AddDuplicate($$)
|
||||
$duplidx++;
|
||||
}
|
||||
|
||||
sub
|
||||
SecondsTillTomorrow($) # 86400, if tomorrow is no DST change
|
||||
{
|
||||
my $t = shift;
|
||||
my $day = int($t/86400);
|
||||
|
||||
if(!$stt_day || $day != $stt_day) {
|
||||
my $t = $day*86400+12*3600;
|
||||
my @l1 = localtime($t);
|
||||
my @l2 = localtime($t+86400);
|
||||
$stt_sec = 86400+
|
||||
($l1[2]-$l2[2])*3600+
|
||||
($l1[1]-$l2[1])*60;
|
||||
$stt_day = $day;
|
||||
}
|
||||
|
||||
return $stt_sec;
|
||||
}
|
||||
|
||||
# Add an attribute to the userattr list, if not yet present
|
||||
sub
|
||||
addToAttrList($)
|
||||
|
Loading…
x
Reference in New Issue
Block a user