Localisation updates for core and extension messages from translatewiki.net (2010...
[mediawiki.git] / includes / specials / SpecialAncientpages.php
blob92192435014513345ae8c994adf2a674cdabcb9d
1 <?php
2 /**
3 * @file
4 * @ingroup SpecialPage
5 */
7 /**
8 * Implements Special:Ancientpages
9 * @ingroup SpecialPage
11 class AncientPagesPage extends QueryPage {
13 function getName() {
14 return "Ancientpages";
17 function isExpensive() {
18 return true;
21 function isSyndicated() { return false; }
23 function getSQL() {
24 global $wgDBtype;
25 $db = wfGetDB( DB_SLAVE );
26 $page = $db->tableName( 'page' );
27 $revision = $db->tableName( 'revision' );
29 switch ($wgDBtype) {
30 case 'mysql':
31 $epoch = 'UNIX_TIMESTAMP(rev_timestamp)';
32 break;
33 case 'ibm_db2':
34 // TODO implement proper conversion to a Unix epoch
35 $epoch = 'rev_timestamp';
36 break;
37 case 'oracle':
38 $epoch = '((trunc(rev_timestamp) - to_date(\'19700101\',\'YYYYMMDD\')) * 86400)';
39 break;
40 case 'sqlite':
41 $epoch = 'rev_timestamp';
42 break;
43 default:
44 $epoch = 'EXTRACT(epoch FROM rev_timestamp)';
47 return
48 "SELECT 'Ancientpages' as type,
49 page_namespace as namespace,
50 page_title as title,
51 $epoch as value
52 FROM $page, $revision
53 WHERE page_namespace=".NS_MAIN." AND page_is_redirect=0
54 AND page_latest=rev_id";
57 function sortDescending() {
58 return false;
61 function formatResult( $skin, $result ) {
62 global $wgLang, $wgContLang;
64 $d = $wgLang->timeanddate( wfTimestamp( TS_MW, $result->value ), true );
65 $title = Title::makeTitle( $result->namespace, $result->title );
66 $link = $skin->linkKnown(
67 $title,
68 htmlspecialchars( $wgContLang->convert( $title->getPrefixedText() ) )
70 return wfSpecialList($link, htmlspecialchars($d) );
74 function wfSpecialAncientpages() {
75 list( $limit, $offset ) = wfCheckLimits();
77 $app = new AncientPagesPage();
79 $app->doQuery( $offset, $limit );