Skip to content

Commit

Permalink
PLUGINS.md: Clarify some things
Browse files Browse the repository at this point in the history
While trying to develop a Leiningen plugin I stumbled over two small
things, which I think make other people stumble as well:

 - Adding the path to my plugin's src directory to .lein-classpath
   didn't help anything. Leiningen still loaded the coded that I had
   installed to the Maven repository and ignored the local changes.
   Putting :provided or :resolve or :classpath after the plugin
   coordinates as suggested in issue technomancy#750 didn't help either. After
   banging my head against this, I got the idea to remove the plugin
   entry completely and it worked. Not sure if this is the intended
   behaviour, though. Add a step-by-step guide to getting what you want
   anyway.

 - It wasn't at all clear to me how to do the subtasks thing. The
   sentence about the :subtask metadata is a bit garbled and I thought
   there might be a mechanisms that invokes subtasks for me. I couldn't
   find anything about that, though. A quick search took me to
   https://github.com/devth/lein-worker/blob/master/src/leiningen/worker.clj,
   which showed the relevant bits. Add an example, because that's what
   people understand.

Discussion:

 - The new place of the paragraph for emitting output is not very good,
   but it's better than leaving it at the bottom of the newly expanded
   local development section, where nobody would see it.

 - Renaming "Documentation" to "Documentation and subtasks" is a rather
   thin patch. – Instructions on how to invoke subtasks don't really
   belong in a section about documentation. – However, I'm too lazy to
   do a lot of restructuring and I think people will still find what
   they're looking for.
  • Loading branch information
rmoehn committed Jul 26, 2015
1 parent d5ed76a commit c096c5f
Showing 1 changed file with 43 additions and 15 deletions.
58 changes: 43 additions & 15 deletions doc/PLUGINS.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,10 @@ See the `lein-pprint` directory
[in the Leiningen source](https://github.com/technomancy/leiningen/tree/stable/lein-pprint)
for a sample of a very simple plugin.

When emitting output, please use `leiningen.core.main/info`,
`leiningen.core.main/warn`, and `leiningen.core.main/debug` rather than
`println` since these will respect the user's output settings.

### Local development
When you're ready to test your plugin in a separate project you can include it via the following (example a plugin named sample-plugin):

Expand All @@ -52,16 +56,24 @@ After this step completes you can now list your plugin in your separate project

During local development, having to re-run `lein install` in your
plugin project and then switch to a test project can be very
cumbersome. Once you've installed the plugin once, you can avoid this
annoyance by creating a `.lein-classpath` file in your test project
containing the path to the `src` directory of your plugin. If your plugin
depends on another library that you are also working on then that needs
to be added to `.lein-classpath` with the classpath separator, either
`:` for unix, or `;` for Windows.

When emitting output, please use `leiningen.core.main/info`,
`leiningen.core.main/warn`, and `leiningen.core.main/debug` rather than
`println` since these will respect the user's output settings.
cumbersome. In order to avoid this annoyance, you can do the following:

1. If you haven't done it yet, run `lein install` in the plugin's project
directory.
2. Just to make sure, run `lein help <plugin-name>` in your test project
directory. A help message for your plugin should be displayed now. Or an
exception originating in your plugin.
3. Add the path to the `src` directory of your plugin to the file
`.lein-classpath` in your test project directory. Probably you'll have to
create that file.
4. If your plugin depends on another library that you are also working on, then
that needs to be added to `.lein-classpath` with the classpath separator,
either `:` for unix, or `;` for Windows. The same goes for your plugin's
other direct dependencies. Run `lein classpath` in order to get an idea how
the contents of `.lein-classpath` are supposed to look.
5. Remove the entry for your plugin from the test project's `project.clj`.
Otherwise it would override what you've added to `.lein-classpath`, because
Leiningen loads those things before it loads plugins.

### Task Arguments

Expand Down Expand Up @@ -92,7 +104,7 @@ library (IDE integration, etc) may not behave the same way, so for
greatest portability check the `:root` key of the project map and work
from there.

### Documentation
### Documentation and subtasks

The `lein help` task uses docstrings. A namespace-level docstring will
be used as the short summary if present; if not then it will take the
Expand All @@ -111,11 +123,27 @@ Often more complicated tasks get divided up into subtasks. Placing
`:subtasks` metadata on a task defn which contains a vector of subtask
vars will allow `lein help $TASK_CONTAINING_SUBTASKS` to list them.
This list of subtasks will show the first line of the docstring for each
subtask. The full help for a subtask can be viewed via
`lein help $TASK_CONTAINING_SUBTASKS $SUBTASK`.
subtask. The full help for a subtask can be viewed via
`lein help $TASK_CONTAINING_SUBTASKS $SUBTASK`.

Note that Leiningen doesn't have a mechanism for automatically invoking
subtasks. You'll have to do that yourself in the main task. A dumb
implementation of it all might look like this:

```clojure
(defn my-task
"Automatically write all the project's code."
{:subtasks [#'my-subtask-0 #'my-subtask-1]}
[project & [sub-name]]
(case sub-name
"my-subtask-0" (my-subtask-0 project args)
"my-subtask-1" (my-subtask-1 project args)
nil :not-implemented-yet
(leiningen.core.main/warn "Unknown task.")))
```

Leiningen will intercept calls to `lein $MYTASK help` by default and
turn it into `lein help $MYTASK`. If your task provides its own help
turn them into `lein help $MYTASK`. If your task provides its own help
subtask you can add `^:pass-through-help` metadata to your task defn
to opt-out of this behaviour.

Expand Down Expand Up @@ -156,7 +184,7 @@ profile in so users can override your changes if necessary. Use
[project port host & opts]
(let [profile (or (:swank (:profiles project)) swank-profile)
project (project/merge-profiles project [profile])]
(eval-in-project project
(eval-in-project project
`(swank.core/-main ~@opts)
'(require 'swank.core))))
```
Expand Down

0 comments on commit c096c5f

Please sign in to comment.