
toolkit.utils.ort-utils.42.1.0.source-code.Environment.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ort-utils Show documentation
Show all versions of ort-utils Show documentation
Part of the OSS Review Toolkit (ORT), a suite to automate software compliance checks.
/*
* Copyright (C) 2017 The ORT Project Authors (see )
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* SPDX-License-Identifier: Apache-2.0
* License-Filename: LICENSE
*/
package org.ossreviewtoolkit.utils.ort
import java.io.File
import java.lang.Runtime
import java.util.jar.JarFile
import org.ossreviewtoolkit.utils.common.Os
/**
* A description of the environment that ORT was executed in.
*/
data class Environment(
/**
* The version of the OSS Review Toolkit as a string.
*/
val ortVersion: String = ORT_VERSION,
/**
* The version of Java used to build ORT.
*/
val buildJdk: String = BUILD_JDK,
/**
* The version of Java used to run ORT.
*/
val javaVersion: String = JAVA_VERSION,
/**
* Name of the operating system, defaults to [Os.name].
*/
val os: String = Os.name,
/**
* The number of logical processors available.
*/
val processors: Int = Runtime.getRuntime().availableProcessors(),
/**
* The maximum amount of memory available.
*/
val maxMemory: Long = Runtime.getRuntime().maxMemory(),
/**
* Map of selected environment variables that might be relevant for debugging.
*/
val variables: Map = RELEVANT_VARIABLES.mapNotNull { key ->
Os.env[key]?.let { value -> key to value }
}.toMap(),
/**
* Map of used tools and their installed versions, defaults to an empty map.
*/
val toolVersions: Map = emptyMap()
) {
companion object {
/**
* The version of the OSS Review Toolkit as a string.
*/
val ORT_VERSION by lazy { this::class.java.`package`.implementationVersion ?: "IDE-SNAPSHOT" }
/**
* The version of Java used to build ORT.
*/
val BUILD_JDK: String by lazy {
runCatching {
val codeSource = this::class.java.protectionDomain.codeSource
JarFile(codeSource?.location?.file).use {
it.manifest.mainAttributes.getValue("Build-Jdk")
}
}.getOrDefault(JAVA_VERSION)
}
/**
* The version of Java used to run ORT.
*/
val JAVA_VERSION: String by lazy { System.getProperty("java.version") }
/**
* A string that is supposed to be used as the User Agent when using ORT as an HTTP client.
*/
val ORT_USER_AGENT = "$ORT_NAME/$ORT_VERSION"
private val RELEVANT_VARIABLES = listOf(
// Windows variables.
"USERPROFILE",
"OS",
"COMSPEC",
// Unix variables.
"HOME",
"OSTYPE",
"HOSTTYPE",
"SHELL",
"TERM",
// General variables.
"http_proxy",
"https_proxy",
"JAVA_HOME",
"ANDROID_HOME",
"GOPATH"
)
}
}
/**
* The directory to store ORT (read-write) data in, like archives, caches, configuration, and tools. Defaults to the
* ".ort" directory below the current user's home directory.
*/
val ortDataDirectory by lazy {
Os.env[ORT_DATA_DIR_ENV_NAME]?.takeUnless {
it.isEmpty()
}?.let {
File(it)
} ?: Os.userHomeDirectory.resolve(".ort")
}
/**
* The directory to store ORT (read-only) configuration in. Defaults to the "config" directory below the data directory.
*/
val ortConfigDirectory by lazy {
Os.env[ORT_CONFIG_DIR_ENV_NAME]?.takeUnless {
it.isEmpty()
}?.let {
File(it)
} ?: ortDataDirectory.resolve("config")
}
/**
* The directory to store ORT (read-write) tools in. Defaults to the "tools" directory below the data directory.
*/
val ortToolsDirectory by lazy {
Os.env[ORT_TOOLS_DIR_ENV_NAME]?.takeUnless {
it.isEmpty()
}?.let {
File(it)
} ?: ortDataDirectory.resolve("tools")
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy