Select a VEE Port
Building or running an Application or a Test Suite with the SDK requires a VEE Port.
Use one of the following available options to provide it to your project.
Note
Declaring a VEE Port in project dependencies only applies to the current project. This configuration is not fetched transitively by consumer projects. Especially when configuring the VEE Port to test a library project, application projects depending on this library will not “see” this test VEE Port, they must configure a VEE Port on their own and are free to use a different one.
Using a Module Dependency
When your VEE Port is published in an artifact repository,
you can define the VEE Port by declaring a module dependency in the build.gradle.kts
file, with the microejVee
configuration:
dependencies { microejVee("com.mycompany:myveeport:1.0.0") }
and by setting the Architecture Usage of the VEE Port.
This is generally the case for developers focused on Application and Library development. They don’t have (and don’t need) the VEE Port project locally, they only need to use it.
Note
For dependencies stored in an Ivy repository, Gradle fetches them with the configuration
default
. If several artifacts are published with this configuration, the build will fail because it doesn’t know which artifact to choose. You can select the right artifact by adding information on the one to fetch in theartifact
block, for example:microejVee("com.mycompany:myveeport:1.0.0") { artifact { name = "artifact-name" type = "zip" } }This will select the artifact with the name
artifact-name
and with the typezip
.Refer to the Gradle documentation to learn all the options to select dependencies.
VEE Port project inside a multi-project
When the VEE Port project is in the same multi-project than the component which needs it (an Application for example), the VEE Port project should be declared as a project dependency.
For example if the multi-project contains an Application subproject named my-app
and a VEE Port subproject called vee-port
,
the VEE Port project must be declared as a dependency in the build.gradle.kts
file of the my-app
subproject as follows:
dependencies {
microejVee(project(":vee-port"))
}
and the Architecture Usage of the VEE Port must be set.
The VEE Port will be automatically built when it is required by the Application.
For example when running the Application on the Simulator (with the runOnSimulator
task)
or when building the Application Executable (with the buildExecutable
),
the VEE Port will be built before executing the requested task.
Local VEE Port project outside a multi-project
When the Application or the Library which needs the VEE Port is not is the same multi-project than the VEE Port, the VEE Port project can be imported thanks to the Gradle Composite Build feature.
This allows to consider the VEE Port project as part of the Application project, so all changes done to the VEE Port are automatically considered when building or running the Application.
This is done by adding the following line in the settings.gradle.kts
file of the Application project:
includeBuild("[vee-port-project-absolute-path]")
Then declaring the VEE Port as a dependency in the build.gradle.kts
file of the Application project:
dependencies {
microejVee("com.mycompany:vee-port:1.0.0")
}
The dependency must use the module notation ("group:name:version"
), where the group and name match with the ones declared in the VEE Port project.
The group is defined in the build.gradle.kts
file of the vee-port
project by the group
property.
The name is defined in the settings.gradle.kts
file when the vee-port
project is included.
For example, the name of the VEE Port is my-custom-vee-port
if the vee-port
subproject is included with:
include("my-custom-vee-port")
project(":my-custom-vee-port").projectDir = file("vee-port")
Otherwise the name of the subproject folder is used, so vee-port
in the recommended structure.
Using a Local VEE Port Directory
When your VEE Port is available in a local directory,
you can use it by declaring a file dependency in the build.gradle.kts
file, with the microejVee
configuration:
dependencies {
microejVee(files("C:\\path\\to\\my\\veePort\\source"))
}
This is generally the case when the VEE Port has been built locally
in SDK 6, by executing the
buildVeePort
Gradle task on the VEE Port project. In this case, the VEE Port directory is located atbuild/veePort/source
in the project.in SDK 5, by executing a
Build Module
on the VEE Port configuration project. In this case, the VEE Port is a sibling folder of the VEE Port configuration project, named after the VEE Port name.
Note
This file, as well as other Gradle configuration files, respects the Java properties file convention:
the OS path must use the UNIX path convention (path separator is /
).
The Windows paths must have been converted manually replacing \
by /
or by \\
.
Using a Local VEE Port Archive
When your VEE Port is available locally as an archive file (.zip
or .vde
),
you can use it by declaring a file dependency in the build.gradle.kts
file, with the microejVee
configuration:
dependencies {
microejVee(files("C:\\path\\to\\my\\veePort\\file.zip"))
}
This is generally the case when
the VEE Port has been built locally in SDK 6, by executing the
buildVeePort
Gradle task on the VEE Port project. In this case, the VEE Port archive is located atbuild/veePort.zip
in the project.the VEE Port has been built and published in SDK 5. In this case, the VEE Port archive is available in an artifact repository and can be downloaded manually to be used in your Application or Library project.
Note
The legacy JPF
format of a VEE Port is not supported anymore in the SDK 6.
If you want to use a VEE Port .jpf
file, you have to use the SDK 5.
Architecture Usage Selection
When the selected VEE Port is fetched from a repository or is a subproject of a multi-project,
the default Architecture Usage is eval
(no matter what is configured in the VEE Port project).
It is possible to change the Architecture Usage in the project which needs it (an Application for example)
by setting the architectureUsage
property in the microej
block in the build.gradke.kts
file:
microej {
architectureUsage = "prod"
}
Set the property to prod
to use a Production Architecture and to eval
to use an Evaluation Architecture.
If not set, the eval
value is used.
Warning
When the VEE Port is a local archive or folder (microejVee(files(...))
), the Architecture Usage is defined when the VEE Port is built and can no longer be changed.
In SDK 6 (with the buildVeePort
task), the Architecture Usage is defined by setting the architectureUsage
property in the build.gradke.kts
file of the VEE Port project.