com.teamscale.index.metadata.abap.EAbapLanguageVersion Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of teamscale-commons Show documentation
Show all versions of teamscale-commons Show documentation
Provides common DTOs for Teamscale
/*
* 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