В файле Assetic не существует ошибки, хотя ссылки на файл больше нет?

1

У меня есть файл main.less, который я создал в прошлом. Я удалил его, потому что мне он больше не нужен, но теперь я получаю следующую ошибку, когда пытаюсь запустить bin/console assetic:watch

[error] The source file "/home/distribution/public_html/distribution.tech/app/../web/bundles/app/less/main.less" does not exist.

или bin/console assetic:dump независимо от используемой среды.

 [RuntimeException]                                                                                                        
  The source file "/home/distribution/public_html/distribution.tech/app/../web/bundles/app/less/main.less" does not exist. 

Моя текущая подпрограмма, которая работала до тех пор, пока я это сделал, заключалась в создании файла сценария оболочки, который выполняет следующие команды:

chown -R distribution:distribution .
rm -rf var/cache/dev/*
rm -rf var/cache/prod/*
rm -rf web/css/*
rm -rf web/js/*
bin/console cache:clear --env=dev
bin/console cache:clear --env=prod --no-debug
bin/console assets:install web --symlink --relative
bin/console assetic:dump --env=dev --verbose
bin/console assetic:dump --env=prod --no-debug
bin/console assetic:watch
bin/console doctrine:schema:update --force --dump-sql
bin/console doctrine:schema:update --force --dump-sql --env=prod
chown -R distribution:distribution .
bin/console server:run

Я всегда запускаю его как root, чтобы убедиться, что все будет работать, однако файлы принадлежат распределению пользователей.

Единственный файл, который ссылается на файлы less и javascript, - это...

base.html.twig

{% spaceless %}
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8" />
        <title>{% block title %}Welcome!{% endblock %}</title>
        {% block stylesheets %}
            {% stylesheets 'bundles/skeleton/less/main.less' filter='less' filter='uglifycss' filter='cssrewrite' output='css/compiled-main.css' %}
                <link rel="stylesheet" href="{{ asset_url }}" />
            {% endstylesheets %}
        {% endblock %}
        <link rel="icon" type="image/x-icon" href="{{ asset('favicon.ico') }}" />
    </head>
    <body>
        {% block body %}{% endblock %}
        {% block javascripts %}
            {% javascripts 
             '@SkeletonBundle/Resources/public/js/*' 
             '@AppBundle/Resources/public/js/*'
              filter='uglifyjs2' 
              output='js/js-compiled.js' 
            %}
                <script src="https://code.jquery.com/jquery-2.2.0.min.js"></script>
                <script src="{{ asset_url }}"</script>
            {% endjavascripts %}
        {% endblock %}
    </body>
</html>
{% endspaceless %}

Структура моего каталога выглядит ниже прямо из моего FTP

Изображение 174551

Вы заметите, что main.less теперь находится в комплекте скелета вместо пакета приложений. Я переместил его здесь, но по какой-то причине он думает, что он все еще в комплекте приложений вместо скелетного пакета?

Как исправить эту ошибку?

Дополнительная информация:

Когда я запустил подробный след ошибки, я получил это с активностью: дамп

Dumping all dev assets.
Debug mode is on.

03:37:43 [file+] /home/distribution/public_html/distribution.tech/app/../web/css/compiled-main.css
        /home/distribution/public_html/distribution.tech/app/../web/bundles/skeleton/less/main.less
03:37:43 [file+] /home/distribution/public_html/distribution.tech/app/../web/css/compiled-main_main_1.css
        /home/distribution/public_html/distribution.tech/app/../web/bundles/skeleton/less/main.less
03:37:44 [file+] /home/distribution/public_html/distribution.tech/app/../web/js/js-compiled.js
        /home/distribution/public_html/distribution.tech/src/SkeletonBundle/Resources/public/js/shared.js
        /home/distribution/public_html/distribution.tech/src/AppBundle/Resources/public/js/app.js
03:37:44 [file+] /home/distribution/public_html/distribution.tech/app/../web/js/js-compiled_part_1_shared_1.js
        /home/distribution/public_html/distribution.tech/src/SkeletonBundle/Resources/public/js/shared.js
03:37:45 [file+] /home/distribution/public_html/distribution.tech/app/../web/js/js-compiled_part_2_app_1.js
        /home/distribution/public_html/distribution.tech/src/AppBundle/Resources/public/js/app.js
03:37:45 [file+] /home/distribution/public_html/distribution.tech/app/../web/css/compiled-main.css
        /home/distribution/public_html/distribution.tech/app/../web/bundles/app/less/main.less


  [RuntimeException]                                                                                                        
  The source file "/home/distribution/public_html/distribution.tech/app/../web/bundles/app/less/main.less" does not exist.  


Exception trace:
 () at /home/distribution/public_html/distribution.tech/vendor/kriswallsmith/assetic/src/Assetic/Asset/FileAsset.php:62
 Assetic\Asset\FileAsset->load() at /home/distribution/public_html/distribution.tech/vendor/kriswallsmith/assetic/src/Assetic/Asset/BaseAsset.php:103
 Assetic\Asset\BaseAsset->dump() at /home/distribution/public_html/distribution.tech/vendor/kriswallsmith/assetic/src/Assetic/Asset/AssetCollection.php:151
 Assetic\Asset\AssetCollection->dump() at /home/distribution/public_html/distribution.tech/vendor/symfony/assetic-bundle/Command/AbstractCommand.php:119
 Symfony\Bundle\AsseticBundle\Command\AbstractCommand->doDump() at /home/distribution/public_html/distribution.tech/vendor/symfony/assetic-bundle/Command/AbstractCommand.php:51
 Symfony\Bundle\AsseticBundle\Command\AbstractCommand->dumpAsset() at /home/distribution/public_html/distribution.tech/vendor/symfony/assetic-bundle/Command/DumpCommand.php:118
 Symfony\Bundle\AsseticBundle\Command\DumpCommand->execute() at /home/distribution/public_html/distribution.tech/vendor/symfony/symfony/src/Symfony/Component/Console/Command/Command.php:256
 Symfony\Component\Console\Command\Command->run() at /home/distribution/public_html/distribution.tech/vendor/symfony/symfony/src/Symfony/Component/Console/Application.php:803
 Symfony\Component\Console\Application->doRunCommand() at /home/distribution/public_html/distribution.tech/vendor/symfony/symfony/src/Symfony/Component/Console/Application.php:186
 Symfony\Component\Console\Application->doRun() at /home/distribution/public_html/distribution.tech/vendor/symfony/symfony/src/Symfony/Bundle/FrameworkBundle/Console/Application.php:86
 Symfony\Bundle\FrameworkBundle\Console\Application->doRun() at /home/distribution/public_html/distribution.tech/vendor/symfony/symfony/src/Symfony/Component/Console/Application.php:117
 Symfony\Component\Console\Application->run() at /home/distribution/public_html/distribution.tech/bin/console:29

assetic:dump [--forks FORKS] [--watch] [--force] [--period PERIOD] [-h|--help] [-q|--quiet] [-v|vv|vvv|--verbose] [-V|--version] [--ansi] [--no-ansi] [-n|--no-interaction] [-e|--env ENV] [--no-debug] [--] <command> [<write_to>]

Настройки конфигурации Config.yml:

assetic:
    debug:          '%kernel.debug%'
    use_controller: '%kernel.debug%'
    filters:
        cssrewrite: ~
        uglifyjs2:
            # the path to the uglifyjs executable
            bin: /usr/bin/uglifyjs
        uglifycss:
            bin: /usr/bin/uglifycss
        less: 
            node_paths: [/usr/local/lib/node_modules/]
            bin: /usr/bin/less

Main.less в комплекте скелета

/* Global Variables */
@logo: "../images/logo-hires-opt.png";

/* Fonts */
@font-face {
    font-family: 'ProximaNova';
    src: url('../fonts/proximanova-regular-webfont.ttf');
}
@font-face {
    font-family: 'ProximaNovaAltBold';
    src: url('../fonts/proxima_nova_alt_bold-webfont.ttf');
}

.withfont{font-family:ProximaNova;color:blue;background:url('../images/background.jpg');}

@import "shared.less";
@import "header.less";
@import "footer.less";

Файл Admin.less в appBundle

.test{color:red}

admin.html.twig

{% extends 'SkeletonBundle::base.html.twig' %}

{% block body %}
    <div id="wrapper">
        <div id="container">
            <div class="withfont">admin page</div>
            <div>admin page without <span class="test">fonts</span></div>
        </div>
    </div>
{% endblock %}
Теги:
caching
symfony-console
assetic

2 ответа

0
Лучший ответ

Хорошо, оказывается, что у моего редактора была старая версия, открытая для base.html.twig которая ссылалась на более base.html.twig местоположение, поэтому, когда она отправилась на визуализацию, она не могла найти ее... Я не уверен, как я не заметил это, но ошибка действительно была связана с файлом, который на самом деле не существует.

Ошибка в этой команде

{% stylesheets 'bundles/skeleton/less/main.less' filter='less' filter='uglifycss' filter='cssrewrite' output='css/compiled-main.css' %}
                <link rel="stylesheet" href="{{ asset_url }}" />
            {% endstylesheets %}

странная часть, я бы поклялся, что я удалил старый файл base.html.twig, но после некоторых настроек он волшебным образом появился, и я думаю, что это связано с моим редактором и тем, как он сохраняет, поскольку я перемещал файлы и сохранял редактор открыт одновременно.

2

В моем случае был необходим ясный кеш...

php bin/console cache:clear --env=dev

Я искал это имя файла (как строку) всего проекта ctrl+shift+f в phpstorm, и он нашел файл где-то в каталоге кеша... Может быть, если вы удалите строку из кэшированного файла, этого будет достаточно... но очистить все кеш я мой случай 100% успех

Ещё вопросы

Сообщество Overcoder
Наверх
Меню