Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 10997x 10997x 10997x 10997x 10997x 32803x 32803x 32803x 32803x 32803x 32803x 32803x 10997x 10997x 10997x 10997x 10447x 10447x 10997x 10997x 260x 260x 10997x 10997x 260x 260x 260x 10997x 10997x 10997x 10997x 326x 326x 326x 10997x 10997x | import {IRule, IRuleMetadata, RuleTag} from "./_irule"; import {Issue} from "../issue"; import {Version} from "../version"; import * as Objects from "../objects"; import {IObject} from "../objects/_iobject"; import {IRegistry} from "../_iregistry"; import {BasicRuleConfig} from "./_basic_rule_config"; import {Position} from "../position"; export class CloudTypesConf extends BasicRuleConfig { } export class CloudTypes implements IRule { private reg: IRegistry; private conf = new CloudTypesConf(); public getMetadata(): IRuleMetadata { return { key: "cloud_types", title: "Check cloud types", shortDescription: `Checks that the package does not contain any object types unsupported in cloud ABAP.`, tags: [RuleTag.SingleFile, RuleTag.Syntax], }; } private getDescription(objectType: string): string { return "Object type " + objectType + " not supported in cloud"; } public getConfig() { return this.conf; } public setConfig(conf: CloudTypesConf) { this.conf = conf; } public initialize(reg: IRegistry) { this.reg = reg; return this; } public static isCloud(obj: IObject): boolean { return obj instanceof Objects.ApplicationJobCatalogEntry || obj instanceof Objects.ApplicationJobTemplate || obj instanceof Objects.AssignmentServiceToAuthorizationGroup || obj instanceof Objects.ATCCheckCategory || obj instanceof Objects.ATCCheckObject || obj instanceof Objects.ATCCheckVariant || obj instanceof Objects.AuthorizationCheckField || obj instanceof Objects.AuthorizationObject || obj instanceof Objects.AuthorizationObjectExtension || obj instanceof Objects.BehaviorDefinition || obj instanceof Objects.BusinessCatalog || obj instanceof Objects.BusinessCatalogAppAssignment || obj instanceof Objects.CDSMetadataExtension || obj instanceof Objects.Class || obj instanceof Objects.ApplicationLogObject || obj instanceof Objects.CommunicationScenario || obj instanceof Objects.DataControl || obj instanceof Objects.DataDefinition || obj instanceof Objects.DataElement || obj instanceof Objects.Domain || obj instanceof Objects.EventBinding || obj instanceof Objects.EventConsumer || obj instanceof Objects.FunctionGroup || obj instanceof Objects.HttpService || obj instanceof Objects.IAMApp || obj instanceof Objects.InboundService || obj instanceof Objects.Interface || obj instanceof Objects.LockObject || obj instanceof Objects.MessageClass || obj instanceof Objects.NumberRange || obj instanceof Objects.OutboundService || obj instanceof Objects.Package || obj instanceof Objects.RestrictionField || obj instanceof Objects.RestrictionType || obj instanceof Objects.ServiceBinding || obj instanceof Objects.ServiceDefinition || obj instanceof Objects.Table || obj instanceof Objects.TableType || obj instanceof Objects.Transformation; } public run(obj: IObject): Issue[] { if (this.reg.getConfig().getVersion() !== Version.Cloud || CloudTypes.isCloud(obj)) { return []; } const position = new Position(1, 1); const issue = Issue.atPosition( obj.getFiles()[0], position, this.getDescription(obj.getType()), this.getMetadata().key, this.conf.severity); return [issue]; } } |