Difference between revisions of "Lenguaje y Normas de Desarrollo"
Line 172: | Line 172: | ||
= Design patterns y programación con objetos = | = Design patterns y programación con objetos = | ||
== Design patterns de Creación (GoF) == | == Design patterns de Creación (GoF) == | ||
− | Design patterns definidos por el le Gang Of Four (ver la | + | Design patterns definidos por el le Gang Of Four (ver la wikipedia sobre los [http://es.wikipedia.org/wiki/Patr%C3%B3n_de_dise%C3%B1o Design patterns]). |
No hay design patterns de creación particulares. | No hay design patterns de creación particulares. | ||
Hay objetos cercanos a los Singleton y creados conforme al 100% en el espíritu, pero no en la sintaxis, a fin de ser compatible con PHP 4 que no es un lenguaje orientado a objetos completo. | Hay objetos cercanos a los Singleton y creados conforme al 100% en el espíritu, pero no en la sintaxis, a fin de ser compatible con PHP 4 que no es un lenguaje orientado a objetos completo. | ||
== Design patterns de Estructura (GoF) == | == Design patterns de Estructura (GoF) == | ||
− | + | (ver la wikipedia sobre los [http://es.wikipedia.org/wiki/Patr%C3%B3n_de_dise%C3%B1o Design patterns]). | |
No hay design patterns de estructura particulares. | No hay design patterns de estructura particulares. | ||
== Design patterns de Comportamiento (GoF) == | == Design patterns de Comportamiento (GoF) == | ||
− | + | (ver la wikipedia sobre los [http://es.wikipedia.org/wiki/Patr%C3%B3n_de_dise%C3%B1o Design patterns]). | |
No hay design patterns de Comportamiento particulares. | No hay design patterns de Comportamiento particulares. | ||
Revision as of 16:46, 28 September 2009
He aquí algunas normas sobre el lenguaje, la sintaxis y las norma de desarrollo en vigor para el proyecto Dolibarr:
Versiones
- Dolibarr debe funcionar con:
- Todos los SO (Windows, Linux, MACOS...)
- PHP 4.3 ó + (Debe funcionar sin ningún módulo PHP complementario, exceptuando los módulos de acceso a la base de datos).
- Mysql 3.1 ó +
Normas PHP
- Dolibarr está escrito en PHP y soporta todas las versiones de PHP superiores a la 4.1. Todos los archivos deben de contener la extensión .php
- La llamada a las variables superglobales PHP deben pasar a través de los operadores dedicados $_GET, $_POST, $_COOKIES, $_SERVER, $_ENV.
Los otros operadores ($HTTP_SERVER_GET, ...) están siendo depreciados en el seno de PHP, no deben de ser ya utilizados. Por lo tanto, el código debe funcionar incluso cuando la opción register_long_arrays esté en off. Además de que el código debe funcionar cuando la opción de PHP register_globals esté en off (recomendado por PHP), también lo deberá hacer cuando la opción register_globals esté en on (por defecto en muchas instalaciones).
- Los smart tags PHP no són utilizados. Las secciones de código deben de empezar por <?php
- No se permite el uso de la variable PHP_SELF. Utilice en su lugar $_SERVER["PHP_SELF"]
- Cuando varias variables deben ser inicializadas con el mismo valor, utilize múltiples líneas
$var1=1;$var2=1;$var3=1;
en lugar de
$var1=$var2=$var3=1;
que es menos eficiente.
- las cadenas deben de ser encuadradas con comillas simples y las variables sacadas de la cadena.
print 'Mi texo muestra mi '.$variable.' !';
- Los comentarios deben seguir la sintaxis de C, es decir, una doble barra invertida para una línea de comentario y el uso de una barra con arterisco para abrir un bloque de varias líneas
/* Bloque de comentarios
*
* Fin el bloque
*/
$monobjet = new MonObjet($db);
$result=$monobjet->fetch($idobject);
for ($i = 1 , $i < 2 ; $i++)
{
// comentario de una línea
print $i;
}
- Los ficheros deben ser guardados en formato Unix (LF) y no en formato Windows (CR/LF). El formato Unix es compatible con los SO Unix, Windows, Mac, mientras que el formato de archivo de texto de Windows es problemático en algunos PHP en Unix.
Las funciones deben devolver 0 en caso de éxito, y un número <0 en caso de error. A día de hoy, muy pocas funciones cumplen este standard, pero es necesario.
Normas SQL
- ¡Los SELECT * están prohibidos! Cada Select deberá especificar la lista completa de los campos para recuperar. Esto permitirá evitar confusiones. Ejemplo:
SELECT field_a, field_b, field_c FROM table_1 WHERE field_d = '$id'
- En las consultas SQL, entrecomillaremos los campos, pero no los numéricos que contengan cantidades que se almacenen en los campos de tipo double o real. Los entrecomillados en los numéricos de tipo float se almacenan con un valor diferente. Por ejemplo 412.62 dentro del insert se guardara con el valor 412.61999512 en base si el campo es de tipo double(24,8). Y PHP sólo ve 412.61999512. Otras herramientas verán 412.62 dando la impresión de que no hay problemas. Y PHP tiene razón, hay un problema en base. Mediante la eliminación de las comillas en los numéricos, esto irá mejor.
Ejemplo:
Bien:INSERT INTO table_1 (field_txt, field_num) VALUES ('txt', 412.62)
Mal: INSERT INTO table_1 (field_txt, field_num) VALUES ('txt', '412.62')
Nota, el problema de los float es general y no sólamete en el acceso a la base de datos, está presente en todos los lenguajes cuando trabajamos sobre números reales, por lo que deberán ser limpiados por la función price2num con el segundo parámetro rellenado con: 'MU', 'MT' ó 'MS' según sea necesario. Consulte el capítulo "Los números reales, importes y cálculos" más abajo.
En la práctica, con la finalidad de set compatible con todas las precisiones de los paises, utilizaremos los siguientes tipos:
- double(24,8) para cualquier importe - double(6,3) para las tasas de IVA - real para una cantidad
- Dolibarr debe trabajar incluso con la opción strict de Mysql activa.
- las funciones NOW ó SYSDATE están prohibidas en las órdenes de SQL. Si se necesita indicar la fecha del momento en un campo, el valor debe provenir de PHP y no del motor de la base de datos. Esto además de ofrecer una mejor portabilidad del código, también permite una gestión correcta de la zona horaria.
Normas HTML
- Todos los atributos de las etiquetas HTML deben de estar *en minúscula* y entrecomillados con *doble comilla* (Norma xhtml)
- Los enlaces href deben de ser absolutos. para las páginas, basarse en la constante DOL_URL_ROOT que apunta a htdocs, para las imágenes basarse en la llamada de la función img_picto.
Por ejemplo:
print '<a href="'.DOL_URL_ROOT.'/monrep/mapage.php">'.img_picto('Texte alt','nompictopng','').'</a>';
- Javascript y la llamada a scripts java en las páginas php está fuera de las normas. Si de todas maneras se incluye código javascript, debe estar condicionado mediante el test "$conf->use_javascript"
if ($conf->use_javascript)
{
... // El código PHP que genera el javascript va aquí
}
- Las ventanas emergentes no deben de ser utilizadas, exceptuando los tooltips (y quedan condicionados por el punto anterior).
- Los scripts externos son escritos en Perl si no pueden serlo en php, la utilización de otro lenguaje no está prohibido, pero debe de ser discutido priero en la lista de correo de desarrollo. El lenguaje debe de ser dominado al menos por 2 desarrolladores para asegurar el mantenimiento
Normas Dolibarr y plantillas de código
Plantillas de código
Para estandarizar el código y acelerar el desarrollo de nuevos componentes en Dolibarr, en la carpeta dev/skeletons encontraremos 4 plantillas de código preparadas.
- 1 que sirve de ejemplo de descriptor de módulo: myModule.class.php
- 1 que sirve de ejemplo de código para crear una nueva clase: skeleton_class.class.php
- 1 que sirve de ejemplo de código para crear una nueva página: skeleton_page.php
- 1 que sirve de ejemplo de código para crear una nuevo script a ejecutar en línea de comandos: skeleton_script.php
Úsenlas como ejemplo. Tenga en cuenta que estas plantillas también son utilizadas por el generador de código PHP que se describe en el capítulo de Desarrollo de módulos Dolibarr módulo para acelerar su desarrollo.
Las fechas y la Zona Horaria
Dolibarr es una aplicación multi-usuario y multi-ubicación. Por lo tanto, es necesario almacenar las fechas en el formato correcto. Para evitar problemas de conversión, deben aplicarse las siguientes reglas:
- Una fecha en memoria debe de estar en formato Timestamp GMT.
- Una fecha guardada en la base de datos contiene el Timestamp GMT en relación con la fecha que figura en la consulta en hora local del servidor PHP. No se trata de las fechas de actualización de la base de datos (campo tms en la base de datos).
Por lo tanto, el 1 de enero de 1970, a las 2 en Paris (TZ=+1) será almacenado en memora y será enviado a la base de datos con la cadena '19700101020000' (PHP convierte en hra de su TZ y la base de datos la deconvierte con su TZ que es la misma que la de PHP).
Los métodos select deben traducir los campos fecha al formato de cadenta TZ de la base ('19700101020000') mediante la llamada del método db->jdate para recuperar la información en memoria en formato Timestamp GMT. Y los métodos insert deben deben generar la petición convirtiendo la fecha en memoria conocida en variable, mediante el método db->idate (Ver ejemplos generados por la plantilla).
- Las actualizaciones automáticas de la base de datos (campo tms en la base) contienen el Timestamp GMT del momento en que se ha realizado la modificación. Los métodos select recuperan directamente este dato en memoria en formato Timestamp GMT.
Codificación UTF8/ISO
Dolibarr guarda la información de la manera siguiente:
- En la base de datos, los datos en UTF8 ó ISO. Esto depende del pagecode de la base de datos, y por lo tanto, de las opciones en la creación de esta base de datos. En todos los casos, el controlador de base de datos Dolibarr (dentro de /lib/database) lee e inserta por conversión desde y hacia UTF8.
- Los datos en memoria se guardan en UTF8 (instancias de objetos PHP).
- las páginas web mostradas en pantalla se encuentran en formato UTF8 (con versiones < 2.5.1, es el antiguo parámetro $character_set del fichero conf.php quien define el formato de salida).
Los números reales, importes y cálculos
Tanto en PHP como en otros lenguajes (Java, por ejemplo), los datos no enteros (float, real, double) no son fialbes. Pruebe a realizar por ejemplo
print 239.2 - 229.3 - 9.9;
No obtendrá 0, sino un número muy pequeño en potencia 10 negativo . Si obtiene cero, puede encontrar otros ejemplos que no funcionan. El problema de los float es general, una variable resultante del cálculo de números reales debe SISTEMATICAMENTE ser limpiada mediante la función price2num con el segundo parámetro rellenado con: 'MU', 'MT' ó 'MS' según el caso (ver doc de la función).
print price2num(239.2 - 229.3 - 9.9, 'MT');
Si no es un precio que se ajuste a los parámetros de MU, MT, MS debe utilizar la función round().
Creación de tablas
No crear una tabla a utilizar, es decir, al primer uso del módulo. Si crea un módulo que usa tablas que no se incluyen como estándar en el código de Dolibarr, asegúrese de seguir el tutorial Creación de un módulo que explica cómo incluir las tablas que se crean en la activación del módulo y no en su uso (ver más arriba).
Logs
Añada traces dentro de su código mediante la función dolibarr_syslog($yourmessage, LOG_INFO|LOG_DEBUG|LOG_WARNING|LOG_ERR);
Carpetas de trabajo
Si tiene que crear una carpeta de trabajo, en el código, haga referencia a esta carpeta de la siguiente forma DOL_DATA_ROOT.'/mimodulo'. La carpeta puede crearse en desde su código mediante el código siguiente:
$mymoduledir=DOL_DATA_ROOT.'/mimodulo';
if (! is_dir($mymoduledir)) create_exdir($mymoduledir);
Si necesita una carpeta de datos temporales, esta carpeta deberá ser DOL_DATA_ROOT.'/minmodulo/temp'
Design patterns y programación con objetos
Design patterns de Creación (GoF)
Design patterns definidos por el le Gang Of Four (ver la wikipedia sobre los Design patterns). No hay design patterns de creación particulares. Hay objetos cercanos a los Singleton y creados conforme al 100% en el espíritu, pero no en la sintaxis, a fin de ser compatible con PHP 4 que no es un lenguaje orientado a objetos completo.
Design patterns de Estructura (GoF)
(ver la wikipedia sobre los Design patterns). No hay design patterns de estructura particulares.
Design patterns de Comportamiento (GoF)
(ver la wikipedia sobre los Design patterns). No hay design patterns de Comportamiento particulares.
Design patterns enterprise (Martin Fowler)
Motivos de organización del código
Martin Fowler ha identificado 3 métodos de organización de código llamados principios:
- El Transaction Script (El código es lineal en función de una acción del usuario).
Es el antiguo principio utilizado en los lenguajes de procedimiento. Inconveniente: Redundancia de código. Necesidad de conocer el modelo físico a desarrollar.
- El Domain Model
Es un modelo posible desde los lenguajes orientados a objeto. Son procedimentos funcionales (que deben de ser indentificados antes) que sirven de base para las clases objeto. Inconveniente: Motivo de mantenimiento complejo.
- El Table Module
Un intermedio entre los 2 anteriores donde se tiene una sola clase por tabla de la base de datos.
Como se muestra en el código de la plantilla (ver sección anterior) Dolibarr se basa en el principio de Table Module.
Comunicación lógica de negociado - datos (ORM)
Existen 3 tipos de conexiones:
- Data Gateway a tablas y filas
Es el más simple. Creamos una tabla por clase y cada clase es un puente con la tabla correspondiente, ver una clase por línea tabla. Una instancia de la clase será pues un registro de la tabla. La clase contiene sólo el código de acceso a líneas o columnas de tablas.
Ejemplo: Es el método utilizado al utilizar ciertos Frameworks de ORM como iBatis (http://ibatis.apache.org/).
- El Active Record
Idéntico al anterior, pero podemos añadir algunas funciones de negociado en la clase, siempre que estas funciones sean exclusivas de la tabla o la grabación.
Ejemplo: Es el método utilizado por los desarrollos de Dolibarr y por otras muchas aplicaciones en PHP que disponen de su propio propio framework y prácticas de desarrollo.
- El Data Mapper
Las clases representan las entidades del problema y no los datos. Por lo tanto hay que doblar, triplicar... estas clases con clases de mapeo para acceder a los datos. Más "purista" en el papel ya que el negociado está más cercano, este método también tiene la desventaja de ser más complejo en la práctica. Ejemplo: Es el utilizadao si utilizamos el Framework de ORM Propel (http://propel.phpdb.org/trac/). Lo encontraremos pues en aplicacciones más pesadas basadas en este ORM.
Para los desarrollos de Dolibarr, es recomendado utilizar el modo Active Record que ofrece las ventajas de un modelo cercano de negociado sin la complejidad y sin dificultar mucho la técnica. Es en este modo mediante el cual el desarrollo, la comprensión del código y el mantenimiento técnico y/o funcional parece ser la más productivo (Sin embargo, se trata de un eterno debate entre los puristas y los pragmáticos, el debate en el que nadie puede realmente estar en lo cierto, porque todo depende de los objetivos a atender).