Raccourcis : Contenu - rubriques - sous rubriques
FR

Piste : jelix_vs_copix

Quel est le rapport entre Jelix et Copix 2.3

Jelix est un framework réalisé par Laurent Jouanneau, qui fut un des développeurs principaux du framework Copix. Jelix réutilise certains composants et concepts de la version 2.3dev20050901 (septembre 2005) de Copix. Le coeur a cependant été réécrit presque entièrement. Jelix va donc plus loin qu'un simple fork de Copix.

Voici les nouveautés et différences qu'apporte Jelix 1.0 alpha par rapport à Copix 2.3dev20050901 (cette liste est destinée aux personnes connaissant déjà Copix).

Généralités

  • Entièrement optimisé pour PHP 5 : utilise donc au maximum les concepts objets de PHP5 et toutes les fonctionnalités de PHP5 : exceptions, autoload… Il n'existe pas de version pour PHP 4.
  • Ce qui a été réutilisé de Copix a été optimisé et “dépoussiéré” : le code mort ainsi que des fonctionnalités inutiles ont été supprimées, du code a été refactorisé etc…
  • Meilleures performances générales : avec toutes les modifications apportées, Jelix est en théorie plus performant. Ainsi le code du coeur de Jelix (3000 lignes de code) est 40% moins important que celui de Copix (5000 lignes, sans compter les 2000 lignes de smarty)
  • Réorganisation au niveau de l'organisation des fichiers : nouvelle arborescence des répertoires, meilleure aptitude à être intégré dans un système de paquet comme celui d'une distribution Linux etc…
  • Meilleure prise en charge du charset et de la langue
  • Il n'y a plus CopixSimpleXml (remplacé par le simplexml de PHP5)
  • Système de thèmes de templates
  • Meilleures prises en charges des services web grâce au nouveau coeur : XMLRPC, JSONRPC, …

Le coeur

  • le coeur a entièrement été réécrit : la coordination a quelque peu changée
    • Il n'y a plus de paramètres “desc”. Restent donc uniquement les paramètres “module” et “action”
    • Il n'y a plus de fichier *.desc.php. le “mapping” des actions se fait directement sur les actiongroups.
    • les actiongroups s'appellent maintenant des contrôleurs. La classe CopixActionGroup fait place à jController
    • Il y a un contrôle sur le type contenu d'une réponse en fonction de la requête. Par exemple, on ne peut pas générer du html s'il s'agit d'une requête formatée en XMLRPC. La réponse devra être en XMLRPC. Il y a ainsi des objets de traitements de requêtes dediés à des requêtes spécifiques et n'autorisant que des réponses spécifiques.
    • Les erreurs techniques qui pourraient apparaitre (par trigger_error ou exceptions) sont générées dans le format approprié à la requête/réponse ! (pas de retour d'erreur formatées en HTML quand on attend du JSONRPC par exemple)
    • les plugins de templates sont dédiés à un format de sortie spécifique.
  • Les sélecteurs : la syntaxe a changé “type:module~ressource” ou “module~ressource”. De plus la gestion des selecteurs a été optimisée.
  • Grâce à certains sélecteurs il est possible de proposer un fichier alternatif à un original. Cela permet ainsi de ne pas toucher au code d'un module. Ainsi, on peut redéfinir les templates, les daos, les locales.
  • Il n'y a plus de “niveau projet”
  • Une application peut utiliser des modules se situant dans des répertoires différents. On peut ainsi mutualiser des modules entre plusieurs applications. Idem pour les plugins du coordinateur et les plugins de templates.
  • Fichiers de configurations au format INI : meilleur performance et plus facile à modifier qu'un fichier php
  • Des noms de répertoire, de fichier, et de classes ont été raccourcis pour plus de simplicité (*.actiongroup.php → *.classic.php, *.dao.definition.xml → *.dao.xml, CopixDbFactory → jDb, CopixEventNotifier → jEvent etc…)

Actions, Actiongroup, Zones

Les zones embarquent leur propre système de cache. Ainsi il n'est plus fait usage du complexe CopixCache (qui a disparu pour le coup, peut être reviendra t-il). Une zone s'occupe maintenant automatiquement d'instancier et d'afficher le template associé.

DAO et Db

Jelix réutilise le concept de DAO de Copix et le connecteur de bases de données CopixDb. Cependant, le format de DAO a un peu changé, a été étendu et le moteur a été totalement refait. Les méthodes PHP sont maintenant à intégrer dans le fichier XML, il n'y a donc plus la possibilité de faire des classes PHP annexes.

CopixDb (jDb dans Jelix) a subit un gros nettoyage et il ne reste que ce qui est utile (il n'y a plus par exemple les QueryWidget et il ne reste que l'indispensable dans le DbWidget). De plus, des méthodes ont été renommées afin d'apporter une similitude entre les classes jDbConnection, jDbResultset, avec les classes de PDO, la nouvelle couche d'abstraction de base de données de PHP5.

D'ailleurs, si un profil désigne le driver pdo, jDb (ex CopixDbFactory) instancie une classe PDO au lieu de jDbConnection.

À terme, jDbConnection/jDbResultSet devraient devenir obsolète, une fois que PDO sera suffisamment stable, performant et répandu sur les serveurs.

Localisation

Le moteur CopixI18N a été repris, optimisé et est accessible sous le nom jLocale. Son moteur est plus léger, et permet maintenant de définir des fichiers properties pour chaque charset. jLocale prend celui qui correspond au charset défini pour l'action courante.

Moteur de template

Jelix n'utilise pas Smarty. C'est un moteur trop lourd, incluant de nombreuses fonctionnalités qui ne sont pas toutes utilisées dans un framework comme Jelix/Copix ou qui font doublons avec des fonctionnalités du framework.

Jelix embarque donc un moteur de template inédit, bien plus léger. Il utilise une syntaxe de balise similaire à Smarty mais les expressions utilisées dans les balises sont en php. On peut aussi utiliser des plugins comme dans smarty (en fait, on peut réutiliser les plugins smarty sans trop de modifications pour les plus simples d'entre eux).

Il ajoute aussi une notation syntaxique spécifique pour les locales : @module~my.locale@ , permettant de récupérer une locale à l'intérieur même d'une expression, ou bien de faciliter son affichage : {@module~my.locale@}

Authentification et Droits

La partie authentification a été reprise d'une version expérimentale de Copix, et qui n'a pas été intégrée dans une version officielle (à ce jour, 23/12/2005). Elle est plus souple, permet l'utilisation de “driver” pour l'accès aux informations d'authentification (driver base de données, ldap etc..), une meilleure personnalisation des données utilisateurs et s'occupe uniquement de l'authentification.

La gestion de droits de Copix n'a pas été reprise et Jelix proposera dans la version finale un nouveau système plus clair et plus performant.

Système évènementiel

Peu de choses ont été modifiées de l'original CopixEvent. Seul CopixEvent et CopixEventNotifier ont été fusionnés. Il y a eu quelques modifications mineures.

Scripts développeurs

Jelix fournis des scripts php à utiliser en ligne de commande, facilitant la création des divers fichiers et arborescences dans une application, permettant donc un développement rapide.

Urls

Jelix contient un système de mapping d'url sur les actions. Deux moteurs de génération / parsing d'urls sont disponibles : un moteur simple, et un moteur permettant l'usage des urls significatives (plus puissant que celui proposé dans Copix 2.3).

Fils rss des changements récents dans le wiki Creative Commons License