clojure – Leiningen 2步构建:如何结合lein-less和lein-asset-minifier

我正在制作一个我在Heroku上部署的Clojure / ClojureScript网站.我正在使用Leiningen进行项目管理.

我想在LESS写我的样式表.我需要构建过程将LESS文件编译成CSS,然后缩小这些CSS文件;显然,我不希望生成的CSS文件受版本控制.

LESS文件–lein-less – > CSS文件–lein-asset-minifier – >缩小的CSS文件

我试图用lein-lesslein-asset-minifier Leiningen插件来实现这一点.我的尝试包括以正确的顺序声明leiningen.less和minify-assets.plugin / hooks作为:uberjar任务的钩子(参见下面的代码).但运行lein uberjar失败,出现以下错误:

Uberjar aborting because jar failed: resources/public/css/site.css (No such file or directory)

因此,似乎没有强制执行构建步骤的顺序.

是否可以使用这些Leiningen插件实现这一多步构建?如果没有,人们怎么做呢?

这是我的project.clj的相关部分:

(defproject sncf-cljs "0.1.0-SNAPSHOT"
            ;; ...
            :min-lein-version "2.5.0"
            :source-paths ["src/clj" "src/cljs"]
            :dependencies [
                       ;; ...
                       ]

            :plugins [
                      [lein-cljsbuild "1.0.4"]
                      [lein-environ "1.0.0"]
                      [lein-ring "0.9.1"]

                      [lein-asset-minifier "0.2.2"]
                      [lein-less "1.7.2"]]


            :less {:source-paths ["src/less"]
                   :target-path "resources/public/css"}



            :uberjar-name "sncf-cljs.jar"

            :minify-assets {:assets
                            {"resources/public/css/site.min.css" "resources/public/css/site.css"}}

            :cljsbuild { 
                        ;; ...
                        }

            :profiles {                                 
                       ;; ...

                       :uberjar {:hooks [leiningen.less
                                         leiningen.cljsbuild
                                         minify-assets.plugin/hooks]

                                 :env {:production true}
                                 :aot :all
                                 :omit-source true
                                 :cljsbuild {:jar true
                                             :builds {:app
                                                      {:source-paths ["env/prod/cljs"]
                                                       :compiler
                                                                     {:optimizations :advanced
                                                                      :pretty-print false}}}}}

                       :production {:ring {:open-browser? false
                                           :stacktraces?  false
                                           :auto-reload?  false}
                                    :cljsbuild {:builds {:app {:compiler {:main "sncf-cljs.prod"}}}}
                                }})

最佳答案 我做了一些研究,因为这是一个有趣的问题.所以我环顾四周,找不到如何配置的信息.所以我继续搜索,我找到了这个任务的插件.

https://github.com/kumarshantanu/lein-cascade

github页面上的自述文件应足以解决此任务.

点赞