How to run bash script after generating scaladoc using doc task?

前端 未结 2 919
灰色年华
灰色年华 2021-01-13 11:45

I have a short Bash script that does a find-and-replace on my Scaladoc comments in order to generate links to external documentation of a third-party library. I would like t

相关标签:
2条回答
  • 2021-01-13 12:30

    It's actually pretty easy. First, I inspected doc to see what it was (inspect doc on the sbt prompt), noticed it was a task, and proceeded with declaring a dependency on itself on build.sbt:

    doc in Compile <<= doc in Compile map { (file) =>
      Seq("bash", "-c", "ls >tmp.log").! // CWD is sbt's current dir
      file
    }
    

    That thing I used to execute bash is the same library as scala.sys.process, so you can look up Scaladoc for that. This was tested on SBT 0.12.2, and I think there might be a small difference on SBT 0.11.x or 0.10.x.

    0 讨论(0)
  • 2021-01-13 12:40

    In sbt 0.13 and the latest releases the use case can also be achieved with := and .value macros (that are both aimed at being simpler than <<=):

    doc in Compile := {
      val f = (doc in Compile).value
      // execute a shell script if you want with sbt's Process API
      // http://www.scala-sbt.org/0.13/docs/Process.html
      val ec = (baseDirectory.value / "myBashScript.sh").getAbsolutePath !
      val log = streams.value.log
      log.debug(s"Exit code: $ec")
      f
    }
    

    You may also like triggeredBy method for tasks as follows:

    lazy val runMyBashScriptTask = taskKey[Unit]("Run myBashScript")
    
    runMyBashScriptTask := {
      val ec = (baseDirectory.value / "myBashScript.sh").getAbsolutePath !
      val log = streams.value.log
      log.debug(s"Exit code: $ec")
    }
    
    runMyBashScriptTask <<= runMyBashScriptTask triggeredBy (doc in Compile)
    

    It assumes that myBashScript.sh is in the main directory of the project as pointed by baseDirectory setting.

    0 讨论(0)
提交回复
热议问题