Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Probleme mit js2fs adapter: Skripte werden doppelt gestartet und ausgeführt

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Probleme mit js2fs adapter: Skripte werden doppelt gestartet und ausgeführt

    This topic has been deleted. Only users with topic management privileges can see it.
    • ruhr70
      ruhr70 last edited by

      @AlCalzone:

      @ruhr70:

      Argh… brauche ich die erste Zeile in einem Skript, in allen Skripten, gar nicht, in Unterordnern (je nach Ebene) anders? `
      Gerade mal probiert. Anscheinend muss nur eine Datei geöffnet sein, die die Referenz auf javascript.d.ts enthält, dann geht es in allen anderen auch.

      Damit es immer in allen dateien geht, brauchst du sowohl // @ts-check als auch /// `

      komischerweise funktioniert es gerade auch, ohne das "reference…" in irgendeiner Datei steht.

      Vielleicht hat sich das VSCode ja gemerkt :lol:

      Danke für die Rückmeldung.

      Dann werde ich mir im Produktivsystem ein Skript anlegen, welches nur die beiden Zeilen enthält und in allen anderen Skripten // @ts-check ergänzen.

      [EDIT]

      Ups… das fette geöffnet überlesen.

      Dann teste ich noch etwas. Eventuell muss nur die Datei selbst geöffnet sein.

      [EDIT2]

      ja. Wenn javascript.d.ts geöffnet ist, dann funktioniert es ohne den Referenzverweis.

      Ist für mcih einfacher, als in allen Datein die richtigen ../../ zu pflegen.

      1 Reply Last reply Reply Quote 0
      • ruhr70
        ruhr70 last edited by

        @AlCalzone:

        Vor allem kann es mit https://github.com/ioBroker/ioBroker.javascript/blob/master/lib/javascript.d.ts Autovervollständigung und Typüberprüfung für die Funktionen der ioBroker-Schnittstelle, wenn du am Anfang deines Skripts diesen Kommentar einfügst:

        /// <reference path="javascript.d.ts">
        // @ts-check</reference>
        ```` `  
        

        ftp-sync funktioniert, Typcheck auch 🙂

        Zur Typprüfung habe ich noch eine Frage.

        Was machst Du mit Zeilen, in denen Module nachgeladen werden?

        Wie:````
        const Co2Monitor = require('./co2-monitor');

        
        Hier bekomme ich einen Fehler. Kann man den verhindern?
         ![327_2018-02-10_typ-check.png](/assets/uploads/files/327_2018-02-10_typ-check.png) 
        
        Die globalen Funktionen, die bei mir verwendet werden, habe ich am Ende der Datei ****javascript.d.ts**** hinzugefügt:
        
        function sayit(text: string, vol: number?, instanz?: number): void;
        function isTimeInRange(strLower:string, strUpper:string): boolean;
        function arbeitstag(): boolean;
        function urlaubstag(): boolean;
        

        }

        
        Wahrscheinlicher ist es sinnvoll noch eine zweite Datei anzulegen?
        
        Hier muss ich mir dann noch ansehen, wie die aussehen muss und was ich aus der ****javascript.d.ts**** weglassen kann.
        
        Dann wird ein Fehler bemängelt, bei dem ich nicht nachvollziehen kann, warum:
         ![327_2018-02-10_false.png](/assets/uploads/files/327_2018-02-10_false.png) 
        
        Die beiden ****createState()**** sind doch inhaltlich gleich. Warum erfolgt bei dem letzten ****createState()**** die Fehlermeldung?
        1 Reply Last reply Reply Quote 0
        • ruhr70
          ruhr70 last edited by

          @AlCalzone:

          Anscheinend vergibt ioBroker da noch etwas mehr als meine Definitionen 😄 `

          Bei der Typprüfung erhalte ich noch einen Fehler bei der Verarbeitung eines Objekts, welches die Funktion on() liefert:
          327_2018-02-10_id.png

          Mein Fehler?

          Oder muss die Datei zur Typprüfung noch angepasst werden?

          1 Reply Last reply Reply Quote 0
          • AlCalzone
            AlCalzone Developer last edited by

            Schau ich mir später in Ruhe an. Die Module werden nicht bemängelt wenn du sie in deinem Entwicklungsordner per npm installierst. Wenn du zusätzlich „@types/modulname“ installierst, gibts dafür auch Hilfe.

            Gesendet von unterwegs

            1 Reply Last reply Reply Quote 0
            • AlCalzone
              AlCalzone Developer last edited by

              Ok hab doch noch ein bisschen Leerlauf.

              Deine eigenen Funktionen kannst du in einer eigenen .d.ts Datei deklarieren. Im einfachsten Fall reicht für jede Funktion ein „declare function(…): ...“

              Oder du machst es ähnlich wie ich mit declare global (aber dann musst du ein Modul wie „fs“ importieren)

              Dein zweites createState hat common.type state statt string. Das gibts glaube ich nicht, deswegen wird das Objekt nicht als Partial common erkannt.

              Das mit on() hat jemand anders nachgerüstet, das hab ich jetzt nicht im Kopf

              Gesendet von unterwegs

              1 Reply Last reply Reply Quote 0
              • R
                robsdobs last edited by

                @ruhe70:Als was verwendest du den das in IOBroker. JavaScript oder Typescript?

                Bei Typescript brauchst du die Definition deiner globalen Funktion immer im Script. Oder, wenn es etwas anderes gibt: Ich suche auch noch nach einer besseren Methode.

                Das mit dem on hab ich zwar nachgerüstet, aber auch nicht im Kopf. Das sehe ich mir an.

                Das hatte ich anhand der verfügbaren Doku erstellt. Vielleicht fehlt noch was. - Bin hier auch nur Anfänger.

                1 Reply Last reply Reply Quote 0
                • ruhr70
                  ruhr70 last edited by

                  @AlCalzone:

                  Schau ich mir später in Ruhe an. Die Module werden nicht bemängelt wenn du sie in deinem Entwicklungsordner per npm installierst. Wenn du zusätzlich „@types/modulname“ installierst, gibts dafür auch Hilfe. `

                  Ich danke Dir für Deine Hilfe und für Deine Geduld! Du schaffst es allerdings durchaus mich abzuhängen.

                  Was heißt Entwicklungsordner? Es geht um die Skripte aus ioBroker, welche einmal auf dem ioBroker Ubuntu Rechner und einmal auf meinem Windows 10 Rechner liegen.

                  Auf dem Windows 10 Rechner habe ich node.js/npm nicht installiert.

                  Kann man eventuell eine einzelne Zeile von der Typprüfung ausnehmen?

                  1 Reply Last reply Reply Quote 0
                  • ruhr70
                    ruhr70 last edited by

                    @robsdobs:

                    Als was verwendest du den das in IOBroker. JavaScript oder Typescript?

                    Bei Typescript brauchst du die Definition deiner globalen Funktion eh immer auch im Script. `

                    Ich verwende Javascript.

                    @robsdobs:

                    Das mit dem on sehe ich mir an. Das hatte ich anhand der verfügbaren Doku erstellt. Vielleicht fehlt noch die ID. `

                    Danke! 🙂

                    1 Reply Last reply Reply Quote 0
                    • R
                      robsdobs last edited by

                      also laut https://github.com/ioBroker/ioBroker.javascript/blob/master/doc/en/javascript.md#on–-subscribe-on-changes-or-updates-of-some-state gibt es beim Rückgabetyp für on/subscribe objekt keine id:

                      {
                          	'_id' : 'javascript.0.myplayer',
                          	'type' : 'state',
                          	'common' : {
                          		'def' :    '0',
                                  'min'  :   '0',
                                  'max'  :   '6',
                          		'type' :   'number',
                          		'read' :   'true',
                          		'write' :  'true',
                          		'states' : '0:stop;1:play;2:pause;3:next;4:previous;5:mute;6:unmute',
                          		'role' :   'media.state',
                          		'desc' :   'Player handling',
                          		'name' :   'MyPlayer'
                          	},
                          	'native' : {},
                          	'channelId' :   'channelID',
                          	'channelName' : 'channelName',
                          	'deviceId' :    'deviceID',
                          	'deviceName' :  'deviceName',
                          	'enumIds' : [],
                          	'enumNames' : [],
                          	'state' : {
                          		'val' :  'new state',
                          		'ts' :   1416149118,
                          		'ack' :  true,
                          		'lc' :   1416149118,
                          		'from' : 'system.adapter.sonos.0'
                          	},
                          	'oldState' : {
                          		'val' :  'old state',
                          		'ts' :   1416148233,
                          		'ack' :  true,
                          		'lc' :   1416145154,
                          		'from' : 'system.adapter.sonos.0'
                          	}
                          }
                      

                      Ist kein Problem das hinzu zutragen. Ich würde nur gerne wissen was es da noch alles gibt oder geben kann.

                      1 Reply Last reply Reply Quote 0
                      • R
                        robsdobs last edited by

                        ok, ich hab die Änderung im https://github.com/ioBroker/ioBroker.javascript/pull/78 requested.

                        die geänderte Datei ist https://github.com/robdg80/ioBroker.javascript/blob/patch-1/lib/javascript.d.ts.

                        Da ist nur das ChangedStateObject geändert. Das kannst du in deine Datei so übernehmen:

                        		/** Represents the change of a state */
                        		interface ChangedStateObject extends StateObject {
                        			common: StateCommon;
                        			native: Record<string, any="">;
                        			id?: string;
                        			name?: string;
                        			channelId?: string;
                        			channelName?: string;
                           			deviceId?: string;
                        			deviceName?: string;
                        			/** The IDs of enums this state is assigned to. For example ["enum.functions.Licht","enum.rooms.Garten"] */
                        			enumIds? : string[];
                        			/** The names of enums this state is assigned to. For example ["Licht","Garten"] */
                        			enumNames? : string[];
                        			/** new state */
                           			state: State;
                        			/** @deprecated Use state instead **/
                        			newState: State;
                        			/** previous state */
                        			oldState: State;
                        			/** Name of the adapter instance which set the value, e.g. "system.adapter.web.0" */
                        			from?: string;
                        			/** Unix timestamp. Default: current time */
                        			ts?: number;
                        			/** Unix timestamp of the last time the value changed */
                        			lc?: number;
                        			/** Direction flag: false for desired value and true for actual value. Default: false. */
                        			ack?: boolean;
                        		}</string,> 
                        
                        Hypnos3 created this issue in ioBroker/ioBroker.javascript

                        closed enhanced ChangedStateObject #78

                        1 Reply Last reply Reply Quote 0
                        • ruhr70
                          ruhr70 last edited by

                          @AlCalzone:

                          Deine eigenen Funktionen kannst du in einer eigenen .d.ts Datei deklarieren. Im einfachsten Fall reicht für jede Funktion ein „declare function(…): ...“

                          Oder du machst es ähnlich wie ich mit declare global (aber dann musst du ein Modul wie „fs“ importieren) `

                          Danke! Ich habe jetzt eine neue Datei javascript-global.d.ts erstellt mit folgendem Inhalt:

                          import child_process = require("child_process");
                          
                          type EmptyCallback = () => void;
                          type ErrorCallback = (err?: string) => void;
                          type GenericCallback = (err: string | null, result?: T) => void;
                          
                          // tslint:disable:no-namespace
                          declare global {
                          
                          	function sayit(text: string, vol: number?, instanz?: number): void;
                          	function isTimeInRange(strLower:string, strUpper:string): boolean;
                          	function arbeitstag(): boolean;
                          	function urlaubstag(): boolean;
                          }
                          

                          Und im Skript:

                          /// <reference path="../javascript.d.ts">/// <reference path="../javascript-global.d.ts">// @ts-check</reference></reference> 
                          

                          Das funktioniert jedenfalls.

                          1 Reply Last reply Reply Quote 0
                          • ruhr70
                            ruhr70 last edited by

                            @robsdobs:

                            ok, ich hab die Änderung im https://github.com/ioBroker/ioBroker.javascript/pull/78 requested.

                            die geänderte Datei ist https://github.com/robdg80/ioBroker.javascript/blob/patch-1/lib/javascript.d.ts.

                            Da ist nur das ChangedStateObject geändert. Das kannst du in deine Datei so übernehmen: `

                            Habe ich gemacht. Die Meldung ist weg.

                            Super! Danke Dir!

                            1 Reply Last reply Reply Quote 0
                            • ruhr70
                              ruhr70 last edited by

                              @AlCalzone:

                              Dein zweites createState hat common.type state statt string. Das gibts glaube ich nicht, deswegen wird das Objekt nicht als Partial common erkannt. `

                              Tomaten auf den Augen. Danke. Da gehört boolean rein. Danke!

                              Aber da sieht man schön, dass eine Typprüfung sinn macht 🙂

                              1 Reply Last reply Reply Quote 0
                              • AlCalzone
                                AlCalzone Developer last edited by

                                @ruhr70:

                                Danke! Ich habe jetzt eine neue Datei javascript-global.d.ts erstellt mit folgendem Inhalt: `
                                Die Callback-Typen kannst du weglassen, oder verwendest du die irgendwo anders noch?

                                1 Reply Last reply Reply Quote 0
                                • ruhr70
                                  ruhr70 last edited by

                                  @AlCalzone:

                                  Die Callback-Typen kannst du weglassen, oder verwendest du die irgendwo anders noch? `

                                  ok. dann kommen die raus.

                                  1 Reply Last reply Reply Quote 0
                                  • ruhr70
                                    ruhr70 last edited by

                                    setStateDelayed() müsste wahrscheinlich auch noch angepasst werden:

                                    327_2018-02-11_setstatedelayed.png

                                    1 Reply Last reply Reply Quote 0
                                    • R
                                      robsdobs last edited by

                                      @ruhr70:

                                      setStateDelayed() müsste wahrscheinlich auch noch angepasst werden:

                                      filename="2018-02-11_setStateDelayed.png" index="0">~~ ` Da fehlen vermutlich ein paar Überladungen. Kann ich mir morgen Abend ansehen (wenn nicht AlCalzone schneller ist :))

                                      1 Reply Last reply Reply Quote 0
                                      • AlCalzone
                                        AlCalzone Developer last edited by

                                        @ruhr70:

                                        setStateDelayed() müsste wahrscheinlich auch noch angepasst werden: `
                                        https://github.com/ioBroker/ioBroker.javascript/pull/79

                                        Ich hoffe ich hab alle Möglichkeiten erwischt. Mit den 2 boolean-Parametern ist das nämlich nicht eindeutig.

                                        1 Reply Last reply Reply Quote 0
                                        • ruhr70
                                          ruhr70 last edited by

                                          @AlCalzone:

                                          @ruhr70:

                                          setStateDelayed() müsste wahrscheinlich auch noch angepasst werden: `
                                          https://github.com/ioBroker/ioBroker.javascript/pull/79

                                          Ich hoffe ich hab alle Möglichkeiten erwischt. Mit den 2 boolean-Parametern ist das nämlich nicht eindeutig. `

                                          Danke! Die Meldungen sind weg 🙂

                                          1 Reply Last reply Reply Quote 0
                                          • ruhr70
                                            ruhr70 last edited by

                                            @AlCalzone:

                                            Schau ich mir später in Ruhe an. Die Module werden nicht bemängelt wenn du sie in deinem Entwicklungsordner per npm installierst. Wenn du zusätzlich „@types/modulname“ installierst, gibts dafür auch Hilfe. `

                                            @ruhr70:

                                            Ich danke Dir für Deine Hilfe und für Deine Geduld! Du schaffst es allerdings durchaus mich abzuhängen.

                                            Was heißt Entwicklungsordner? Es geht um die Skripte aus ioBroker, welche einmal auf dem ioBroker Ubuntu Rechner und einmal auf meinem Windows 10 Rechner liegen.

                                            Auf dem Windows 10 Rechner habe ich node.js/npm nicht installiert.

                                            Kann man eventuell eine einzelne Zeile von der Typprüfung ausnehmen? `

                                            Darf ich hier noch einmal nachfragen?

                                            Ich bin mit Eurer Hilfe einen Riesenschritt weiter VSCode besser mit ioBroker zu nutzen.

                                            Wo ich noch nicht weiter bin, ist der Punkt mit der Typprüfung eingebundener externer Module in normalen Skripten.

                                            @AlCalzone:

                                            Die Module werden nicht bemängelt wenn du sie in deinem Entwicklungsordner per npm installierst. `

                                            Auch bei normalen Skripten oder nur bei der Adapterentwicklung?

                                            Dann muss ich auf den Windowsrechner auch node.js / npm installieren.

                                            @AlCalzone:

                                            Wenn du zusätzlich „@types/modulname“ installierst, gibts dafür auch Hilfe. `

                                            Danke für die Info!

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            851
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            8
                                            67
                                            5282
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo