mirror of
https://github.com/fhem/fhem-mirror.git
synced 2025-03-10 03:06:37 +00:00
90_at.pm: add absolute time (Forum #43612)
git-svn-id: https://svn.fhem.de/fhem/trunk@9868 2b470e98-0d58-463d-a4d8-8e2adae1ed80
This commit is contained in:
parent
35191cc739
commit
4741328574
@ -56,15 +56,29 @@ at_Define($$)
|
||||
(undef, $command) = split("[ \t]+", $hash->{OLDDEF}, 2);
|
||||
$hash->{DEF} = "$tm $command";
|
||||
} else {
|
||||
return "Usage: define <name> at <timespec> <command>";
|
||||
return "Usage: define <name> at [timespec or datespec] <command>";
|
||||
}
|
||||
}
|
||||
|
||||
return "Wrong timespec, use \"[+][*[{count}]]<time or func>\""
|
||||
if($tm !~ m/^(\+)?(\*({\d+})?)?(.*)$/);
|
||||
my ($rel, $rep, $cnt, $tspec) = ($1, $2, $3, $4);
|
||||
my ($err, $hr, $min, $sec, $fn) = GetTimeSpec($tspec);
|
||||
|
||||
my ($abstime, $err, $hr, $min, $sec, $fn);
|
||||
if($tspec =~ m/^\d{10}$/) {
|
||||
$abstime = $tspec;
|
||||
|
||||
} elsif($tspec =~ m/^(\d{4})-(\d\d)-(\d\d)T(\d\d):(\d\d):(\d\d)$/) {
|
||||
my ($y,$m,$d,$h,$m2,$s) = ($1,$2,$3,$4,$5,$6);
|
||||
$abstime = mktime($s,$m2,$h,$d,$m-1,$y-1900);
|
||||
|
||||
} else {
|
||||
($err, $hr, $min, $sec, $fn) = GetTimeSpec($tspec);
|
||||
return $err if($err);
|
||||
|
||||
}
|
||||
return "datespec is not allowed with + or *" if($abstime && ($rel || $rep));
|
||||
|
||||
$rel = "" if(!defined($rel));
|
||||
$rep = "" if(!defined($rep));
|
||||
$cnt = "" if(!defined($cnt));
|
||||
@ -77,7 +91,10 @@ at_Define($$)
|
||||
$ot = int($ot) if(!$rel); # No way to specify subseconds
|
||||
my $nt = $ot;
|
||||
|
||||
if($rel eq "+") {
|
||||
if($abstime) {
|
||||
$nt = $abstime;
|
||||
|
||||
} elsif($rel eq "+") {
|
||||
$nt += ($hr*3600+$min*60+$sec); # Relative time
|
||||
|
||||
} else {
|
||||
@ -113,7 +130,8 @@ at_Define($$)
|
||||
InternalTimer($nt, "at_Exec", $hash, 0);
|
||||
$hash->{NTM} = $ntm if($rel eq "+" || $fn);
|
||||
my $d = IsDisabled($name); # 1
|
||||
my $val = ($d==3 ? "inactive" : ($d ? "disabled":("Next: ".FmtTime($nt))));
|
||||
my $val = ($d==3 ? "inactive" : ($d ? "disabled":("Next: ".
|
||||
($abstime ? FmtDateTime($nt) : FmtTime($nt)) )));
|
||||
readingsSingleUpdate($hash, "state", $val,
|
||||
!$hash->{READINGS}{state} || $hash->{READINGS}{state}{VAL} ne $val);
|
||||
}
|
||||
@ -378,7 +396,8 @@ EOF
|
||||
<a name="atdefine"></a>
|
||||
<b>Define</b>
|
||||
<ul>
|
||||
<code>define <name> at <timespec> <command></code><br>
|
||||
<code>define <name> at [<timespec>|<datespec>]
|
||||
<command></code><br>
|
||||
<br>
|
||||
<code><timespec></code> format: [+][*{N}]<timedet><br>
|
||||
<ul>
|
||||
@ -388,9 +407,13 @@ EOF
|
||||
executed <i>repeatedly</i>.<br>
|
||||
The optional <code>{N}</code> after the * indicates,that the command
|
||||
should be repeated <i>N-times</i> only.<br>
|
||||
<timedet> is either HH:MM, HH:MM:SS, seconds since 1970 or
|
||||
{perlfunc()}. perlfunc must return a string in timedet format.
|
||||
Note: {perlfunc()} may not contain any spaces or tabs.
|
||||
|
||||
<timespec> is either HH:MM, HH:MM:SS or {perlfunc()}. perlfunc must
|
||||
return a string in timedet format. Note: {perlfunc()} may not contain
|
||||
any spaces or tabs.<br>
|
||||
|
||||
<datespec> is either ISO8601 (YYYY-MM-DDTHH:MM:SS) or number of
|
||||
seconds since 1970.
|
||||
</ul>
|
||||
<br>
|
||||
|
||||
@ -536,7 +559,8 @@ EOF
|
||||
<a name="atdefine"></a>
|
||||
<b>Define</b>
|
||||
<ul>
|
||||
<code>define <name> at <timespec> <command></code><br>
|
||||
<code>define <name> at [<timespec>|<datespec>]
|
||||
<command></code><br>
|
||||
<br>
|
||||
<code><timespec></code> Format: [+][*{N}]<timedet><br>
|
||||
<ul>
|
||||
@ -549,9 +573,12 @@ EOF
|
||||
Das optionale <code>{N}</code> nach dem * bedeutet, dass der Befehl genau
|
||||
<i>N-mal</i> wiederholt werden soll.<br>
|
||||
|
||||
<timedet> ist entweder HH:MM, HH:MM:SS, Sekunden seit 1970 oder
|
||||
{perlfunc()}. perlfunc muss ein String in timedet Format zurueckliefern.
|
||||
Achtung: {perlfunc()} darf keine Leerzeichen enthalten.
|
||||
<timespec> ist entweder HH:MM, HH:MM:SS oder {perlfunc()}. perlfunc
|
||||
muss ein String in timedet Format zurueckliefern. Achtung: {perlfunc()}
|
||||
darf keine Leerzeichen enthalten.<br>
|
||||
|
||||
<datespec> ist entweder ISO8601 (YYYY-MM-DDTHH:MM:SS) oder Anzahl
|
||||
der Sekunden seit 1970.
|
||||
|
||||
</ul>
|
||||
<br>
|
||||
|
@ -2908,7 +2908,7 @@ EvalSpecials($%)
|
||||
}
|
||||
|
||||
#####################################
|
||||
# Parse a timespec: HH:MM:SS, HH:MM, sec-since-1970 or { perfunc() }
|
||||
# Parse a timespec: HH:MM:SS, HH:MM or { perfunc() }
|
||||
sub
|
||||
GetTimeSpec($)
|
||||
{
|
||||
@ -2921,10 +2921,6 @@ GetTimeSpec($)
|
||||
} elsif($tspec =~ m/^([0-9]+):([0-5][0-9])$/) { # HH:MM
|
||||
($hr, $min, $sec) = ($1, $2, 0);
|
||||
|
||||
} elsif($tspec =~ m/^([0-9]{10})$/) { # seconds-since-1970
|
||||
my @a = localtime($1);
|
||||
($hr, $min, $sec) = ($a[2],$a[1],$a[0]);
|
||||
|
||||
} elsif($tspec =~ m/^{(.*)}$/) { # {function}
|
||||
$fn = $1;
|
||||
$tspec = AnalyzeCommand(undef, "{$fn}");
|
||||
|
Loading…
x
Reference in New Issue
Block a user