cstamas commented on code in PR #598:
URL: https://github.com/apache/maven-site/pull/598#discussion_r1894125583


##########
content/markdown/whatsnewinmaven4.md:
##########
@@ -0,0 +1,466 @@
+# What's new in Maven 4?
+
+Maven is over 20 years old and is one of the most used build-tool in the Java 
world.
+Since all the years one important rule was the highest backward-compatibility 
as possible, especially with
+its [POM-schema with Model version 4.0.0][2], used for the build itself, but 
also by consumers.
+This made Maven more than a tool, but a whole ecosystem with a lot of things 
depended on the POM, esp. the Maven Central
+repository, other build tools and IDEs.
+But this stable schema comes at a price - the lack of flexibility.
+
+> "With the Maven build schema preserved in amber, we can’t evolve much: we’ll 
stay forever with Maven 3 minor releases,
+> unable to implement improvements that we imagine will require seriously 
updating the POM schema…"
+> &mdash; <cite>[Hervé Boutemy (in Javaadvent 2021)][1]</cite>
+
+Maven 4 will prepare to changes which are impossible nowadays, like a complete 
new build schema.
+
+Another pain point of Maven 3 is a code base with a lot of deprecated, 
convoluted, non performant and duplicated code
+which costs the volunteers who maintain Maven a lot of time.
+This not only means that the Maven codebases contains old Java code that can 
be optimized nowadays, but also old
+dependencies and bad API design of its own APIs, especially for Maven plugins.
+Therefore, Maven 4 will also be a maintenance release.
+
+This article presents and explains major changes brought by Maven 4, grouped 
into several topics.
+
+## POM-Changes
+
+### Build-POM and Consumer-POM
+
+As written in the introduction the Model version 4.0.0 is used not only for 
the build, but also by consumers of the
+artifact.
+But several contents of the POM are only necessary for the build while others 
like the dependencies are also needed by
+the consumer.
+Maven 4 will therefore differentiate between a "Build-POM" and a 
"Consumer-POM".
+As names suggest the "Build-POM" will contain all information needed for to 
build the artifact, e.g. used plugins and
+their configuration, while the "Consumer-POM", which is created during the 
Maven build, will not contain those.
+This POM will only keep those which are really needed to use the artifact, 
e.g. dependency information.
+
+**Note**: See below for a comparison of the content of both POMs.
+
+### Model version 4.1.0
+
+With now having two types of POM Maven 4 can already make additions to the 
Build-POM as it will only be used by Maven (
+and of course IDEs).
+Therefore, with Maven 4 a new Model version 4.1.0 is introduced.
+This version introduces some new elements and attributes, while others got 
marked as deprecated.
+To not break the ecosystem this version is only available for the Build-POM, 
while the Consumer-POM will still use
+version 4.0.0.
+This means Maven will generate the Consumer-POM during the build.
+
+**Note**: Maven 4 will of course continue to build your model version 4.0.0 
project!
+There is no need to update your POMs to 4.1.0 as long as you don't want to 
make use of the new features.
+But as like every software update - it's suggested to update them to 4.1.0, 
e.g. to avoid problems when deprecated
+things get removed in future updates.
+
+### Modules are now subprojects
+
+From the early days of Maven 1 till today, all build information is stored in 
the POM, short for "Project Object Model".
+Together with build folders and other files the wording "Maven project" is 
used.
+However, project containing multiple parts, e.g. an API and a client, each of 
those parts was called "module" and listed
+in the `<modules>` section of the POM, leading to the terms of "multi-module 
project".
+This wording introduced some inconsistency, especially as projects with any 
`<modules>` section are often called "
+single-module".
+Since the introduction of the [Java Platform Module System][3] in Java 9 the 
term "module" raised additional confusion.
+
+Maven 4 gets rid of this by naming "modules" as what they are - subprojects.
+Model version 4.1.0 contains a new element `<subprojects>`analogous to the now 
deprecated, but still usable, element
+`<modules>`.
+
+**Note**: It's suggested to use the terms `multi-project setup` and 
`single-project setup` to differentiate between a
+Maven project with or without subprojects.
+
+### New packaging type: bom
+
+Maven 4 introduces a dedicated packaging type to provide a [Bill of Material 
BOM][4] called "bom" to differentiate more
+precisely between "parent POMs" and dependency managing BOMs.
+While the new type is only available with model Version 4.1.0 the final 
outcome is a full Maven 3 compatible (model
+4.0.0) POM file!
+For an example see the link above or
+the [live coding by Maven maintainer Karl Heinz Marbaise at IntelliJ IDEA Conf 
2004][5].
+
+**Note**: With Maven 4 it's also possible to exclude dependencies which are 
declared by BOMs using the existing
+`<exclusions>` element.
+Also note that in Maven4 importing BOMs with classifier is now possible.
+Therefore, Maven team suggests that projects BOMs be generated as classified 
artifacts (see Maven build "skinny" vs "

Review Comment:
   So to recap:
   * BOM import should happen only with POMs coming from outside of reactor (in 
other words "you should import only external BOMs").
   * BOM creation does not matter, doing it by hand is fine as well, but 
generating BOMs is much more less error prone, as you "just do the usual maven 
stuff" and generator makes you a BOM out of it. Less typos, less room for 
mistakes. And, it does not becomes "tempting" to import it either :smile:  
Still, due to reason above, "not reusing it within reactor" means you need to 
manually maintain two times same information (once the versions in your build, 
and once in your manually crafted BOM), hence automating the BOM generation 
makes much more sense.
   * The definition of BOM is not enforced, you can still author manually or 
generate whatever kind of BOM you want. We just offered this naming similar to 
shading (skinny vs fat).



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: issues-unsubscr...@maven.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org

Reply via email to