Developer hub

From MediaWiki.org
Jump to: navigation, search
120

Contents

Crystal Clear app display.png Users Crystal Clear app terminal.png System Administrators Crystal Clear app tutorials.png Developers

This is a high-level overview of MediaWiki development, including links to the key documents, resources and tools available to MediaWiki developers. It is written for skilled LAMP developers who have experience using MediaWiki.

For an introductory guide to developing MediaWiki, read how to become a MediaWiki hacker. If you want to understand how to use a part of MediaWiki (e.g. the Job Queue) see the developer's FAQ

For help installing or customizing MediaWiki, visit the Sysadmin hub. For help using MediaWiki, visit the User hub.

Developer news

Read older news

Overview

MediaWiki is developed in an open source style[1] using the PHP programming language [2] primarily for the LAMP platform[3][4]. Core development is largely coordinated online:

Key documents

Code, development and style

Debugging and testing

  • Bugs – an overview of bug tracking in the MediaWiki project.
  • How to debug – a guide to debugging MediaWiki.
  • Manual:Errors and Symptoms – an overview of common MediaWiki errors and their correlating symptoms.
  • Selenium Framework – learn to write UI tests for MediaWiki using Selenium.
  • Unit testing – learn to write unit tests for MediaWiki using PHPUnit.

Architecture

  • Manual:Code – an overview of the key parts of MediaWiki's source code.
  • Database layout – an overview of MediaWiki's database schemas.
  • Global object variables – a partial list of key global variables.
  • Localisation – learn about MediaWiki's internationalization system.
  • MediaWiki Class Reference – technical documentation generated from the MediaWiki source code. (Note: The class reference is a large, slow-to-load page.)

Sub-systems

  • API – MediaWiki's API provides direct, high-level access to the data contained in the MediaWiki databases.
  • Database access – an overview of using databases in MediaWiki, including a brief guide to the database abstraction layer.

Documentation

Extending MediaWiki

MediaWiki has been designed to allow for modification without changing the "core code". This makes it easy to update to a new version of MediaWiki without having to manually merge in old extension code changes. There are five main extension points that allow developers to change or extend what MediaWiki can do. The extension points are:

  • API – access the data and metadata of MediaWiki instances through a powerful web API.
  • Hooks – every time a given event happens do something.
  • Parser Functions – create a new command like: {{#if:...|...|...}}
  • Skins – change the look and feel of MediaWiki.
  • Special Pages – add a new special page.
  • Tag Extensions – create a new tag like: <newtag>...</newtag>

Help for extension developers

Help for skin developers

Notes

  1. Developers are a mix of volunteers and paid Wikimedia Foundation staff (or contractors). For a full list of who works on the MediaWiki code, read the Developers article.
  2. Not all of MediaWiki is written in PHP. Some supporting tools are written in other languages, including batch files, shell scripts, makefiles and Python.
  3. MediaWiki runs on most platforms that can support PHP, however, the lack of certain utilities or operating system features may limit the functionality or performance of MediaWiki on non-LAMP platforms.
  4. MediaWiki has support for DBMS other than MySQL, including Oracle, PostgreSQL and SQLite.
  5. Visit http://news.gmane.org/gmane.org.wikimedia.mediawiki.bugs to see recent changes to bugs and issues in the MediaWiki Bugzilla instance.
  6. Browse the source code and revisions at http://svn.wikimedia.org/viewvc/mediawiki/trunk/phase3 or checkout the development version of the code using this SVN command:
    svn checkout http://svn.wikimedia.org/svnroot/mediawiki/trunk/phase3 MediaWiki
Language: English  • Català • Česky • Español • Suomi • Français • Bahasa Indonesia • Italiano • 日本語 • 한국어 • Nederlands • Polski • Русский • 粵語 • 中文
Personal tools
Namespaces
Variants
Actions
Site
Support
Download
Development
Communication
Print/export
Toolbox