解決できない問題があります。手動で実行すると簡単にコンパイルできる sass テンプレートがcompass
ありますが、django-pipeline を使用して同じ結果を得ることができません。
私の設定は簡単です。共通assets
アセットへのディレクトリとデプロイ用の静的ディレクトリがあります
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
STATIC_URL = '/static/'
STATICFILES_DIRS = (
('assets', os.path.join(BASE_DIR, "assets")),
)
STATICFILES_STORAGE = 'pipeline.storage.PipelineStorage'
STATICFILES_FINDERS = (
'django.contrib.staticfiles.finders.FileSystemFinder',
'django.contrib.staticfiles.finders.AppDirectoriesFinder',
'pipeline.finders.PipelineFinder',
)
私のパイプライン設定は、これを機能させるためだけに簡単です。
PIPELINE_CSS = {
'public': {
'source_filenames': (
'assets/public/sass/scss/style.scss',
),
'output_filename': 'css/style.css',
'extra_context': {'media': 'all',},
},
}
PIPELINE_JS = {
'vendors': {
'source_filenames': (
# created using manage.py (check django-js-reverse)
'assets/public/js/jquery/jquery-2.1.3.js',
....
),
'output_filename': 'js/vendors.js',
},
}
PIPELINE = {
'PIPELINE_ENABLED': True,
'STYLESHEETS': PIPELINE_CSS,
'JAVASCRIPT': PIPELINE_JS,
'SASS_BINARY': '/usr/bin/env compass',
'SASS_ARGUMENS': '--trace',
'JS_COMPRESSOR': None,
'CSS_COMPRESSOR': None,
'DISABLE_WRAPPER': True,
'COMPILERS': (
'pipeline.compilers.sass.SASSCompiler',
),
}
JS は機能しますjs/vendors.js
が、CSS でエラーが発生します。
pipeline.exceptions.CompilerError: ['/usr/bin/env', 'compass', u'/[..]application/static/assets/public/sass/scss/style.scss', u'/[..]application/static/assets/public/sass/scss/style.css'] exit code 1
Command not found: /[..]application/static/assets/public/sass/scss/style.scss
私が理解していないのは、私が を指していて を正しく指しているときapplication/static/assets
にコンパスが検索を試みる理由です。JS は機能しますが、SASS は機能しません。:-(BASE_DIR
application
STATICFILE_DIRS
assets
何か案が?これを解決する方法を見つけるのに何時間も費やしました。