diff --git a/index.js b/index.js index ba25ec5..aea2482 100644 --- a/index.js +++ b/index.js @@ -37,23 +37,14 @@ var gulpSass = function gulpSass(options, sync) { opts = assign({}, options); opts.data = file.contents.toString(); + // we set the file path here so that libsass can correctly resolve import paths + opts.file = file.path; + // Ensure `indentedSyntax` is true if a `.sass` file if (path.extname(file.path) === '.sass') { opts.indentedSyntax = true; } - // Ensure file's parent directory in the include path - if (opts.includePaths) { - if (typeof opts.includePaths === 'string') { - opts.includePaths = [opts.includePaths]; - } - } - else { - opts.includePaths = []; - } - - opts.includePaths.unshift(path.dirname(file.path)); - // Generate Source Maps if plugin source-map present if (file.sourceMap) { opts.sourceMap = file.path; @@ -69,35 +60,33 @@ var gulpSass = function gulpSass(options, sync) { sassMapFile, sassFileSrc, sassFileSrcPath, - sourceFileIndex, - filteredSources; + sourceFileIndex; // Build Source Maps! if (sassObj.map) { // Transform map into JSON sassMap = JSON.parse(sassObj.map.toString()); // Grab the stdout and transform it into stdin - sassMapFile = sassMap.file.replace('stdout', 'stdin'); + sassMapFile = sassMap.file.replace(/^stdout$/, 'stdin'); // Grab the base file name that's being worked on sassFileSrc = file.relative; // Grab the path portion of the file that's being worked on sassFileSrcPath = path.dirname(sassFileSrc); if (sassFileSrcPath) { //Prepend the path to all files in the sources array except the file that's being worked on - for (sourceFileIndex = 0; sourceFileIndex < sassMap.sources.length; sourceFileIndex++) { - if (sourceFileIndex !== sassMap.sources.indexOf(sassMapFile)) { - sassMap.sources[sourceFileIndex] = path.join(sassFileSrcPath, sassMap.sources[sourceFileIndex]); - } - } + sourceFileIndex = sassMap.sources.indexOf(sassMapFile); + sassMap.sources = sassMap.sources.map(function(source, index) { + return (index === sourceFileIndex) ? source : path.join(sassFileSrcPath, source); + }); } + // Remove 'stdin' from souces and replace with filenames! - filteredSources = sassMap.sources.filter(function(src) { - if (src.indexOf('stdin') === -1) { + sassMap.sources = sassMap.sources.filter(function(src) { + if (src !== 'stdin') { return src; } }); - sassMap.sources = filteredSources; - sassMap.sources.unshift(sassFileSrc); + // Replace the map file with the original file name (but new extension) sassMap.file = gutil.replaceExtension(sassFileSrc, '.css'); // Apply the map