Note: You are currently viewing documentation for Moodle 3.7. Up-to-date documentation for the latest stable version of Moodle may be available here: Developer documentation.

Development:Developer documentation: Difference between revisions

From MoodleDocs
No edit summary
m (Reverted edits by Speakinginenglish (talk) to last revision by Tim Hunt)
 
(41 intermediate revisions by 13 users not shown)
Line 1: Line 1:
Este [[: Categoría: Desarrollador | Developer]] en la sección de Moodle Docs está dirigida a los desarrolladores que contribuyen al código de Moodle, plugins, temas, y así sucesivamente.
[[image:moodle-development-logo.jpg|right|400px]]
* Si usted administra un sitio Moodle, [[Documentación Administrador]] puede satisfacer mejor sus necesidades.
* Si usted enseña el uso de Moodle intenta [[Manual del Profesor]].


<p class="note">'' 'Nota:''' páginas de documentación de Nuevo desarrollador debe añadirse al espacio de nombres''''de Desarrollo escribiendo <code> Desarrollo: </ code>, es decir, antes de que el nuevo nombre de la página <código de > <nowiki> [[Desarrollo: Nuevo nombre de página]] </ nowiki> </ code>. Si usted es un desarrollador, es probable que desee cambiar su [[Especial: Preferences | preferencias]] para incluir el espacio de nombres para el Desarrollo en las búsquedas. <br /> <br />
This [[:Category:Developer|Developer]] section of Moodle Docs is aimed at developers who contribute to the Moodle code, plugins, themes, and so on.


Una página puede ser añadido a la categoría de Desarrollo, añadiendo la plantilla <code> <nowiki> CategoryDeveloper (()) </ nowiki> </ code> en la parte inferior de la página. - Si es necesario, puede utilizar <code> <nowiki> [[Categoría: Desarrollador | Sort key]] </ nowiki> </ code> para proporcionar una clave de ordenación que no sea el nombre de la página predeterminada. </ P>
* If you manage a Moodle site, [[Administrator documentation]] may suit your needs better.
* If you teach using Moodle, try [[Teacher documentation]].
<br />
<p class="note">'''Note:''' New developer documentation pages should be added to the ''Development namespace'' by typing <code>Development:</code> before the new page name i.e. <code><nowiki>[[Development:New page name]]</nowiki></code>. If you are a developer, you probably want to change your [[Special:Preferences|preferences]] to include the Development namespace in searches.<br /><br />


== ¿Cómo funciona el desarrollo de Moodle ==
A page may be added to the Developer category by adding the template <code><nowiki>{{CategoryDeveloper}}</nowiki></code> to the bottom of the page. - If required, you can use <code><nowiki>[[Category:Developer|Sort key]]</nowiki></code> to provide a sort key other than the default page name.</p>


El [[Desarrollo: Introducción | Visión general del proceso de desarrollo de Moodle]] se explica cómo se produce el desarrollo de Moodle y cómo la gente se los desarrolladores de Moodle. Los planes actuales están listados en la [[Plan de Trabajo]].
==How Moodle development works==


También puede inscribirse en una de las [http://dev.moodle.org Moodle Cursos de Desarrollo].
The [[Development:Overview|overview of the Moodle development process]] explains how Moodle development occurs and how people become Moodle developers. Current plans are listed on the [[Roadmap]].


Directrices == ==
You can also enrol in one of the [http://dev.moodle.org Moodle Developer Courses].


Las siguientes directrices son de lectura esencial para cualquiera que desee contribuir a la base de código de Moodle:
==Guidelines==
* [[Desarrollo: Codificación | Codificación de directrices]] tiene que ser seguido por todos los desarrolladores de Moodle
* [[Objetivos de diseño de Moodle]] expone los objetivos básicos de diseño detrás de Moodle
* [[Interface Guidelines]] tienen por objeto proporcionar una sensación común a la interfaz de usuario de Moodle
* [[CVS (desarrollador) | Moodle CVS para desarrolladores]] se explica cómo trabajar con el código de Moodle en el CVS
* [[Tracker]] explica el Rastreador de Moodle para el seguimiento de errores, problemas, peticiones de características, etc
* [[Desarrollo: Trabajo con la Comunidad | Trabajar con la Comunidad]] se explica cómo comprometerse con la comunidad dev y discutir los cambios
* [[Desarrollo: Pruebas de Unidad | Unidad de pruebas]] se explica cómo ejecutar las pruebas de unidad, y cómo escribir casos de prueba nueva.
* [[Desarrollo: Rápido portátiles SQL]] muestra las técnicas de SQL que son rápidos, eficientes, y se sabe que funciona en todos los DBs apoyo.


== Documentación de los componentes principales ==
The following guidelines are crucial reading for anyone wanting to contribute to the Moodle code base:
*[[Development:Coding|Coding guidelines]] have to be followed by all Moodle developers
*[[Moodle architecture]] gives an overview of how the Moodle code works
*[[Development:Process]] explains how changes are incorporated into Moodle
*[[Tracker]] explains the Moodle Tracker for keeping track of bugs, issues, feature requests etc
*[[Development:Working with the Community|Working with the Community]] explains how to engage with the dev community and discuss changes
*[[Development:Unit tests|Unit tests]] explains how to run the unit tests, and how to write new test cases.
*[[Development:Profiling PHP|Profiling PHP]] how to analyse your code to find out why it is slow.
*[[Development:Fast portable SQL]] shows SQL techniques that are fast, efficient, and known to work on all supported DBs.
*[[Development:Development hints and tips]] a (developing) list of general wisdom to help with your Moodle projects.


Esta sección es para la documentación de componentes específicos de la actual código de Moodle. Discusión de los componentes que están en discusión o en desarrollo se encuentra en el [[Desarrollo: notas para desarrolladores | Notas de desarrolladores]] o en [[Plan de trabajo | hoja de ruta]].
==Documentation for core components==


Los documentos a continuación dar una visión general. Para la función detallado por la función de documentación, véase el [http://phpdocs.moodle.org/] phpDocumentor documentación que se genera automáticamente a partir de los comentarios en el código.
This section is for documentation of specific components of the existing core Moodle code. Discussion of components that are under discussion or in development can be found in the [[Development:Developer notes|developer notes]] or on the [[Roadmap|roadmap]].


Y no se olvide que la información más actualizada y detallada descripción de cómo funciona el código es el código en sí, y usted puede [http://xref.moodle.org/nav.html?index.html navegar por el código de en línea] usando [[Desarrollo: PHPXref | PHPXref]].
The documents below give a general overview. For detailed function-by-function documentation, see the [http://phpdocs.moodle.org/ phpDocumentor] documentation that is automatically generated from the comments in the code.  


=== Los componentes fundamentales que afectan a todo ===
And don't forget that the most up-to-date and detailed description of how the code works is the code itself, and you can [http://xref.moodle.org/nav.html?index.html browse the code online] using [[Development:PHPXref|PHPXref]].


* [[Desarrollo: introducción de esquemas de base de datos | El esquema de base de datos]]
===Core components ===
* [[Desarrollo: ¿Qué sucede en caso de requerir config.php | ¿Qué sucede en caso de requerir config.php]]
* / lib / moodlelib.php
* [[Desarrollo: lib / weblib.php | lib / weblib.php]] para dar salida cosas
* [[Desarrollo: JavaScript_functions | JavaScript de funciones disponibles en el cliente]]
* [[Desarrollo: XMLDB_Documentation | capa de abstracción de bases de datos]] @ v [[1,7]]
* [[Desarrollo: Roles | Funciones y capacidades del sistema]] @ v [[1,7]] para controlar quién puede hacer qué
* [[Desarrollo: lib / formslib.php | biblioteca de formularios]] @ v [[1,8]] para crear formularios HTML accesibles y seguros que permiten a los usuarios editar las cosas
* [[Desarrollo: Using_the_file_API | Archivo de la API]] @ v [[2,0]] para la gestión de los archivos almacenados por Moodle


=== Bibliotecas básicas con un uso más específico ===
*[[Development:XMLDB_Documentation|Database abstraction layer]] @ v[[1.7]]
*[[Development:Roles|Roles and Capabilities system]] @ v[[1.7]] for controlling who can do what
*[[Development:lib/formslib.php|Forms library]] @ v[[1.8]] for creating accessible and secure HTML forms that let users edit things
*[[Development:Using_the_file_API|File API]] @ v[[2.0]] for managing files stored by Moodle
*[[Development:Database schema introduction|The database schema]]
*[[Development:What happens when you require config.php|What happens when you require config.php]]
*[[Development:lib/moodlelib.php|lib/moodlelib.php]]
*[[Development:lib/weblib.php|lib/weblib.php]] for outputting stuff


* [[Autenticación API]]
===Core libraries with a more specific uses===
* [[Sin cookies Sesiones]]
* [[Procesamiento de correo electrónico]]
* [[Desarrollo: control de Medio Ambiente | control de Medio Ambiente]] antes de instalar, comprobar el servidor del usuario para asegurarse de Moodle trabajar allí.
* [[Desarrollo: Grupos | Grupos de sistema]]
* [[Desarrollo: Grados | cuaderno de notas]]
* [[Desarrollo: Moodle Red | Red Moodle]]
* [[Motor de preguntas]]
* [[Paquete Estadísticas]]
* [[UTF-8 Migración | Migración a UTF-8]] @ v [[: Categoría: Moodle 1.6 | 1.6]]
* [http://developer.yahoo.com/yui YUI JavaScript librería] - YUI fue seleccionada como la biblioteca de AJAX oficial de Moodle.
* [[Desarrollo: lib / graphlib | lib / graphlib]]
* [[Desarrollo: configuración Admin | Administrador de configuración]]


=== Módulos incluidos en la distribución estándar ===
*[[Authentication API]]
*[[Cookieless Sessions]]
*[[Email processing]]
*[[Development:Environment checking|Environment checking]] before install, check the user's server to ensure Moodle will work there.
*[[Development:Groups|Groups system]]
*[[Development:Grades|Gradebook]]
*[[Development:Moodle Network|Moodle Network]]
*[[Question engine]]
*[[Stats package]]
*[[UTF-8 migration|Migration to UTF-8]] @ v[[:Category:Moodle 1.6|1.6]]
*[http://developer.yahoo.com/yui YUI JavaScript library] - YUI was selected as the official AJAX library for Moodle.
*[[Development:lib/graphlib|lib/graphlib]]
*[[Development:Admin settings|Admin settings]]


* [[Desarrollo: Especificación de lección | Especificación Lección]]
===Modules included in the standard distribution===
* [[Docs desarrollador Quiz | Módulo Quiz]]
* [[Esquema SCORM | módulo SCORM 1.5 esquema]]


== ¿Cómo puede contribuir ==
*[[Development:Lesson Specification|Lesson Specification]]
*[[Quiz developer docs|Quiz module]]
*[[SCORM schema|SCORM module 1.5 schema]]


=== Crear un nuevo plugin ===
==How you can contribute==


La M en Moodle significa modular, y más fácil de la manera más fácil de mantener para añadir nuevas funcionalidades a Moodle es mediante el uso de uno de los API plugin de muchos. Hay muchos tipos de plug-in se puede escribir:
===Make a new plugin===
* [[Desarrollo: Módulos | módulos de actividad]], ver también [[Desarrollo: NEWMODULE Documentación]] (en preparación)
* [[Desarrollo: informes Admin | Administrador de informes]]
* [[Desarrollo: los tipos de misiones | Asignación de tipos]]
* [[Desarrollo: plugins de autenticación | Autenticación plugins]]
* [[Desarrollo: Bloques | Bloques]]
* [[Formatos de cursos]]
* [[Desarrollo: Informe del curso Plugins | Curso de informes]]
* [[Desarrollo: Los campos de base de datos | base de datos de los campos]]
* [[Desarrollo: presets de base de datos | base de datos de presets]]
* [[Desarrollo: plugins Inscripción | Inscripción plugins]]
Filtros * [[Desarrollo: Filtros |]]
* [[Desarrollo: plugins cuaderno de notas | cuaderno de notas plugins]] (1,9 en adelante)
** [[Desarrollo: Gradebook_Report_Tutorial | Informe de cuaderno de notas]]
** [[Desarrollo: la exportación del libro de calificaciones | exportación cuaderno de notas]]
** [[Desarrollo: cuaderno de notas de importación | cuaderno de notas de importación]]
* [[Desarrollo: Writing_a_Portfolio_Plugin | Portafolio plugins]] (2.0 en adelante)
* [[Desarrollo: Question_type_plugin_how_to | Tipos de preguntas]]
* [[Desarrollo: Pregunta de importación / exportación de formatos | Cuestión de importación / exportación de formatos]]
* [[Desarrollo: Cómo escribir un plugin informe de prueba | informes Quiz]]
* [[Desarrollo: plugins Repositorio | Repositorio plugins]] (2.0 en adelante)
* [[Desarrollo: Tipos de recursos | Tipos de recursos]]
* [[Desarrollo: Los adaptadores de motores de búsqueda | adaptadores de motores de búsqueda]]


De información general que se aplica a todo tipo de plugins
The M in Moodle stands for modular, and the easiest, most maintainable way to add new functionality to Moodle is by using one of the many plugin APIs. There are many types of plugin you can write:
* [[Desarrollo: Lugares para buscar cadenas lang | ¿Dónde poner las cadenas de idioma de su plug-in]]
*[[Development:Modules|Activity modules]], see also [[Development:NEWMODULE Documentation]] (work in progress)
* [[Desarrollo: Instalar y actualizar tablas de base de datos de plugin | Definición de las tablas de base de datos de los plugins]]
**and [[Development:Subplugins|Sub-Plugins]] (2.0 Onwards)
*[[Development:Admin reports|Admin reports]]
*[[Development:Assignment types|Assignment types]]
*[[Development:Authentication plugins|Authentication plugins]]
*[[Development:Blocks|Blocks]]
*Content editors (2.0 onwards)
*[[Course formats]]
*[[Development:Course Report Plugins|Course reports]]
*Course importers (2.0 onwards)
*[[Development:Database fields|Database fields]]
*[[Development:Database presets|Database presets]]
*[[Development:Enrolment plugins|Enrolment plugins]]
*[[Development:Filters|Filters]]
*[[Development:Gradebook_Report_Tutorial|Gradebook report]]
*[[Development:Gradebook export|Gradebook export]]
*[[Development:Gradebook import|Gradebook import]]
*Message senders (2.0 onwards)
*Mnet services
*Plagiarism detection plugins (2.0 onwards)
*[[Development:Writing_a_Portfolio_Plugin|Portfolio plugins]] (2.0 onwards)
*[[Development:Question_type_plugin_how_to|Question types]]
*[[Development:Question import/export formats|Question import/export formats]]
*[[Development:How to write a quiz report plugin|Quiz reports]]
*[[Development:Repository plugins|Repository plugins]] (2.0 onwards)
*[[Development:Resource types|Resource types]]
*[[Development:Search engine adapters|Search engine adapters]]
*Themes which are different in [[Development:Themes_2.0|Moodle 2.0]], and [[Theme_basics|earlier versions]].
*User profile fields
*[[Development:Web services (2.0 onwards)|Web services (2.0 onwards)]]
*Workshop allocators (2.0 onwards)
*Workshop forms (2.0 onwards)
*Workshop evaluators (2.0 onwards)


Por favor, consulte la [[el desarrollo: directrices para el código contribuido | Guía para el código contribuido]] para una descripción de cómo contribuir en el código de Moodle.
General information that applies to all types of plugins
*[[Development:Places to search for lang strings|Where to put language strings for your plugin]]
*[[Development:Installing and upgrading plugin database tables|Defining the database tables for your plugin]]


A veces no es posible escribir un plugin adecuado para lo que quieres hacer, en cuyo caso puede que tenga que recurrir al uso de la [[Desarrollo: Local_customisation | personalizaciones locales]] gancho.
Please see the [[Development:Guidelines for contributed code|Guidelines for contributed code]] for an overview of how to contribute to the Moodle code.


=== Código del núcleo Cambio ===
Sometimes it is not possible to write a proper plugin for what you want to do, in which case you may have to resort to using the [[Development:Local_customisation|local customisations]] hook.


Algunos tipos de cambio sólo puede hacerse mediante la modificación del código fundamental de Moodle. Estos cambios son mucho más difíciles de mantener que los plugins. Si desea que su cambio básico para ser considerados para su inclusión en la versión oficial de Moodle, es necesario crear un problema en el [[Registros Registro |]], y adjunte su cambio como un [[Desarrollo: How_to_create_a_patch | patch]]. También es una buena idea para discutir sus ideas en los foros primero. Ver [[Desarrollo: Resumen # Major_Development]] para más detalles.
===Change core code===


=== Formas de contribuir que no implican la programación PHP ===
Some types of change can only be made by editing the core Moodle code. Such changes are much harder to maintain than plugins. If you want your core change to be considered for inclusion in the official Moodle release, you need to create an issue in the [[Tracker|tracker]], and attach your change as a [[Development:How_to_create_a_patch|patch]]. It is also a good idea to discuss your ideas in the forums first.  See [[Development:Overview#Major_Development]] for more details.


* [[Temas | Crear temas de Moodle]]
===Ways to contribute that do not involve PHP programming===
* [[Traducción | Traducir Moodle en otros idiomas]]
* [[MoodleDocs: Normas para colaboradores | Ayuda documento de Moodle]]
* [[Desarrollo: Pruebas | Únete al esfuerzo de pruebas]], que consiste en [[Tracker | participantes en el seguimiento de errores]]


== Los planes para el futuro ==
*[[Themes|Create Moodle themes]]
*[[Translation|Translate Moodle into other languages]]
*[[MoodleDocs:Guidelines for contributors|Help document Moodle]]
*[[Development:Tests|Join the testing effort]], which involves [[Tracker|participating in the bug tracker]]


Ideas para detalles y características de un proyecto de futuro de Moodle son inicialmente discutidas en los foros en los [http://moodle.org/course/view.php?id=5 Using Moodle] curso en moodle.org. De que los debates de desarrolladores se entremezclan con los debates de usuario en los mismos foros, puede parecer extraño al principio, pero es una de las razones para el éxito de Moodle. Es importante que tanto los usuarios finales y desarrolladores de discutir las características de un futuro juntos.
==Plans for the future==


Una vez que empiezan a cristalizar las ideas sobre los foros que se pueden resumir en este wiki, ya sea como parte de la [[Plan de trabajo | hoja de ruta]] o en forma de [[Desarrollo: notas para desarrolladores | Notas de desarrolladores]]. Estas páginas a continuación, constituyen la base para continuar el debate en los foros.
Ideas for and details of planned future features of Moodle are initially discussed on the forums in the [http://moodle.org/course/view.php?id=5 Using Moodle] course at moodle.org. That developer discussions are intermixed with user discussions in the same forums may seem strange at first but is one of the reasons for the success of Moodle. It is important that both end-users and developers discuss the future features together.


* [[Plan de Trabajo]]
Once ideas begin to crystallize on the forums they can be summarized in this wiki, either as part of the [[Roadmap|roadmap]] or in the form of [[Development:Developer notes|developer notes]]. These pages then form the basis for further discussion in the forums.
* [[Desarrollo: notas para desarrolladores | notas de desarrolladores]]
* [[Proyectos de estudiantes]]
* [[Reuniones de desarrolladores]]


== Recursos ==
*[[Roadmap]]
*[[Development:Developer notes|Developer notes]]
*[[Student projects]]
*[[Developer meetings]]


* [[Developer FAQ]] - preguntas más frecuentes, especialmente útil para los recién llegados a Moodle
== Resources ==
* [[Desarrollo: Finding_your_way_into_the_Moodle_code | Encontrar su camino en el código de Moodle]] - también se dirige a los recién llegados
cuestiones * [http://tracker.moodle.org/ tracker Moodle] - informes de errores, peticiones de características y otras orugas
** [[De búsqueda de Firefox tracker]] - Como instalar una búsqueda rápida de Firefox para navegar fácilmente a Moodle errores
** [[De búsqueda de Firefox tracker # plugins de búsqueda de Firefox | plugins de búsqueda de Firefox]] - Buscar seguimiento de las cuestiones aún más fácilmente
* [[Archivos unmerged]] - cambios en la rama estable en el CVS que no se han fusionado en [[cabeza]]
* Examinar el código en línea:
** [http://cvs.moodle.org/moodle/ el código con un historial de cambios de CVS completa]
** [http://xref.moodle.org/index.html el código, con enlaces generados por PHPXref]
* [http://phpdocs.moodle.org/ Moodle referencia de PHP doc] - compilado todas las noches en el comentario adjunto a cada clase y la función en el código.
* [[Desarrollo: Base de datos de esquema | Esquema de base de datos]] - para las versiones recientes
* [http://moodle.org/course/view.php?id=5 # 4 noticias sobre el desarrollo y la discusión] de Uso de curso de Moodle
** especialmente el [http://moodle.org/mod/forum/view.php?id=55 Developer Forum General]
** [[Filtros utilizados en los foros de Moodle.org | trucos cool puede utilizar en los foros de moodle.org]]


Herramientas == ==
*[[Developer FAQ]] - frequently asked questions, especially useful for newcomers to Moodle
Algunas personas las herramientas de uso cuando se trabaja en el código de Moodle:
*[[Development:Finding_your_way_into_the_Moodle_code|Finding your way into the Moodle code]] - also aimed at newcomers
*[http://tracker.moodle.org/ Moodle tracker] - bug reports, feature requests and other tracked issues
**[[Firefox tracker search]] - How to setup a firefox quicksearch to easily navigate to moodle bugs
**[[Firefox tracker search#Firefox Search Plugins|Firefox Search Plugins]] - Find tracked issues even more easily
*[[Unmerged files]] - changes on the stable branch in CVS that have not been merged to [[HEAD]]
*Browse the code online:
**[http://cvs.moodle.org/moodle/ the code with a complete change history from CVS]
**[http://xref.moodle.org/index.html the code, with links generated by PHPXref]
*[http://phpdocs.moodle.org/ Moodle PHP doc reference] - compiled nightly from the comment attached to each class and function in the code. 
*[[Development:Database Schema|Database Schema]] - for recent releases
*[http://moodle.org/course/view.php?id=5#4 Development news and discussion] section of Using Moodle course
**especially the [http://moodle.org/mod/forum/view.php?id=55 General developer forum]
**[[Filters used on the Moodle.org forums|cool tricks you can use in the moodle.org forums]]


IDEs === ===
== Tools ==
Some tools people use when working on Moodle code:


* [[Desarrollo: Setting_up_Netbeans | Creación de NetBeans para el desarrollo de Moodle]] - NetBeans para PHP es un gran fuera del editor de la caja.
=== IDEs ===
* [[Desarrollo: Setting_up_Eclipse | Creación de Eclipse para el desarrollo de Moodle]] - Eclipse es un editor de gran utilidad, para el desarrollo de PHP, si usted puede descubrir cómo configurarlo.
* [[Desarrollo: vim | Creación de Vim para el desarrollo de Moodle]]


=== Complementos del explorador ===
* [[Development:Setting_up_Netbeans|Setting up NetBeans for Moodle development]] - NetBeans for PHP is a great out-of-the-box editor.
* [Firebug http://getfirebug.com], véase [[Desarrollo: Firebug]].
* [[Development:Setting_up_Eclipse|Setting up Eclipse for Moodle development]] - Eclipse is a great editor to use for php development, if you can work out how to set it up.
* [[Extensión desarrollador Web]]
* [[Development:vim|Setting up Vim for Moodle development]]
* [Https: / / addons.mozilla.org/en-US/firefox/addon/394 Viewsourcewith] - El objetivo principal es para ver la fuente de la página con aplicaciones externas, pero usted puede hacer un montón de otras cosas también.
* [http://www.aptana.com/ Aptana Studio 2]


Varios === ===
=== Browser add-ons ===
* [[Desarrollo: ctags | Ctags]] - Con un archivo de etiquetas de código para navegar
*[http://getfirebug.com Firebug], see [[Firebug]] for details.
* [[W3C_validation | W3C validador HTML]] - Moodle tiene soporte para el uso más fácil.
* [[Web developer extension]]
* [[Desarrollo: Windows Installer | Windows Installer]] - Windows Installer documentación para desarrolladores.
* [https://addons.mozilla.org/en-US/firefox/addon/394 ViewSourceWith] - The main goal is to view page source with external applications, but you can do a lot of other things as well.


Véase también: [http://dev.moodle.org/mod/forum/view.php?id=18 útiles Foro para el Desarrollo Herramientas] en la [http://dev.moodle.org/course/view.php?id = 2 Introducción a la programación de cursos Moodle]
=== Miscellaneous ===
*[[Development:ctags|Ctags]] - Using a tags file to navigate code
*[[W3C_validation|W3C HTML validator]] - Moodle has built in support to make using it easier.
*[[Development:Windows Installer|Windows Installer]] - Windows Installer documentation for developer.


== Véase también ==
See also: [http://dev.moodle.org/mod/forum/view.php?id=18 Useful Development Tools forum]in the [http://dev.moodle.org/course/view.php?id=2 Introduction to Moodle Programming course]


* [http://moodle.org/security/ Moodle Anuncios de Seguridad]
==See also==
* [http://moodle.com/partners/ Moodle Asociados] - los proveedores de servicios con Moodle desarrollo


[[Category: Desarrollador]]
*[http://moodle.org/security/ Moodle Security Announcements]
[[Categoría: Herramientas de Desarrollo]]
*[http://moodle.com/partners/ Moodle Partners] - providers of custom Moodle development services


[[ru: Desarrollo: Краткий обзор]]
[[Category:Developer]]
[[en: Documentación para Desarrolladores]]
[[Category:Developer tools]]
[[fr: développeur Documentación]]
 
[[pt: Desenvolvimento: Documentación para programadores]]
[[ru:Development:Краткий обзор]]
[[es:Documentación para Desarrolladores]]
[[fr:Documentation développeur]]
[[pt:Desenvolvimento:Documentação para programadores]]
[[zh:开发者文档]]
[[zh:开发者文档]]
[[ja:開発者ドキュメント]]
[[ja:開発者ドキュメント]]
[[fi: opas Ohjelmoijan]]
[[fi:Ohjelmoijan opas]]

Latest revision as of 21:33, 26 April 2011

moodle-development-logo.jpg

This Developer section of Moodle Docs is aimed at developers who contribute to the Moodle code, plugins, themes, and so on.


Note: New developer documentation pages should be added to the Development namespace by typing Development: before the new page name i.e. [[Development:New page name]]. If you are a developer, you probably want to change your preferences to include the Development namespace in searches.

A page may be added to the Developer category by adding the template {{CategoryDeveloper}} to the bottom of the page. - If required, you can use [[Category:Developer|Sort key]] to provide a sort key other than the default page name.

How Moodle development works

The overview of the Moodle development process explains how Moodle development occurs and how people become Moodle developers. Current plans are listed on the Roadmap.

You can also enrol in one of the Moodle Developer Courses.

Guidelines

The following guidelines are crucial reading for anyone wanting to contribute to the Moodle code base:

Documentation for core components

This section is for documentation of specific components of the existing core Moodle code. Discussion of components that are under discussion or in development can be found in the developer notes or on the roadmap.

The documents below give a general overview. For detailed function-by-function documentation, see the phpDocumentor documentation that is automatically generated from the comments in the code.

And don't forget that the most up-to-date and detailed description of how the code works is the code itself, and you can browse the code online using PHPXref.

Core components

Core libraries with a more specific uses

Modules included in the standard distribution

How you can contribute

Make a new plugin

The M in Moodle stands for modular, and the easiest, most maintainable way to add new functionality to Moodle is by using one of the many plugin APIs. There are many types of plugin you can write:

General information that applies to all types of plugins

Please see the Guidelines for contributed code for an overview of how to contribute to the Moodle code.

Sometimes it is not possible to write a proper plugin for what you want to do, in which case you may have to resort to using the local customisations hook.

Change core code

Some types of change can only be made by editing the core Moodle code. Such changes are much harder to maintain than plugins. If you want your core change to be considered for inclusion in the official Moodle release, you need to create an issue in the tracker, and attach your change as a patch. It is also a good idea to discuss your ideas in the forums first. See Development:Overview#Major_Development for more details.

Ways to contribute that do not involve PHP programming

Plans for the future

Ideas for and details of planned future features of Moodle are initially discussed on the forums in the Using Moodle course at moodle.org. That developer discussions are intermixed with user discussions in the same forums may seem strange at first but is one of the reasons for the success of Moodle. It is important that both end-users and developers discuss the future features together.

Once ideas begin to crystallize on the forums they can be summarized in this wiki, either as part of the roadmap or in the form of developer notes. These pages then form the basis for further discussion in the forums.

Resources

Tools

Some tools people use when working on Moodle code:

IDEs

Browser add-ons

Miscellaneous

See also: Useful Development Tools forumin the Introduction to Moodle Programming course

See also