SublimeOnSaveBuild et les partials Sass

Accueil Tags Recherche

23 Février 2015

SublimeOnSaveBuild et les partials Sass

Comment éviter que le plugin SublimeOnSaveBuild compile les partials SASS (ou LESS) ?

Le problème

Si vous travaillez avec SASS, vous utilisez probablement un fichier principal et de nombreux partials, afin de n’avoir qu’un seul fichier CSS à inclure au final (ci-dessous un exemple) :

// app.scss
@import "variable";
@import "layout";
@import "ie6";
@import "ie7";
@import "rtl";

Vous avez paramétré Sublime Text pour qu’il compile le code SASS automatiquement lorsque vous enregistrez votre fichier app.scss (si vous ne l’avez toujours pas fait, voici la procédure). Oui mais voilà, le build se fait aussi quand vous enregistrez le fichier _variables.scss, et vous vous retrouvez systématiquement avec de nombreux fichiers type variables.css et variables.min.css dont vous ne vous servez pas, et que vous devez supprimer manuellement.

Paramétrer SublimeOnSaveBuild

Pour éviter de lancer les builds sur les partials (c’est-à-dire, sur les fichiers commençant par un underscore _), il faut allez changer les préférences du package SublimeOnSaveBuild. Pour ce faire, rendez-vous dans Preferences > Package Settings > SublimeOnSaveBuild > Settings - User. Une fois le fichier ouvert, collez-y ce bout de code :

{
  "filename_filter": "(/|\\\\|^)(?!_)(\\w+)\\.(css|js|sass|less|scss)$",
  "build_on_save": 1
}

Ceci permet d’ajouter un filtre sur le nom du fichier. Si ce dernier ne correspond pas à notre regex, le build n’est pas lancé. Concernant la regex, elle vérifie que :

  • (/|\\\\|^) : on est en début de chaîne, ou juste après un / ou un \
  • (?!_) le premier caractère n’est pas un _
  • (\\w+)\\.(css|js|sass|less|scss)$ : la fin de chaîne est un nom de fichier suivi par une des extensions autorisées

And voilà ! Dans notre exemple, seul le fichier app.scss sera compilé.

Liens

Sublime Text 3 SublimeOnSaveBuild