Commit 7b4075d5 by Timothée Peignier

improve less and sass compilers

parent 8fcaffdb
...@@ -112,6 +112,6 @@ A custom compiler for a imaginary compiler called jam :: ...@@ -112,6 +112,6 @@ A custom compiler for a imaginary compiler called jam ::
def match_file(self, filename): def match_file(self, filename):
return path.endswith('.jam') return path.endswith('.jam')
def compile_file(self, content): def compile_file(self, content, path):
return jam.compile(content) return jam.compile(content)
...@@ -22,7 +22,7 @@ class Compiler(object): ...@@ -22,7 +22,7 @@ class Compiler(object):
new_path = self.output_path(path, compiler.output_extension) new_path = self.output_path(path, compiler.output_extension)
content = self.read_file(path) content = self.read_file(path)
try: try:
compiled_content = compiler.compile_file(content) compiled_content = compiler.compile_file(content, storage.path(path))
self.save_file(new_path, compiled_content) self.save_file(new_path, compiled_content)
except CompilerError: except CompilerError:
if not storage.exists(new_path) or not settings.PIPELINE: if not storage.exists(new_path) or not settings.PIPELINE:
...@@ -53,7 +53,7 @@ class CompilerBase(object): ...@@ -53,7 +53,7 @@ class CompilerBase(object):
def match_file(self, filename): def match_file(self, filename):
raise NotImplementedError raise NotImplementedError
def compile_file(self, content): def compile_file(self, content, path):
raise NotImplementedError raise NotImplementedError
def save_file(self, path, content): def save_file(self, path, content):
...@@ -68,11 +68,13 @@ class CompilerError(Exception): ...@@ -68,11 +68,13 @@ class CompilerError(Exception):
class SubProcessCompiler(CompilerBase): class SubProcessCompiler(CompilerBase):
def execute_command(self, command, content): def execute_command(self, command, content=None):
pipe = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE, pipe = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE,
stdin=subprocess.PIPE, stderr=subprocess.PIPE) stdin=subprocess.PIPE, stderr=subprocess.PIPE)
pipe.stdin.write(content)
pipe.stdin.close() if content:
pipe.stdin.write(content)
pipe.stdin.close()
compressed_content = pipe.stdout.read() compressed_content = pipe.stdout.read()
pipe.stdout.close() pipe.stdout.close()
......
...@@ -8,6 +8,9 @@ class CoffeeScriptCompiler(SubProcessCompiler): ...@@ -8,6 +8,9 @@ class CoffeeScriptCompiler(SubProcessCompiler):
def match_file(self, path): def match_file(self, path):
return path.endswith('.coffee') return path.endswith('.coffee')
def compile_file(self, content): def compile_file(self, content, path):
command = "%s -sc %s" % (settings.PIPELINE_COFFEE_SCRIPT_BINARY, settings.PIPELINE_COFFEE_SCRIPT_ARGUMENTS) command = "%s -sc %s" % (
settings.PIPELINE_COFFEE_SCRIPT_BINARY,
settings.PIPELINE_COFFEE_SCRIPT_ARGUMENTS
)
return self.execute_command(command, content) return self.execute_command(command, content)
import os
import tempfile
from pipeline.conf import settings from pipeline.conf import settings
from pipeline.compilers import SubProcessCompiler from pipeline.compilers import SubProcessCompiler
...@@ -11,20 +8,11 @@ class LessCompiler(SubProcessCompiler): ...@@ -11,20 +8,11 @@ class LessCompiler(SubProcessCompiler):
def match_file(self, filename): def match_file(self, filename):
return filename.endswith('.less') return filename.endswith('.less')
def compile_file(self, content): def compile_file(self, content, path):
in_file, in_filename = tempfile.mkstemp()
in_file = os.fdopen(in_file, 'w+b')
in_file.write(content)
in_file.flush()
command = '%s %s %s' % ( command = '%s %s %s' % (
settings.PIPELINE_LESS_BINARY, settings.PIPELINE_LESS_BINARY,
settings.PIPELINE_LESS_ARGUMENTS, settings.PIPELINE_LESS_ARGUMENTS,
in_filename path
) )
content = self.execute_command(command, content) content = self.execute_command(command)
in_file.close()
os.remove(in_filename)
return content return content
...@@ -8,8 +8,10 @@ class SASSCompiler(SubProcessCompiler): ...@@ -8,8 +8,10 @@ class SASSCompiler(SubProcessCompiler):
def match_file(self, filename): def match_file(self, filename):
return filename.endswith('.scss') return filename.endswith('.scss')
def compile_file(self, content): def compile_file(self, content, path):
command = "%s --scss %s" % (settings.PIPELINE_SASS_BINARY, settings.PIPELINE_SASS_ARGUMENTS) command = "%s --scss %s %s" % (
if self.verbose: settings.PIPELINE_SASS_BINARY,
command += '--verbose' settings.PIPELINE_SASS_ARGUMENTS,
return self.execute_command(command, content) path
)
return self.execute_command(command)
...@@ -10,7 +10,7 @@ class DummyCompiler(CompilerBase): ...@@ -10,7 +10,7 @@ class DummyCompiler(CompilerBase):
def match_file(self, path): def match_file(self, path):
return path.endswith('.coffee') return path.endswith('.coffee')
def compile_file(self, content): def compile_file(self, content, path):
return content return content
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment