Wikipedia:Lua/Modul/JSONutil

Vorlagenprogrammierung Diskussionen Lua Test Unterseiten
Modul Deutsch English

Modul: Dokumentation
Zentrale Diskussionsseite fehlt

JSONutil – Modul zur Vorbereitung und Analyse von JSON-Daten, die als Parameterwerte an Lua-Module übergeben werden.

Zeilenumbrüche und Tabulatoren in Zeichenketten werden toleriert.

Statt eines pauschalen „Invalid“ wird versucht, einige typische Fehler zu detektieren und mit auffindbarem Kontext zu melden.

Zusätzlich ist es möglich, JSON-Code aus Vorlagensyntax zu generieren.

Funktionen für Vorlagen

failsafe
Versionsmanagement

Die Failsafe-Schnittstelle erlaubt den damit ausgerüsteten Modulen in globaler Verteilung

  • sicherzustellen, dass eine von einer Vorlage oder einem Modul benötigte Funktion in der lokalen Kopie eines Bibliotheksmoduls vorhanden ist, und ggf. auch in einer erforderlichen Mindestversion;
  • die globale Aktualisierung und Verknüpfung von Modulen über Wikidata zu verwalten.

Die Failsafe-Schnittstelle liegt sowohl auf Ebene der Vorlagen wie auch in direktem Lua-Zugriff vor.

Die Funktionen sind im Einzelnen (nicht alle werden bereits überall in vollem Umfang unterstützt):

Parameter
Wert Ergebnis aktuell
nichts
false
lokale Version »2020-11-08«
Mindest­version Mindestversionsbezeichnung
Datum im ISO-Format

Es wird verglichen, ob das aktuelle Modul diese Version oder später erfüllt.

  • leer, falls Mindestversion nicht erfüllt
  • 2001-01-01 → »2020-11-08«
  • 2099-01-01 → »«
wikidata Versionsbezeichnung der globalen Mutter (d:Q63869449)
  • Versionsbezeichnung auf Wikidata
  • lokal, falls dort keine gefunden
»2020-11-08«
item ID des Wikidata-Items
  • leer, falls nicht definiert
  • Q63869449
~ Übereinstimmung der lokalen mit der auf Wikidata registrierten Versionsbezeichnung
  • leer, falls aktuell
  • Versionsbezeichnung auf Wikidata, falls ungleich
»«
@ Ist die aktuelle (Modul-)Seite richtig mit Wikidata verknüpft?
  • leer, falls mit dem richtigen Item verknüpft
  • Item-ID, falls nicht
»Q63869449«
Der Rückgabewert ist in der Vorlagenprogrammierung leer und per Lua false; andernfalls die angegebene Zeichenkette.

Encode

Diese Funktionen generieren JSON-Quelltext aus Vorlagensyntax.

encodeArray
Generiere ein Array mit nicht-leeren Elementen.
Parameter der Vorlageneinbindung (alle optional):
1
Erstes Element des Array
2
Zweites Element des Array
3 4 5 6 7 8 9 …
Beliebig viele weitere Elemente des Array
Parameter des #invoke:
type
Datentyp aller Elemente; boolean / number / string (optional)
encodeComponent
Generiere eine Komponente in einem Objekt.
Parameter des #invoke:
sign
Name der Komponente
value
Wert der Komponente
type
Datentyp der Komponente; boolean / number / string (optional)
indent
Einrückungsstufe der JSON-Quelle (optional number)
encodeHash
Generiere ein Objekt.
Parameter der Vorlageneinbindung (alle optional):
Name1
Wert1
Name2
Wert2
Name3 Name4 Name5 Name6 … (beliebig viele weitere Komponenten)
Wert3 Wert4 Wert5 Wert6 …
encodeI18N
Generiere einen mehrsprachigen Text.
en
Text auf Englisch (empfohlen)
de
Text auf Deutsch (optional)
fr es pt zh … (beliebig viele weitere Sprachen)
Text
indent
Einrückungsstufe der JSON-Quelle (optional number)
encodeObject
Füge eine Abfolge von Komponenten in Objekt-Klammern ein.
1
JSON-Quelltext mit Komponenten, darf auf ein Komma enden
indent
Einrückungsstufe der JSON-Quelle (optional number)
encodePolyglott
Generiere einen lokalen oder mehrsprachigen Text.
1
JSON-Quellcode mit mehrsprachigem Text, oder einfache Zeichenkette
indent
Einrückungsstufe der JSON-Quelle (optional number)

Verwendung

Allgemeine Bibliothek.

Internationalisierung

Siehe auch


Allgemeine Hinweise zur Einbindung von Modulen

Eine Einbindung erfolgt jeweils im Format

{{#invoke: JSONutil | Funktionsname | Wert1 | Wert2 | NameX=Wert … }}

Die Parameter können wie bei Vorlagen benannt oder unbenannt sein; deren Regeln gelten analog.

Wenn unbekannte Zeichenketten von außen kommen (als Vorlagenparameter), sollte immer mit der Form 1=Wert gearbeitet werden.

Zu allgemeinen Problemen beachte die Abhilfen wie bei Vorlagen.

Wenn in einer Vorlage ein Modul verwendet wird, sollte auch immer {{Lua-Vorlage}} in der Dokumentationsseite eingebunden werden.
  1. Das gibt einem Programmierer Aufschluss, dass ein Lua-Modul benutzt wird, welche/s und ggf. welche Einzelfunktion daraus, und verlinkt auf die Dokumentation.
  2. Die Modul-Dokumentationen bekommen ein Link, in welchen Vorlagen sie eingesetzt werden, und wo bei eventuellen Funktionsänderungen Anpassungen erforderlich werden.
  3. Die Vorlage wird zur Übersicht kategorisiert in Kategorie:Vorlage:mit Lua-Programmierung.


Zu weiteren Informationen siehe Hilfe:Lua.

Bei Problemen wende dich bitte an die Vorlagen-Werkstatt, in schweren Fällen hilft auch die Lua-Werkstatt.