Klammerebenen: Unterschied zwischen den Versionen
Keine Bearbeitungszusammenfassung |
Krikan (Diskussion | Beiträge) K (Link repariert) |
||
(5 dazwischenliegende Versionen von 3 Benutzern werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
Nachdem das Thema im Forum zum xten mal aufkam, hier ein schneller Stub zum Thema Klammern und Mischen von Perl und | Nachdem das Thema im Forum zum xten mal aufkam, hier ein schneller Stub zum Thema Klammern und Mischen von Perl und FHEM Kommandos. | ||
FHEM kennt einiges an Befehlen um Aktoren zu Schalten und auf Dinge zu reagieren. Es konnte aber anfänglich insbesondere keine komplexeren Operationen wie "if...else". Wollte man diese nutzen, muss man FHEM mit Perl-Einzeilern versehen. | |||
Die Perl Ebene wird mittels geschweifter Klammern aufgerufen: { } | Die Perl Ebene wird mittels geschweifter Klammern aufgerufen: { } | ||
INNERHALB von | INNERHALB von Perl-Ausdrücken will man aber oft doch FHEM Kommandos ausführen. Dazu muss man Perl mitteilen, dass diese Kommandos an FHEM übergeben werden sollen. Dies macht man durch den Ausdruck: | ||
{ fhem(" ")} | {fhem(" ")} | ||
FHEM Befehle innerhalb von Perl-Ausdrücken müssen "Escaped" werden (verdoppelt). Mehr dazu hier: [[Escapen in Perlbefehlen]]. | |||
Ein kompletter Ausdruck mit Perl und | Ein kompletter Ausdruck mit Perl und FHEM gemischt hat daher diese Form: | ||
define Name notify Ereignis {''ab hier Perl-Code'' { fhem(" ''hier | define ''Name'' notify ''Ereignis'' {''''ab hier Perl-Code'''' { fhem(" ''hier FHEM Kommandos, escapen nicht vergessen'' ")} } | ||
Konkretes Beispiel: Es soll ein Garagentor geöffnet werden, aber nur wenn es vorher auch wirklich zu war. Dazu wird mittels des Perl Befehls "if" geprüft ob das Tor zu ist. Wenn ja (Value("Einfahrt") eq "Closed"), dann wird der Toraktor eingeschaltet, | Konkretes Beispiel: Es soll ein Garagentor geöffnet werden, aber nur wenn es vorher auch wirklich zu war. Dazu wird mittels des Perl Befehls "if" geprüft ob das Tor zu ist. Wenn ja (Value("Einfahrt") eq "Closed"), dann wird der Toraktor eingeschaltet, außerdem einen Kontrollleuchte. | ||
define act_on_Einfahrt_AUF notify Einfahrt_AUF { if (Value("Einfahrt") eq "Closed") { fhem("set Tor_Aktor on ;; set Kontrollampe on")} } | define act_on_Einfahrt_AUF notify Einfahrt_AUF { if (Value("Einfahrt") eq "Closed") { fhem("set Tor_Aktor on ;; set Kontrollampe on")} } | ||
Sinnlos sind mitunter anzutreffende Konstruktionen wie etwa: | |||
define act_on_Einfahrt_AUF notify Einfahrt_AUF { fhem("set Tor_Aktor on ;; set Kontrollampe on")} } | |||
Da Perl hier nur dazu verwendet wird ohne weitere Bedingung Kommandos an FHEM weiterzureichen, ist dies nur eine besonders komplizierte Schreibweise von | |||
define act_on_Einfahrt_AUF notify Einfahrt_AUF set Tor_Aktor on ; set Kontrollampe on | |||
Inzwischen ist FHEM um den relativ mächtigen Befehl DOIF erweitert, der die meisten Fälle von bedingten Aktionen ohne Perl abbildbar macht. Es gibt aber dennoch Fälle, wo Perl die einzige Möglichkeit bleibt bestimmte Aktionen durchzuführen. | |||
[[Kategorie:HOWTOS]] | [[Kategorie:HOWTOS]] |
Aktuelle Version vom 3. Mai 2019, 15:42 Uhr
Nachdem das Thema im Forum zum xten mal aufkam, hier ein schneller Stub zum Thema Klammern und Mischen von Perl und FHEM Kommandos.
FHEM kennt einiges an Befehlen um Aktoren zu Schalten und auf Dinge zu reagieren. Es konnte aber anfänglich insbesondere keine komplexeren Operationen wie "if...else". Wollte man diese nutzen, muss man FHEM mit Perl-Einzeilern versehen.
Die Perl Ebene wird mittels geschweifter Klammern aufgerufen: { }
INNERHALB von Perl-Ausdrücken will man aber oft doch FHEM Kommandos ausführen. Dazu muss man Perl mitteilen, dass diese Kommandos an FHEM übergeben werden sollen. Dies macht man durch den Ausdruck:
{fhem(" ")}
FHEM Befehle innerhalb von Perl-Ausdrücken müssen "Escaped" werden (verdoppelt). Mehr dazu hier: Escapen in Perlbefehlen.
Ein kompletter Ausdruck mit Perl und FHEM gemischt hat daher diese Form:
define Name notify Ereignis {'ab hier Perl-Code' { fhem(" hier FHEM Kommandos, escapen nicht vergessen ")} }
Konkretes Beispiel: Es soll ein Garagentor geöffnet werden, aber nur wenn es vorher auch wirklich zu war. Dazu wird mittels des Perl Befehls "if" geprüft ob das Tor zu ist. Wenn ja (Value("Einfahrt") eq "Closed"), dann wird der Toraktor eingeschaltet, außerdem einen Kontrollleuchte.
define act_on_Einfahrt_AUF notify Einfahrt_AUF { if (Value("Einfahrt") eq "Closed") { fhem("set Tor_Aktor on ;; set Kontrollampe on")} }
Sinnlos sind mitunter anzutreffende Konstruktionen wie etwa:
define act_on_Einfahrt_AUF notify Einfahrt_AUF { fhem("set Tor_Aktor on ;; set Kontrollampe on")} }
Da Perl hier nur dazu verwendet wird ohne weitere Bedingung Kommandos an FHEM weiterzureichen, ist dies nur eine besonders komplizierte Schreibweise von
define act_on_Einfahrt_AUF notify Einfahrt_AUF set Tor_Aktor on ; set Kontrollampe on
Inzwischen ist FHEM um den relativ mächtigen Befehl DOIF erweitert, der die meisten Fälle von bedingten Aktionen ohne Perl abbildbar macht. Es gibt aber dennoch Fälle, wo Perl die einzige Möglichkeit bleibt bestimmte Aktionen durchzuführen.