Merge "Update tests/phpunit/MediaWikiTestCase.php with support for apcu"
[mediawiki.git] / maintenance / minify.php
blob16e4d1c9727ca5c18d98da013cfa8e50bbf7e669
1 <?php
2 /**
3 * Minify a file or set of files
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 * http://www.gnu.org/copyleft/gpl.html
20 * @file
21 * @ingroup Maintenance
24 require_once __DIR__ . '/Maintenance.php';
26 /**
27 * Maintenance script that minifies a file or set of files.
29 * @ingroup Maintenance
31 class MinifyScript extends Maintenance {
32 public $outDir;
34 public function __construct() {
35 parent::__construct();
36 $this->addOption( 'outfile',
37 'File for output. Only a single file may be specified for input.',
38 false, true );
39 $this->addOption( 'outdir',
40 "Directory for output. If this is not specified, and neither is --outfile, then the\n" .
41 "output files will be sent to the same directories as the input files.",
42 false, true );
43 $this->addDescription( "Minify a file or set of files.\n\n" .
44 "If --outfile is not specified, then the output file names will have a .min extension\n" .
45 "added, e.g. jquery.js -> jquery.min.js."
49 public function execute() {
50 if ( !count( $this->mArgs ) ) {
51 $this->error( "minify.php: At least one input file must be specified." );
52 exit( 1 );
55 if ( $this->hasOption( 'outfile' ) ) {
56 if ( count( $this->mArgs ) > 1 ) {
57 $this->error( '--outfile may only be used with a single input file.' );
58 exit( 1 );
61 // Minify one file
62 $this->minify( $this->getArg( 0 ), $this->getOption( 'outfile' ) );
64 return;
67 $outDir = $this->getOption( 'outdir', false );
69 foreach ( $this->mArgs as $arg ) {
70 $inPath = realpath( $arg );
71 $inName = basename( $inPath );
72 $inDir = dirname( $inPath );
74 if ( strpos( $inName, '.min.' ) !== false ) {
75 $this->error( "Skipping $inName\n" );
76 continue;
79 if ( !file_exists( $inPath ) ) {
80 $this->error( "File does not exist: $arg", true );
83 $extension = $this->getExtension( $inName );
84 $outName = substr( $inName, 0, -strlen( $extension ) ) . 'min.' . $extension;
85 if ( $outDir === false ) {
86 $outPath = $inDir . '/' . $outName;
87 } else {
88 $outPath = $outDir . '/' . $outName;
91 $this->minify( $inPath, $outPath );
95 public function getExtension( $fileName ) {
96 $dotPos = strrpos( $fileName, '.' );
97 if ( $dotPos === false ) {
98 $this->error( "No file extension, cannot determine type: $fileName" );
99 exit( 1 );
102 return substr( $fileName, $dotPos + 1 );
105 public function minify( $inPath, $outPath ) {
106 $extension = $this->getExtension( $inPath );
107 $this->output( basename( $inPath ) . ' -> ' . basename( $outPath ) . '...' );
109 $inText = file_get_contents( $inPath );
110 if ( $inText === false ) {
111 $this->error( "Unable to open file $inPath for reading." );
112 exit( 1 );
114 $outFile = fopen( $outPath, 'w' );
115 if ( !$outFile ) {
116 $this->error( "Unable to open file $outPath for writing." );
117 exit( 1 );
120 switch ( $extension ) {
121 case 'js':
122 $outText = JavaScriptMinifier::minify( $inText );
123 break;
124 case 'css':
125 $outText = CSSMin::minify( $inText );
126 break;
127 default:
128 $this->error( "No minifier defined for extension \"$extension\"" );
131 fwrite( $outFile, $outText );
132 fclose( $outFile );
133 $this->output( " ok\n" );
137 $maintClass = 'MinifyScript';
138 require_once RUN_MAINTENANCE_IF_MAIN;