| PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Post your PHP questions here! |
 |
|

02-12-2009, 20:25
|
|
Mastacheata
Registrierter Benutzer
|
|
Registriert seit: May 2004
Beiträge: 4
|
|
Bedingte Funktionsdefinition
Hallo,
ich suche nach einer eleganteren Variante für folgendes Konstrukt, das in mehreren Projekten genutzt wird an denen ich mitarbeite:
Es geht darum eine Funktion auf 2 oder noch mehr verschiedene arten zu definieren, je nachdem ob bestimmte globale Vorbedingungen eintreten. Insbesondere um Kompatibilität zwischen verschiedenen PHP Versionen zu gewährleisten.
Dazu gibt es dann hässliche Konstrukte wie folgt:
PHP-Code:
if (PHPVersion < 5)
{
function bla($abc)
{
workaround
}
}
else
{
function bla($abc)
{
neue_funktion_genutzt
}
}
Mit Fug und Recht meckert meine IDE da jetzt dran rum, dass ich ja eine Funktion doppelt definiert habe. (PHP selbst stört das übrigens nicht im geringsten)
Irgendwelche Vorschläge wie man solche Konstrukte vermeidet und dennoch die selbe Funktionalität erreicht ohne die Prüfung in den Funktionsrumpf einzubauen?
|

02-12-2009, 20:35
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.328
|
|
Eigentlich sollte aus Sicherheitsgründen immer eine aktuelle PHP-Version installiert sein. Ich würde Server mit veralteten Versionen generell meiden, weil sie eine Gefahr darstellen. Du würdest doch auch keine Uraltversion von Windows ohne Sicherheitspatches verwenden, oder?
|

02-12-2009, 20:44
|
|
Mastacheata
Registrierter Benutzer
|
|
Registriert seit: May 2004
Beiträge: 4
|
|
Das liegt nicht in meinem Einflussbereich.
Es ist definitiv geplant irgendwann den PHP4 Support zu droppen, aber nicht in naher Zukunft.
Das Konstrukt wird außerdem noch in anderen Zusammenhängen benutzt wo die Bedingung nicht gerade die PHP Version ist.
|

02-12-2009, 20:49
|
unset
 Moderator
|
|
Registriert seit: Jan 2007
Ort: Düsseldorf
Beiträge: 3.778
|
|
Zitat:
Zitat von Mastacheata
Mit Fug und Recht meckert meine IDE da jetzt dran rum, dass ich ja eine Funktion doppelt definiert habe. (PHP selbst stört das übrigens nicht im geringsten)
|
Was ist denn das für eine IDE, denn eigentlich dürfte Sie da nix zu meckern haben. Die Funktion sollte nur in der Funktionsliste zweimal auftauchen bzw. in der Code-Completion-Funktion zweimal angeboten werden.
|

02-12-2009, 20:50
|
|
PHP-Desaster
PHP Expert
|
|
Registriert seit: Mar 2006
Beiträge: 3.104
|
|
Du kannst die Funktionen in verschiedene Dateien auslagern, aber wirklich hübscher wird es dadurch auch nicht.
|

02-12-2009, 20:56
|
 |
onemorenerd
 Moderator
|
|
Registriert seit: Mar 2005
Ort: Berlin
Beiträge: 9.481
|
|
PHP stört das nicht, weil das erst zur Laufzeit einen Fehler werfen würde ("Cannot redeclare bla"). Mit den If-Bedingungen stellst du aber sicher, dass das nicht passiert.
Deine IDE wertet die Ifs nicht aus. Kann sie auch nicht.
Versuch doch mal, in den If-Else-Blöcken Dateien zu inkludieren und lagere die Funktionen in diese Dateien aus. So mache ich das.
PHP-Code:
// PHP_VERSION_ID and PHP_*_VERSION are available as of PHP 5.2.7. if (!defined('PHP_VERSION_ID')) { $version = explode('.', PHP_VERSION); define('PHP_VERSION_ID', ($version[0] * 10000 + $version[1] * 100 + $version[2])); defined('PHP_MAJOR_VERSION') or define('PHP_MAJOR_VERSION', $version[0]); defined('PHP_MINOR_VERSION') or define('PHP_MINOR_VERSION', $version[1]); defined('PHP_RELEASE_VERSION') or define('PHP_RELEASE_VERSION', $version[2]); }
if (PHP_VERSION_ID < 50300) { $compatFile = dirname(__FILE__) .'/compat_'. PHP_VERSION_ID .'.php';
// Use exception instead of E_ERROR level error from require_once. if (!is_file($compatFile) || !is_readable($compatFile)) { throw new Exception('Unsupported PHP version or missing compatibility file "'. $compatFile .'".'); } require_once $compatFile; }
Die Datei heißt dann z.B. compat_50206.php für PHP 5.2.6.
Diese Datei kann ihrerseits die compat_*.php-Files früherer PHP-Versionen inkludieren. Um die Dateizugriffe zu reduzieren, mache ich das aber nicht. Ich erzeuge die compat_50206.php beim Build.
Meine IDE, ich benutze Eclipse mit PDT, kommt damit klar. Sie kann zwar das require nicht automatisch einbinden, aber ich gebe das aktuellste compat-File (manuell) als Projekt-Include an.
Geändert von onemorenerd (02-12-2009 um 20:59 Uhr)
|

02-12-2009, 21:13
|
|
Mastacheata
Registrierter Benutzer
|
|
Registriert seit: May 2004
Beiträge: 4
|
|
Zitat:
Zitat von unset
Was ist denn das für eine IDE, denn eigentlich dürfte Sie da nix zu meckern haben. Die Funktion sollte nur in der Funktionsliste zweimal auftauchen bzw. in der Code-Completion-Funktion zweimal angeboten werden.
|
Zend Studio 7.0 (Der Markiert das sogar als Error und nicht nur als Warning)
Hier der zugehörige Screenshot:
|

02-12-2009, 21:29
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.328
|
|
Also bei mir zeigt Zend Studio 7.1 keinen Fehler an:
Geändert von h3ll (02-12-2009 um 21:31 Uhr)
|

02-12-2009, 21:35
|
 |
onemorenerd
 Moderator
|
|
Registriert seit: Mar 2005
Ort: Berlin
Beiträge: 9.481
|
|
stripos() kennt die IDE vielleicht als built-in Funktion.
|

02-12-2009, 21:45
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.328
|
|
Zitat:
Zitat von onemorenerd
stripos() kennt die IDE vielleicht als built-in Funktion. 
|
Bei mir lässt PHP sowas erst gar nicht zu, unabhängig von der IDE:
Code:
<?php
function stripos() {
}
Fatal error: Cannot redeclare stripos() in C:\Users\hell\- on line 4
|

02-12-2009, 21:50
|
|
combie
PHP Expert
|
|
Registriert seit: May 2006
Beiträge: 2.925
|
|
Zitat:
Zitat von h3ll
Bei mir lässt PHP sowas erst gar nicht zu, unabhängig von der IDE:
|
Kein Wunder, denn: stripos (PHP 5)
Und du hast es nicht in ein IF verpackt.
|

02-12-2009, 21:54
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.328
|
|
Zitat:
Zitat von combie
Kein Wunder, denn: stripos (PHP 5)
Und du hast es nicht in ein IF verpackt.
|
Das selbe:
PHP-Code:
<?php
if (version_compare(PHP_VERSION, '5.0.0', '>')) {
function stripos() {
}
} else {
function stripos() {
}
}
Fatal error: Cannot redeclare stripos() in C:Usershell- on line 9
|

02-12-2009, 22:04
|
unset
 Moderator
|
|
Registriert seit: Jan 2007
Ort: Düsseldorf
Beiträge: 3.778
|
|
Momentchen, wenn ich das richtig verstehe, dann gibt es stripos erst seit PHP5. D.h., wenn du dich im dem Block befindest, der für PHP5 zuständig ist, darfst du die Funktion gar nicht definieren.
Das würde jedenfalls erklären, warum h3lls code nicht geht (wird ja auch im PHP5 Block definiert) und deiner (du definierst sie ja auch in beiden Blöcken).
Kann es leider grad nicht testen da mein eigentlicher Rechner frecke ist ...
|

02-12-2009, 22:13
|
Kropff
  Administrator
|
|
Registriert seit: Mar 2002
Ort: Köln
Beiträge: 11.310
|
|
Warum triffst du denn keine Unterscheidung in der Funktion? Mal abgesehen vom Namen.
PHP-Code:
function bla($abc)
{
if (PHPVersion < 5)
{
...
}
else
{
...
}
}
Peter
__________________
Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
Meine Seite
|

02-12-2009, 22:36
|
 |
onemorenerd
 Moderator
|
|
Registriert seit: Mar 2005
Ort: Berlin
Beiträge: 9.481
|
|
Wie soll das gehen? Dann darf die Funktion ja nicht z.B. stripos heißen, sonst knallts in neueren PHP-Versionen. Im Code müßte er also statt stripos() my_stripos() aufrufen und für neuere Versionen. Das wäre ziemlich ungelenk und würde bei jedem Aufruf etwas Kosten.
|
|
Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
|
|
|
| Themen-Optionen |
|
|
| Thema bewerten |
|
|
Forumregeln
|
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.
HTML-Code ist aus.
|
|
|
|
PHP News
|