Skip to content
Java Native Runtime constants
Java Ruby
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Type Name Latest commit message Commit time
Failed to load latest commit information.
.settings Adjusted Eclipse settings Feb 6, 2010
gen protocol family on windows Nov 28, 2018
src protocol family on windows Nov 28, 2018
.classpath Adjusted Eclipse settings Feb 6, 2010
.gitignore Add IDEA files to .gitignore. Sep 12, 2018
.project Added Eclipse/Maven settings Dec 30, 2009
.travis.yml Fix botched "os x" notation. Sep 12, 2018
LICENSE Switch to apache-2.0 license May 22, 2011
Rakefile protocol family on windows Nov 28, 2018
pom.xml [maven-release-plugin] prepare for next development iteration Nov 28, 2018

Java Native Runtime Constants

Build Status


This project contains Java enums for common POSIX constants. It is predominately used to make calls into jnr-posix far simpler.

Adding Constants

If you want to add new constants to the project, note that all the Java source code is generated. The gen/ directory contains Ruby code to declare the constants you want. The constant values themselves are exctracted by inspection. In order to do so, the code generator will compile a small program that outputs the values of the constants as discovered in declared header files. When the program is run, the output is parsed, and these are the values that are used when generating the Java source.

To run the code generator, you must have Rake installed in Ruby 1.9+. There are three tasks you must run in order to generate all the necessary files.

If you have not added any new constants or modified any constant sets, you can generate updated values for the existing constants on your platform using the generate:platform task. This must be run on each platform you'd like to generate the files for.

$ rake generate:platform

If you have added any constants or sets of constants, you must also run the xplatform and fake generators.

The generate:xplatform variant generates the top-level enum file. While this contains the necessary fields, it does not contain the integer values for those fields. The values lookup is delegated to either an OS-specific (and possibly architecture-specific) implementation or a so-called "fake" implementation, generated by the generate:fake task.

$ rake generate:xplatform
$ rake generate:fake

The generated files are version-controlled. Please remember to commit them in addition to the Ruby templates for the generator.


The project is maven-based. It uses standard maven lifecycle events. To build the code:

$ mvn package

To install the code into your local maven repository:

$ mvn install

To push snapshots out to Sonatype (you must have the necessary permissions):

$ mvn deploy
You can’t perform that action at this time.