fyr
fyr

Reputation: 20859

How to use platform architecture in Maven to determine dependency?

As the question states is there a nice way to use dependencies based on the platform architecture while building maven artefacts. I know about profiles and how to use them. For this special purpose i dont want to incorporate them into my build.

The problem in detail could be described as follows:

Solutions which i do not want to use in the settings:

As an example:

Person1

Person2

Continous integration

Edit about Profiles

I know that profiles are one solution to do this. But what i want to achieve is that you checkout your project from some random source version control and build a project with native libraries out of the box without doing anything (as long as the platform meets the requirement of the configured ones).

I do not want to configure these profile settings nor i want to run a specific target explicitally. If there is such thing with profiles i would like to see an example which determines automatically the platform architecture and runs a target. IF there is one without profiles i would prefer it because it is much less complex while having different existent combinations of profiles(including tests and other usecases).

Having solely profiles feels a little bloated to me and manual efforts are required.

I hope someone has a neat suggestion because im somehow stuck on this.

Upvotes: 19

Views: 16702

Answers (2)

Michael-O
Michael-O

Reputation: 18405

What is the problem with using profiles? They have been made exactly for such a situation. You can specify the profile action by OS/platform and add the dependency. Completely transparent.

The other way would be to move your core lib to a separate module and have a module for each platform.

Upvotes: 1

Ryan Gross
Ryan Gross

Reputation: 6515

I don't know of any way to do this without profiles. This is the main use case for which profiles were added to maven. You can do it using the following:

<profiles>
  <profile>
    <activation>
      <os>
        <name>Windows XP</name>
        <family>Windows</family>
        <arch>x86</arch>
      </os>
    </activation>
    ...
  </profile>
  <profile>
    <activation>
      <os>
        <family>Linux</family>
        <arch>x64</arch>
      </os>
    </activation>
    ...
  </profile>
  <profile>
    <activation>
      <property>
         <name>integration-test</name>
      </property>
    </activation>
    ...
  </profile>
</profiles>

Then, when someone checks out a project and builds it on a Linux x64 machine, they will automatically get everything under the Linux x64 profile. If they also provided the property -Dintegration-test on the command line, they would activate the integration-test profile as well. You can have any number of active profiles, which are combined to create the effective POM for the build. These profiles can be defined in a shared parent POM for all projects that you work on, so developers don't have to change their settings.xml files.

To get more info on the activation of profiles, check out: http://maven.apache.org/guides/introduction/introduction-to-profiles.html.

Upvotes: 26

Related Questions