2

我有一个我过去创建的名为 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. 

在我这样做之前一直在工作的当前例程是创建一个运行以下命令的 shell 脚本文件:

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

在此处输入图像描述

您会注意到 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";

appBundle 中的 Admin.less 文件

.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 %}
4

2 回答 2

2

在我的情况下是必要的清除缓存...

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

我在phpstorm的整个项目中搜索这个文件名(作为字符串)ctrl+shift+f,他在缓存目录的某个地方找到了文件......也许如果你从缓存文件中删除行就足够了......但是清除所有缓存我的案例100 % 成功

于 2017-08-28T08:11:56.687 回答
0

好的,事实证明我的编辑器打开了一个旧版本,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,但是在做了一些调整之后它神奇地重新出现了,我认为这与我的编辑器以及它如何保存有关,因为我移动了文件并保留了编辑器同时打开。

于 2016-01-18T19:56:59.690 回答