-
Notifications
You must be signed in to change notification settings - Fork 3
/
Score.php
116 lines (96 loc) · 2.99 KB
/
Score.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
<?php
/*
Score, a MediaWiki extension for rendering musical scores with LilyPond.
Copyright © 2011 Alexander Klauer
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
To contact the author:
http://en.wikisource.org/wiki/User_talk:GrafZahl
https://github.com/TheCount/score
*/
if ( !defined( 'MEDIAWIKI' ) ) {
die( "This file cannot be run standalone.\n" );
}
/**
* Score extension
*
* @file
* @ingroup Extensions
*
* @author Alexander Klauer <[email protected]>
* @license GPL v3 or later
* @version 0.2
*/
/*
* Configuration
*/
/* Whether to trim the score images. Requires ImageMagick.
* Default is $wgUseImageMagick and set in efScoreExtension */
$wgScoreTrim = null;
/* Path to LilyPond executable */
$wgScoreLilyPond = '/usr/bin/lilypond';
/* Path to converter from ABC */
$wgScoreAbc2Ly = '/usr/bin/abc2ly';
/* Path to TiMidity++ */
$wgScoreTimidity = '/usr/bin/timidity';
/**
* The URL path of the directory where files will be stored.
* Defaults to "{$wgUploadPath}/lilypond".
*/
$wgScorePath = false;
/**
* The filesystem path where files will be stored.
* Defaults to "{$wgUploadDirectory}/lilypond".
*/
$wgScoreDirectory = false;
/**
* The name of a file backend ($wgFileBackends) to be used for storing files.
* Defaults to FSFileBackend using $wgScoreDirectory as a base path. Files will
* be stored in a container internally called "score-render".
*/
$wgScoreFileBackend = false;
/*
* Extension credits
*/
$wgExtensionCredits['parserhooks'][] = array(
'name' => 'Score',
'path' => __FILE__,
'version' => '0.2',
'author' => 'Alexander Klauer',
'url' => 'https://www.mediawiki.org/wiki/Extension:Score',
'descriptionmsg' => 'score-desc'
);
/*
* Setup
*/
$scoreBase = __DIR__;
$wgHooks['ParserFirstCallInit'][] = 'efScoreExtension';
$wgExtensionMessagesFiles['Score'] = "$scoreBase/Score.i18n.php";
$wgAutoloadClasses['Score'] = "$scoreBase/Score.body.php";
$wgAutoloadClasses['ScoreException'] = "$scoreBase/Score.body.php";
$wgAutoloadClasses['Score_ScopedProfiling'] = "$scoreBase/Score.body.php";
/**
* Init routine.
*
* @param $parser Parser Mediawiki parser
*
* @return bool Returns true
*/
function efScoreExtension( Parser &$parser ) {
global $wgUseImageMagick, $wgScoreTrim;
if ( $wgScoreTrim === null ) {
// Default to if we use Image Magick, since it requires Image Magick.
$wgScoreTrim = $wgUseImageMagick;
}
$parser->setHook( 'score', 'Score::render' );
return true;
}