Fix JS asset generation
At some point SeparatorFilter should be included upstream (kriswallsmith/assetic), then lib/private/assetic/separatorfilter.php can be removed and the `use` in lib/private/templatelayout.php rewritten. SeparatorFilter inserts a separator between assets, preventing issues when files are incorrectly terminated. For JS this is a semicolon.remotes/origin/fix-10825
parent
0e17a00b62
commit
2c44bc1768
@ -0,0 +1,57 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* ownCloud
|
||||
*
|
||||
* Copyright (C) 2014 Robin McCorkell <rmccorkell@karoshi.org.uk>
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 3 of the License, or any later version.
|
||||
*
|
||||
* This library 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 AFFERO GENERAL PUBLIC LICENSE for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Affero General Public
|
||||
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace OC\Assetic;
|
||||
|
||||
use Assetic\Filter\FilterInterface;
|
||||
use Assetic\Asset\AssetInterface;
|
||||
|
||||
/**
|
||||
* Inserts a separator between assets to prevent merge failures
|
||||
* e.g. missing semicolon at the end of a JS file
|
||||
*/
|
||||
class SeparatorFilter implements FilterInterface
|
||||
{
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $separator;
|
||||
|
||||
/**
|
||||
* Constructor.
|
||||
*
|
||||
* @param string $separator Separator to use between assets
|
||||
*/
|
||||
public function __construct($separator = ';')
|
||||
{
|
||||
$this->separator = $separator;
|
||||
}
|
||||
|
||||
public function filterLoad(AssetInterface $asset)
|
||||
{
|
||||
}
|
||||
|
||||
public function filterDump(AssetInterface $asset)
|
||||
{
|
||||
$asset->setContent($asset->getContent() . $this->separator);
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue