首页 > 其他分享 >如何用工具检查 ABAP 代码是否符合 Clean ABAP 编码规范

如何用工具检查 ABAP 代码是否符合 Clean ABAP 编码规范

时间:2024-08-10 18:58:58浏览次数:9  
标签:编码 Code 代码 abap ABAP Clean pal

本文在 ABAP 系统里的操作截图,来自 SAP 社区博客,地址如下:

  • https://community.sap.com/t5/application-development-blog-posts/how-to-enable-clean-code-checks-for-abap/ba-p/13544856

  • https://community.sap.com/t5/technology-blogs-by-sap/clean-code-checks-for-abap-cloud-edition/ba-p/13562780

笔者之前的文章,介绍了 Clean ABAP 的概念。

聊聊 Clean ABAP

简单的说,Clean ABAP 由四个“一”组成:一个由 SAP 主推的开源项目,一套通用的 Clean ABAP 编程规范,一套匹配该规范的代码扫描工具,加上一套对应的代码自动重构工具。

图中紫色的椭圆区域,包含的就是 Clean ABAP 编程规范,在笔者之前的文章有详细介绍:

SAP 官方 ABAP 编程规范(2023 版)

本文介绍下图粉色椭圆区域的内容:Code pal for ABAP,一个开源的 ABAP 代码扫描工具。

该工具基于 Clean ABAP 编码规范对 ABAP 代码进行扫描。

当然,工具不可能 100% 覆盖编码规范中定义的所有规则,因此图中 Code pal for ABAP 所占的区域,只是 Clean ABAP 编码规范的一个子集。

pal 在英语中有朋友,老兄,兄弟的意思。

Code pal for ABAP 是开源工具,Github 地址如下

使用 abapGit 将其源代码克隆到本地 ABAP 系统。

笔者之前的文章已经介绍过 abapGit 的使用:

使用 abapGit 在 ABAP On-Premises 系统和 SAP 云平台 ABAP 环境之间进行代码传输

从官网上将 abapGit 的完整源代码,拷贝到 ABAP 系统里新建的报表里,激活即可使用。

新建一个 Online Repository:

输入 Code pal for ABAP 的 Github 地址,点击 Create Online Repo:

点击 Pull,即可把远端 Github 网站的 ABAP 代码,全部拉取到本地 ABAP 系统里,自动生成对应的 ABAP 类和其他开发资源。

激活这些 ABAP 开发资源之后,使用事务码 SCI 进入 ABAP Code Inspector,开启 Code pal for ABAP 的扫描选项:

选中所有 Test Category 为 code pal for ABAP 的检查规则:

新建一个 Check Variant,包含刚才开启的检查规则:

单击每个 Checks 的 Attributes 按钮,可以对违反这个检查规则的 ABAP 代码的处理行为,进行自定义。

比如对于输入参数类型为布尔类型这条检查规则,可以定义违反规则后抛出消息的严重级别,以及是否允许通过 ABAP Pragma #EC BOOL_PARAM(一种特殊的注释) 来屏蔽掉。

配置完毕之后,就能在 ABAP Development Tool 的 ATC 工具里使用了:

选择刚才创建的包含了 Code pal for ABAP 检查的 Check Variant 即可:

完成代码扫描之后,选中每条检查结果,可以看到详细的错误说明和解决方案提示。

在 SAP BTP ABAP 云端编程环境里,可以使用 Code pal for ABAP 的云版本。

在 ABAP Development Tool 里打开 abapGit 仓库的视图:

把 Code pal for ABAP 对应的云端版本克隆下来即可:

https://github.com/SAP/code-pal-for-abap-cloud

之后就能够看到对应的检查规则了。后续的使用方法,同 ABAP Opportunities 环境里一致。

Code pal for ABAP 里的很多检查选项,能够给我们提供一些有意思的思考。

每个选项在 Github 上都有一个对应的文档,介绍了引入这个检查选项的初衷和背景,以及一些讨论。

比如一个方法的输入参数,选择布尔数据类型,有什么好处和弊端?

其对应的文档链接如下:

https://github.com/SAP/code-pal-for-abap/blob/master/docs/checks/boolean-input-parameter.md

为什么 Clean ABAP 编程规范里,不推荐在方法设计时,使用布尔类型的输入参数呢?

因为编程规范认为,这种设计有违反设计领域里单一职责 - Single Responsibility 的嫌疑。

比如下面这个方法:

METHODS update
  IMPORTING
    do_save TYPE abap_bool.

在 update 的实现体内,完成的逻辑是:如果传入的输入参数值为 abap_false, 那么只修改内表值,不进行 commit 操作。反之,调用另一个 Update Function Module 执行数据库层面的修改。

表面上看,用一个方法,处理了两种业务场景,节省了代码量。

但是 Clean ABAP 编程规范认为,这样的设计增加了 update 方法的测试复杂度,同时也降低了消费 update 方法的代码的可读性。

消费 update 方法的应用代码:

do_save(abap_false).
do_save(abap_true).

上面这种消费代码方式,并不是自描述的。

接手这段代码的维护人员,可能看了之后一头雾水:这里的 abap_true 和 abap_false, 是用来区分 save 操作是同步或者异步?是真实提交或者 simulation 即模拟方式提交?是保存时考虑或者忽略权限检查?

总之在阅读 do_save 方法实现源代码之前,维护人员只能瞎猜。

Clean ABAP 编程规范的建议就是:简单的将 do_save 拆分成两个方法:

METHODS update_without_saving.
METHODS update_and_commit.

虽然看起来可能有点笨拙,但提高了代码的可测试性和可读性。

总之,Clean ABAP 编码规范和其配套的工具,不但能从规则和技术上,确保 ABAP 代码符合 Clean 规范,而且通过阅读编码规范的文档,也能从中学到很多编码的最佳实践和准则。

标签:编码,Code,代码,abap,ABAP,Clean,pal
From: https://blog.csdn.net/m0_55213370/article/details/141094657

相关文章

  • transformer的位置编码具体是如何做的
    VisionTransformer(ViT)位置编码VisionTransformer(ViT)位置编码1.生成位置编码对于每个图像块(patch),根据其位置生成一个对应的编码向量。假设每个图像块的嵌入向量维度为D,则位置编码的维度也是D。ViT通常使用可学习的绝对位置编码,这意味着这些位置编码是在训练过程......
  • 熵编码(五)-CABAC(一) 基础篇
    目录1.前言2.二进制算术编码3.CABAC编码原理分析3.1.自适应算术编码3.1.1.算法流程流程3.1.2.自适应3.1.3.码流输出(区间缩放)3.1.4自适应算术编码的计算复杂度及优化3.1.4.1自适应概率模型背景3.1.4.2.自适应概率模型设计3.1.4.2.1.自适应概率模型量化3.1.4.2.1.自适......
  • 一个简单的录音软件(利用QT录音,ffmpeg进行音频重采样,fdk-aac编码)
             录音软件是一种非常有用的工具,可以帮助我们记录和存储语音信息。在本文中,我们将介绍一个简单的录音软件,该软件利用QT进行录音,使用ffmpeg进行音频重采样,并使用fdk-aac编码。一、 环境介绍  1、QT版本:QT5.12.62、编译器: MSVC2017643、ffmpeg版......
  • CentOS修改系统默认语言与编码
    有时候在安装CentOS无意中把默认语言设置为中文,而部分SSH软件不支持中文编码,所以在远程管理的时候会出现些乱码的现象。如何修改CentOS的默认语言呢?请先使用root权限帐户登陆一、进入语言配置文件vi /etc/sysconfig/i18n用SSH执行以上命令,用vi编辑器修改/etc/sysconfig/i1......
  • 机器学习笔记:编码器与解码器
    目录介绍组成结构代码实现编码器解码器合并编码器-解码器思考介绍在机器翻译中,输入的序列与输出的序列经常是长度不相等的序列,此时,像自然语言处理这种直接使用循环神经网络或是门控循环单元的方法就行不通了。因此,我们引入一个新的结构,称之为“编码器-解码器”(Enco......
  • 医学图像分割的基准:TransUnet(用于医学图像分割的Transformer编码器)器官分割
    1、TransUnet介绍TransUnet是一种用于医学图像分割的深度学习模型。它是基于Transformer模型的图像分割方法,由AI研究公司HuggingFace在2021年提出。医学图像分割是一项重要的任务,旨在将医学图像中的不同结构和区域分离出来,以便医生可以更好地诊断和治疗疾病。传统的医学......
  • 简单理解H264编码
    参考帖子:https://blog.csdn.net/go_str/article/details/80340564?spm=1001.2014.3001.55020、序言:首先要弄明白编码的目的。当你此刻显示器正在播放一个视频,分辨率为1280*720,帧率为25,那么一秒所产生正常的数据大小为:1280*720(像素)*25(张)/8(1字节8位)(结果:B)/1024(结果:KB)/1024(结果:MB)=2.......
  • 12 个开源社区喊你跟通义灵码结伴编码,赢开源先锋大奖!
    ......
  • C#使用HttpUtility,HttpServerUtility、HttpUtility对URL编码、解码
    1、HttpUtility.UrlEncode方法:对URL字符串进行编码,以便实现从Web服务器到客户端的可靠的HTTP传输。重载列表:[1]将字节数组转换为已编码的URL字符。[C#]publicstaticstringUrlEncode(byte[]);[2]对URL字符串进行编码。[C#]publicstaticstringUrlEncode......
  • Mac OS 批量将Java编码iso-8859-1( english_us8859)转换为utf-8格式
    !/bin/bash#指定源目录SOURCE_DIR="./serialMonitor"#遍历源目录下所有.java文件functionconvert_to_utf8(){localfile="$1"encoding=`file-I${file}|awk-F='{print$2}'`echo"encoding:$encoding"if[[&qu......