diff --git a/docs/index.html b/docs/index.html index 40ffa27..56cd586 100644 --- a/docs/index.html +++ b/docs/index.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Meyvn @@ -209,27 +209,27 @@

Meyvn

Table of Contents

-
-

Intro

-
+
+

Intro

+

You Know Nothing, Jon Snow. — Ygritte @@ -260,9 +260,9 @@

Intro

-
-

Goals

-
+
+

Goals

+
  • Use deps.edn as single source of truth.
  • @@ -281,37 +281,37 @@

    Goals

-
-

Installation

-
+
+

Installation

+
  • Meyvn requires Maven. Interestingly, Meyvn does not require Clojure. Neither a Clojure installation nor the official CLI tools. This is because Meyvn relies on Maven for pulling core dependencies (it's turtles all the way down). If you do have Clojure installed, you can install Meyvn with our easy installer. Otherwise, please follow the manual installation instructions.
-
-

Easy installation

-
+
+

Easy installation

+

Copy and paste the following command in your terminal:

-
clj -Sdeps '{:deps {org.meyvn/meyvn-installer {:mvn/version "1.4.9"}}}' -m meyvn-installer.core
+
clj -Sdeps '{:deps {org.meyvn/meyvn-installer {:mvn/version "1.5.0"}}}' -M -m meyvn-installer.core
 
-
-

Manual installation

-
+
+

Manual installation

+
  • Download Meyvn to your local repository
-
mvn org.apache.maven.plugins:maven-dependency-plugin:3.2.0:get -DremoteRepositories=https://nexus.tuppu.net/repository/meyvn/ -Dartifact=org.meyvn:meyvn:1.7.2
+
mvn org.apache.maven.plugins:maven-dependency-plugin:3.2.0:get -DremoteRepositories=https://nexus.tuppu.net/repository/meyvn/ -Dartifact=org.meyvn:meyvn:1.7.3
 
@@ -331,7 +331,7 @@

Manual installation

$ cat /usr/local/bin/myvn
 #!/bin/sh
-M2_HOME=/path/to/maven/root java -jar ~/.m2/repository/org/meyvn/meyvn/1.7.2/meyvn-1.7.2.jar "$@"
+M2_HOME=/path/to/maven/root java -jar ~/.m2/repository/org/meyvn/meyvn/1.7.3/meyvn-1.7.3.jar "$@"
 
@@ -386,9 +386,9 @@

Manual installation

-
-

Usage

-
+
+

Usage

+

The standard Maven lifecycle phases and goals are passed as arguments. There’s documentation, too.

@@ -428,9 +428,9 @@

Usage

-
-

Debugging the build

-
+
+

Debugging the build

+

If you see errors with the build, run myvn -x pom. This will persist Meyvn’s pom file. You can now run mvn on it and debug as you normally would in Maven. You will need to specify the path to the pom file.

@@ -442,9 +442,9 @@

Debugging the build

-
-

Configuration

-
+
+

Configuration

+

Configuration is stored in meyvn.edn, which will be created in the root of your project on first run.

@@ -489,9 +489,9 @@

Configuration

-
-

How does it work?

-
+
+

How does it work?

+

tools.deps has the ability to translate a deps.edn file into a pom file (clj -Spom). Meyvn starts off from that pom file and augments it with features that make sense for Clojure workflows. Meyvn’s pom file is transient and does not interfere with POM files that may already be present in your project.

@@ -670,9 +670,9 @@

How does it work?

-
-

Uberjars

-
+
+

Uberjars

+

Consider the following deps.edn file:

@@ -732,9 +732,9 @@

Uberjars

-
-

Regular jars

-
+
+

Regular jars

+

Libraries uploaded to Clojars are typically non-aot, source-only jars. Uploading to Clojars follows standard procedure. Private repositories are supported as well. For example, to upload an artifact to deps.co, adjust the remote repository setting in the jar section of meyvn.edn. @@ -752,9 +752,9 @@

Regular jars

-
-

Pom files

-
+
+

Pom files

+

Meyvn works with its own set of pom files. It isn’t bothered with existing pom files in your project directory. This is by design. The single source of truth is deps.edn. Together with the configuration (in meyvn.edn), it knows all that it needs to know.

@@ -765,9 +765,9 @@

Pom files

-
-

Dependency mechanism

-
+
+

Dependency mechanism

+

The transitive dependency mechanism used by Maven is guided by the nearest wins conflict resolution strategy. This allows for resolution of individual conflicts: for any particular conflicting dependency, you can specify its version within your own POM, and that version becomes the nearest. @@ -785,9 +785,9 @@

Dependency mechanism

-
-

Testing

-
+
+

Testing

+

Consider the following deps.edn file.

@@ -830,9 +830,9 @@

Testing

-
-

Interactive coding

-
+
+

Interactive coding

+
$ myvn -a nrepl
 
@@ -844,9 +844,9 @@

Interactive coding

-
-

Profiles

-
+
+

Profiles

+

In Maven, profiles are used to parameterize builds, not the runtime environment of the executable. There are good reasons for this, but this means that after your build is done, you can't just run the executable (if it needs environment variables to be set). First you need to make sure the environment is set up properly.

@@ -905,9 +905,9 @@

Profiles

-
-

Auxiliary commands

-
+
+

Auxiliary commands

+

Meyvn runs with the same interface as Maven. Goals and lifecycle phases are being passed to it as you would with standard Maven. The -x flag changes the mode of operation and allows you to run specialized tasks. @@ -920,9 +920,9 @@

Auxiliary commands

-
-

Will it work?

-
+
+

Will it work?

+

It should work for the typical Clojure workflows. Please feel free to contact me in private if you want help solving your company’s build workflow.

@@ -937,9 +937,9 @@

Will it work?

-
-

Roadmap

-
+
+

Roadmap

+

The takeaway for Meyvn is that building on top of the Maven ecosystem is rewarding. It is a huge ecosystem, well documented and extremely mature. A lot of functionality just sits there, waiting to be tapped by our tooling (in areas such as continuous integration, generated documentation, testing, reporting, etc.)

@@ -950,18 +950,18 @@

Roadmap

-
-

What about Boot and Leiningen?

-
+
+

What about Boot and Leiningen?

+

Boot and Leiningen can also produce artifacts, and they also provide development-time workflows and extension mechanisms. They are fine, too. In other words, there is no competition, only complementary options.

-
-

Sustainable open source

-
+
+

Sustainable open source

+

We as a community know how to write open source software, but we are less knowledgeable in how to make that activity sustainable. With Meyvn, I’m attempting to lead a sustainable Open Source project. That means that Meyvn is dual licensed, with a commercial license available for sale.

@@ -976,9 +976,9 @@

Sustainable open source

-
-

License

-
+
+

License

+

Meyvn is released under a dual licensing scheme.

@@ -1001,18 +1001,18 @@

License

-
-

Patron

-
+
+

Patron

+

Writing and maintaining Open Source Software takes time and effort. Be a mensch. Be a maven. Patronize Meyvn.

-
-

Literature

-
+
+

Literature

+

Author: Daniel Szmulewicz

-

Created: 2024-04-08 Mon 03:00

+

Created: 2024-04-08 Mon 03:37

Validate

diff --git a/docs/index.org b/docs/index.org index 1b4288c..ca94cce 100644 --- a/docs/index.org +++ b/docs/index.org @@ -49,7 +49,7 @@ Finally, Meyvn offers fully fleshed quick-start templates covering general Cloju Copy and paste the following command in your terminal: #+begin_src sh -clj -Sdeps '{:deps {org.meyvn/meyvn-installer {:mvn/version "1.4.9"}}}' -m meyvn-installer.core +clj -Sdeps '{:deps {org.meyvn/meyvn-installer {:mvn/version "1.5.0"}}}' -M -m meyvn-installer.core #+end_src ** Manual installation @@ -57,7 +57,7 @@ clj -Sdeps '{:deps {org.meyvn/meyvn-installer {:mvn/version "1.4.9"}}}' -m meyvn - Download Meyvn to your local repository #+begin_src shell -mvn org.apache.maven.plugins:maven-dependency-plugin:3.2.0:get -DremoteRepositories=https://nexus.tuppu.net/repository/meyvn/ -Dartifact=org.meyvn:meyvn:1.7.2 +mvn org.apache.maven.plugins:maven-dependency-plugin:3.2.0:get -DremoteRepositories=https://nexus.tuppu.net/repository/meyvn/ -Dartifact=org.meyvn:meyvn:1.7.3 #+end_src - Create a new shell script in your path. @@ -71,7 +71,7 @@ $ touch /usr/local/bin/myvn #+BEGIN_SRC sh $ cat /usr/local/bin/myvn #!/bin/sh -M2_HOME=/path/to/maven/root java -jar ~/.m2/repository/org/meyvn/meyvn/1.7.2/meyvn-1.7.2.jar "$@" +M2_HOME=/path/to/maven/root java -jar ~/.m2/repository/org/meyvn/meyvn/1.7.3/meyvn-1.7.3.jar "$@" #+END_SRC ~M2_HOME~ points to the root of your Maven installation directory, replace the content with the prefix appropriate for your system.