Vorlage:IstZahl

Aus Kitakien

(Unterschied zwischen Versionen)
Wechseln zu: Navigation, Suche
(neu)
K (24 Versionen: Vorlagenmix)
 
(Der Versionsvergleich bezieht 23 dazwischenliegende Versionen mit ein.)
Zeile 1: Zeile 1:
-
{{#switch:{{#expr:{{{1}}}-{{{1}}}}}
+
<onlyinclude>{{#ifeq:{{#iferror:{{#expr:{{#switch:{{{2|}}}<!--
-
  |0={{{1}}}
+
| R
-
  |#default=<!-- in case of error: #1 is not numeric -->
+
|#default= -->
-
}}<noinclude>
+
| R+ =  abs
-
Diese Vorlage prüft, ob der übergebene Parameter numerisch ist (im Sinne der [[WP:VP|Vorlagenprogrammierung]] in der englischen Zahlenschreibweise, mit Punkt als Dezimaltrenner). Falls der Eingangsparameter numerisch ist, wird er unverändert zurückgegeben, im anderen Fall wird der leere Wert zurückgegeben (und keine Fehlermeldung, welche auch immer, ausgegeben).
+
| R- = -abs
-
 
+
| Z  = trunc
-
Diese Vorlage soll nur in anderen Vorlagen verwendet werden. Um dort sinnvoll auf fehlerhafte Parameter reagieren zu können.
+
| Z+
-
  <nowiki>{{</nowiki>#if: <nowiki>{{</nowiki> {{PAGENAME}}|''&lt;expression>'' }} | ''&lt;ist-zahl-text>'' | ''&lt;sonst-text>'' }}
+
| N =  abs trunc
-
Beispiel:
+
| Z- = -abs trunc}}({{{1}}}) = ({{{1}}}) {{#if:{{{3|}}} | round ({{{3}}}) }} }} | }} | 1 | 1 | }}</onlyinclude>
-
<nowiki>{{#if: {{ </nowiki>{{PAGENAME}}<nowiki>|{{{1|}}} }} | {{Höhe|{{{1|}}}}} | {{{1|}}} }}</nowiki>
+
{{Dokumentation}}
-
In diesem Beispiel wird der erste Parameter der aufrufenden Vorlage geprüft und falls es sich um eine Zahl handelt, in die [[Vorlage:Höhe]] weitergereicht, die einen numerischen Parameter erwartet, andernfalls wird der erste Parameter unverändert ausgegeben und ein Fehler vermieden. Natürlich kann die aufrufende Vorlage an dieser Stelle ihre spezifische Fehlermeldung ausgeben.
+
-
 
+
-
===Hintergrund===
+
-
Bisherige Implementierung haben bei Berechnungen in Vorlagen oft den Fehlertext abgefangen, der aus nicht numerischen Werten resultiert. Dies hat aber mehrere Nachteile:
+
-
* es gibt verschiedene Fehlerfälle (etwa „Unexpected number“ oder „Unrecognised punctuation character“)
+
-
* Fehlertexte können variable Teile enthalten (etwa den fehlerhaften Dezimaltrenner)
+
-
* Fehlertexte sind in Englisch.
+
-
* Fehlertexte sind im Prinzip nirgendwo definiert. Sie sind (vermutlich) nicht Teil der offiziellen Schnittstellen und können sich daher im Prinzip mit jeder neuen Version der MediaWiki Software ändern.
+
-
 
+
-
== Test ==
+
-
Testfälle für den [[Regressionstest]] unter [[{{FULLPAGENAME}}/Test]].
+
-
 
+
-
[[Kategorie:Vorlage:für Vorlagen|{{PAGENAME}}]]
+
-
 
+
-
</noinclude>
+

Aktuelle Version vom 15:09, 9. Dez. 2009

Datei:Information.svg Dokumentation
Datei:Zeichen 206.svg Diese Vorlage ist vielfach eingebunden. Wenn du die Auswirkungen genau kennst, kannst du sie bearbeiten. Bitte berücksichtige den aktuellen Stand der Auftragswarteschlange.

Beschreibung

Diese Vorlage prüft, ob der übergebene Parameter numerisch ist (im Sinne der Vorlagenprogrammierung in der englischen Zahlenschreibweise, mit Punkt als Dezimaltrenner). Falls der Eingangsparameter numerisch ist, wird der Wert 1 (für true, wahr), im anderen Fall der leere Wert zurückgegeben (und keine Fehlermeldung, welche auch immer, ausgegeben).

Diese Vorlage soll nur in anderen Vorlagen verwendet werden, um dort sinnvoll auf fehlerhafte Parameter reagieren zu können.

{{#if: {{ IstZahl|<expression> }} | <ist-zahl-text> | <sonst-text> }}

Beispiel:

{{#if: {{ IstZahl|{{{1|}}} }} | {{Höhe|{{{1|}}}}} | {{{1|}}} }}

In diesem Beispiel wird der erste Parameter der aufrufenden Vorlage geprüft und falls es sich um eine Zahl handelt, in die Vorlage:Höhe weitergereicht, die einen numerischen Parameter erwartet, andernfalls wird der erste Parameter unverändert ausgegeben und ein Fehler vermieden. Natürlich kann die aufrufende Vorlage an dieser Stelle ihre spezifische Fehlermeldung ausgeben.

Parameter

{{IstZahl|<Zahl oder Ausdruck>|<Zahlraum>|<Rundung>}}
  • Erster Parameter: Die zu testende Zahl
  • Zweiter Parameter (optional): Test, ob übergebener Wert
    • leer oder R: eine Reelle Zahl ist
    • R+: eine nicht-negative Zahl ist
    • R-: eine nicht-positive Zahl ist
    • Z: eine Ganze Zahl ist
    • N oder Z+: eine Natürliche Zahl ist (inkl. 0)
    • Z-: eine nicht-positive Ganze Zahl ist
  • Dritter Parameter (optional): Test, ob der Wert auf eine bestimmte Weise gerundet wurde (siehe Hilfe:Vorlagenprogrammierung unter round)

Hintergrund

Bisherige Implementierungen haben bei Berechnungen in Vorlagen oft den Fehlertext abgefangen, der aus nicht numerischen Werten resultiert. Dies hat aber mehrere Nachteile:

  • es gibt verschiedene Fehlerfälle (etwa „Unexpected number“ oder „Unrecognised punctuation character“)
  • Fehlertexte können variable Teile enthalten (etwa den fehlerhaften Dezimaltrenner)
  • Fehlertexte sind in Englisch, seit neuesten Deutsch
  • Fehlertexte sind im Prinzip nirgendwo definiert. Sie sind (vermutlich) nicht Teil der offiziellen Schnittstellen und können sich daher im Prinzip mit jeder neuen Version der MediaWiki-Software ändern.


Wenn du Fragen zu dieser Vorlage hast, dann kannst du auf der Seite Kitakien Diskussion:Wikiprojekt Vorlage fragen.
Persönliche Werkzeuge