public function __construct() {
parent::__construct();
- $this->addOption( 'outfile',
- 'File for output. Only a single file may be specified for input.',
+ $this->addOption( 'outfile',
+ 'File for output. Only a single file may be specified for input.',
false, true );
$this->addOption( 'outdir',
- "Directory for output. If this is not specified, and neither is --outfile, then the\n" .
+ "Directory for output. If this is not specified, and neither is --outfile, then the\n" .
"output files will be sent to the same directories as the input files.",
false, true );
$this->mDescription = "Minify a file or set of files.\n\n" .
- "If --outfile is not specified, then the output file names will have a .min extension\n" .
+ "If --outfile is not specified, then the output file names will have a .min extension\n" .
"added, e.g. jquery.js -> jquery.min.js.";
}
$inDir = dirname( $inPath );
if ( strpos( $inName, '.min.' ) !== false ) {
- echo "Skipping $inName\n";
+ $this->error( "Skipping $inName\n" );
continue;
}
if ( !file_exists( $inPath ) ) {
- $this->error( "File does not exist: $arg" );
- exit( 1 );
+ $this->error( "File does not exist: $arg", true );
}
$extension = $this->getExtension( $inName );
public function minify( $inPath, $outPath ) {
$extension = $this->getExtension( $inPath );
- echo basename( $inPath ) . ' -> ' . basename( $outPath ) . '...';
+ $this->output( basename( $inPath ) . ' -> ' . basename( $outPath ) . '...' );
$inText = file_get_contents( $inPath );
if ( $inText === false ) {
case 'js':
$outText = JSMin::minify( $inText );
break;
+ case 'css':
+ $outText = CSSMin::minify( $inText );
+ break;
default:
$this->error( "No minifier defined for extension \"$extension\"" );
}
fwrite( $outFile, $outText );
fclose( $outFile );
- echo " ok\n";
+ $this->output( " ok\n" );
}
}