All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.teamscale.index.metadata.abap.EAbapLanguageVersion Maven / Gradle / Ivy

/*
 * Copyright (c) CQSE GmbH
 *
 * 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
 *
 *     http://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.
 */

package com.teamscale.index.metadata.abap;

import org.conqat.lib.commons.collections.CounterSet;
import org.conqat.lib.commons.js_export.ExportToTypeScript;
import org.conqat.lib.commons.test.IndexValueClass;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;

/**
 * Lists all possible values of ABAP language versions for ABAP objects. See language
 * version for SAP NetWeaver AS ABAP Release 752 and language
 * version for newer SAP systems.
 */
@ExportToTypeScript
@IndexValueClass
public enum EAbapLanguageVersion {

	/**
	 * Represents a version character that is not known to Teamscale and for which support need to be
	 * provided.
	 */
	UNKNOWN('~', "Unknown"),

	/**
	 * This version of ABAP is obsolete and is no longer supported in the current release. The version
	 * ID of a program of this type is initial. No Unicode checks are performed in programs of this
	 * type.
	 */
	OBSOLETE_ABAP(' ', "Obsolete"),

	/**
	 * The universal basic version. This version of ABAP is an unrestricted ABAP language version for
	 * classic ABAP. It covers the entire language scope of ABAP that can be used in Unicode systems and
	 * apart from the static package concept, access to all other repository objects is allowed. The
	 * syntax check for Standard ABAP is performed as Unicode check, which is the minimum requirement
	 * for a Unicode system. The documentation of this version describes all ABAP language elements.
	 */
	STANDARD_ABAP('X', "Standard"),

	/**
	 * This version of ABAP is intended for the secure implementation of enhancements by key users
	 * within the scope of enhancement options provided by SAP. ABAP for Key Users is a restricted ABAP
	 * language version where the general rules for Standard ABAP (Unicode) apply but only a very
	 * restricted set of language elements is supported and access
	 * to repository objects is restricted. Furthermore, enhancements can be implemented in methods
	 * only, where the stricter syntax rules for classes automatically apply and no obsolete language
	 * elements are allowed. ABAP for Key Users is not supported by the ABAP keyword documentation. Only
	 * ABAP syntax diagrams with a short explanation are shown. For more information, see Key User
	 * Extensibility.
	 */
	ABAP_FOR_KEY_USERS('2', "Key Users"),

	/**
	 * In this version of ABAP, the rules for Standard ABAP (Unicode) apply, with restrictions on access
	 * to external repository objects. Dynamically specified data and statements for dynamic creation of
	 * programs are forbidden here to make sure that static checks can be carried out. The corresponding
	 * language elements are hidden in the documentation for static ABAP with restricted object use.
	 */
	STATIC_ABAP_WITH_RESTRICTED_OBJECT_USE('3', "Static ABAP (Restricted)"),

	/**
	 * In this version of ABAP, the rules for Standard ABAP (Unicode) apply, with restrictions on access
	 * to external repository objects. Dynamic language elements are not forbidden in this version.
	 */
	STANDARD_ABAP_WITH_RESTRICTED_OBJECT_USE('4', "Standard ABAP (Restricted)"),

	/**
	 * This version of ABAP is a restricted ABAP language version for ABAP Cloud. The general rules for
	 * Standard ABAP (Unicode) apply but only a very restricted set of language elements is supported
	 * and to
	 * repository objects is restrictedaccess. Furthermore, most developments can be implemented in
	 * methods only, where the stricter syntax rules of classes automatically apply. Almost no obsolete
	 * language elements are allowed. For ABAP SQL, the most strict syntax check mode currently
	 * available is applied. The documentation for ABAP for Cloud Development is a restricted version of
	 * the full documentation.
	 */
	ABAP_FOR_CLOUD_DEVELOPMENT('5', "Cloud");

	private static final String VERSION_ID_PROPERTY = "versionId";

	private static final String HUMAN_READABLE_NAME_PROPERTY = "humanReadableName";

	@JsonProperty(VERSION_ID_PROPERTY)
	private final char versionId;

	@JsonProperty(HUMAN_READABLE_NAME_PROPERTY)
	private final String humanReadableName;

	@JsonCreator
	EAbapLanguageVersion(@JsonProperty(VERSION_ID_PROPERTY) char versionId,
			@JsonProperty(HUMAN_READABLE_NAME_PROPERTY) String humanReadableName) {
		this.versionId = versionId;
		this.humanReadableName = humanReadableName;
	}

	/**
	 * Derives a {@link EAbapLanguageVersion} from some given version id. Returns {@link #UNKNOWN} if
	 * the type value is not defined in this enumeration.
	 */
	public static EAbapLanguageVersion getLanguageVersionFromId(char versionId) {
		for (EAbapLanguageVersion languageVersion : EAbapLanguageVersion.values()) {
			if (languageVersion.versionId == versionId) {
				return languageVersion;
			}
		}

		return UNKNOWN;
	}

	/** @see #versionId */
	public char getVersionId() {
		return versionId;
	}

	/**
	 * Converts the enum to a human-readable metric.
	 * 

* We are using {@link CounterSet counter sets} because we don't lose the amount of files with the * specific enum on aggregation in a folder. */ public static CounterSet toMetric(EAbapLanguageVersion langVersion) { if (langVersion == null || langVersion == UNKNOWN) { return new CounterSet<>(UNKNOWN.humanReadableName, 1); } return new CounterSet<>(langVersion.humanReadableName, 1); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy