在Google上根据关键字”程序员鄙视链”搜索,会获得68多万条结果。前端
玲琅满目的搜索结果里是众多不一样维度划分的鄙视链。java
其中有一个维度,就是编程工具的鄙视链,好比:git
而我在SAP作的全部开发都用的是IDE而不是text editor,看来我也免不了处于鄙视链末端的结局了。程序员
这篇文章我想介绍一些我用过的SAP IDE的周边。但愿您看了以后有些许收获。而像Eclipse, Visual Studio这些IDE在SAP圈子外使用也更加普遍,因此本文再也不说起。github
本文里提到的全部IDE都是基于Windows版本的,这使得我又一次被鄙视了:使用Mac OS的程序猿鄙视使用Windows OS的程序猿。web
我在SAP工做期间用过的IDE清单以下:(名称不包含SAP则说明该IDE不是由SAP开发出来的)数据库
SAPGUI编程
SAPGUI是全部ABAPer养家糊口的工具,见证了SAP从只有5个员工的无名之辈走向企业管理软件巅峰的辉煌之路。从严格意义上讲,SAPGUI不只仅是个IDE,也是不少使用SAP传统管理软件的业务人员们天天工做使用的工具。有个段子就是某同事去苏宁买电器,在柜台结帐时,销售小妹说,”您等等, 如今系统有问题,下不了单。” 该同事走上前去看了看屏幕说,”哟,出error啦?让我F1看看错误明细,再看看/h能不能用。” 用过SAPGUI的读者必定明白我在说什么。json
本文我尽可能分享一些个人原创以及并不是每位朋友都知道的一些小技巧。ubuntu
2013年的时候,我看到SAP社区上有些朋友在讨论SAPGUI command line这些用过的事物码列表是存储在什么地方的:
获得的答案是,若是是Windows系统,则存储在操做系统的注册表里:
具体讨论见以下连接:
https://blogs.sap.com/2013/10/07/where-does-tcodes-on-command-line-gets-stored/
当时我以为比较有意思,而后想知道有没有一个通用且快速的办法,找到SAPGUI里任意一个设置,是存储在注册表里具体哪一个位置的。
一样是2013年,我写过一篇博客:Six kinds of debugging tips to find the source code where the message is raised
需求就是在SAPGUI里看到一条错误信息,怎样用六种不一样的办法找到具体是哪一行ABAP代码抛出的这条错误信息。最后一种使用ST05跟踪的思路也适用于如今讨论的如何查找SAPGUI的配置在Windows操做系统注册表里的具体存储位置:
1. 在修改SAPGUI配置以前,将注册表导出存为A;
2. 修改SAPGUI配置,而后将注册表导出存为B;
3. 用工具比较A和B差别,便可得到该配置在注册表里存储的位置。
我最先遇到须要将SAPGUI里某段ABAP代码导出成PDF格式时,老是先新建一个word文档,在ABAP代码上Ctrl C而后Ctrl V到word文档,最后把word文档转换成PDF。
其实SAPGUI里自带一键将代码导出成PDF的功能。只须要在下图配置里给导出PDF功能分配对应的快捷键:
而后就可一键保存成PDF:
值得一提的是,由于SAPGUI里的全部事物码也是经过ABAP开发的,包括用来作开发的事物码SE80自己。所以这些事物码自己也是能够经过ABAP进行加强的。
好比我在SE80的开发对象类型里,自定义了一种新的名称为”Jerry’s Product”的开发对象类型,可以像其余全部开发对象同样,经过右键菜单进行建立:
新建一个开发对象的实例,维护名称:
实例建立成功以后,能在SE80里继续维护其余明细:
再好比假若您对SAPGUI里ABAP编辑器标准的ABAP语法检查不太满意,想对其作加强,这固然是能够的。具体步骤参考个人博客:Implement Custom Syntax Check in SAPGUI
这种语法加强的一个应用例子,能够参考我公众号文章 Jerry的ABAP, Java和JavaScript乱炖 里提到的博客:Covariance in Java and simulation in ABAP.
我写这篇博客的背景是为SAP成都研究院的一个内部技术培训准备培训材料。该文首先介绍了Covariance和Contravaariance的概念,而后描述了Covariance在Java里的实现,最后给出了我在ABAP里对于Covariance的一个模拟实现,以及如何加强ABAP编辑器的语法检查使其可以自动检测出违反了Covariance规范的代码。
我记得在2011年的时候,WebIDE的概念比较火,WebIDE使得开发者只须要一个浏览器就能够编写代码,并在WebIDE 提供的终端环境中运行。
当时我就以为很囧, 由于相似WebIDE的概念,其实SAPGUI在很早很早以前就支持了。SAP Netweaver里有个模块叫SAP Internet Trasaction Server,能让SAPGUI里的流程运行于浏览器里。关于这个模块的详细介绍,请参考SAP帮助文档: SAP ITS in SAP NetWeaver Application Server
举个例子:我能够把SAPGUI里的SE80放到Fiori的Launchpad里,
点击该Tile,能直接在浏览器里使用SE80。以下图所示:
只须要一些简单的配置便可实现上述效果,具体步骤见我博客:Open your SAP GUI transaction in Fiori launchpad
原理介绍见个人另外一篇博客:How is old SAP GUI transaction embedded into Fiori launchpad
文内也提到S/4HANA里有大量的Fiori tile使用到了这种技术,即经过ITS的方式,让很古老的一些事务码好比MM01继续在浏览器里运行。下面第一张图是SAPGUI里使用事务码MM01打开的物料建立页面,第二张图是该事务码经过ITS运行在浏览器里的截图。
能够看出这两个页面的布局彻底一致。
再回到IDE这个话题,直接经过个人上述博客提到的方式在浏览器里运行SE80,其实不能算严格意义上的WebIDE,由于缺少语法高亮。
这种局限在S/4HANA里获得了改善。S/4HANA里有个应用叫作Custom Logic,能容许咱们直接在浏览器里编辑ABAP代码,支持语法高亮显示,以下图所示:
我不久前刚刚研究过ABAP的语法高亮显示是怎么在Chrome浏览器里实现的。若是您对此技术细节感兴趣,请参考个人博客:How ABAP syntax highlight is implemented in WebIDE launched via browser
SAP ABAP Development Tools
之前SAP内部喜欢把这个IDE称为ABAP in Eclipse。如今的官方叫法是ABAP Development Tools。实质上就是SAP在Eclipse上以插件(plugin)的方式作了一些扩展。
不少具备Java开发经验的朋友们都喜欢用ABAP Development Tools进行ABAP开发。我在2014年时,曾经研究过ABAP Development Tool这个IDE的Java实现代码,是如何经过RFC(Remote Function Call)调用到ABAP后台的。
分析的关键是使用IDE里这个log功能:
ABAP Development Tools的后台实现细节请参考我博客: An example to help you understand how does ADT work
而IDE端的Java实现细节,能够将安装目录的plugins文件夹下的.class文件反编译出来自行学习:
SAP HANA Studio
和ABAP Development Tools同样,HANA Studio也是基于Eclipse的IDE,只是其拥有的SAP自开发的plugin和ABAP Development Tools有所区别。由于须要在此IDE里链接SAP HANA数据库,所以大多plugin都以命名空间com.sap.ndb.studio开头。这里的ndb其实是HANA刚刚诞生时的SAP内部名称: New DB的缩写。
既然是基于Java实现的plugin去链接HANA数据库,必然少不了JDBC。在HANA Studio里的大多数操做都会使用到com.sap.ndb.studio.jdbc这个plugin:
其实现代码也是能够将plugin文件夹里的.class文件反编译出来查看。
SAP Cloud Application Studio
SAP Business by Design和SAP Cloud for Customer的Partners使用该IDE进行二次开发。
该IDE基于Visual Studio Shell开发,与后者的关系相似于SAP ABAP Development Tools / SAP HANA Studio和Eclipse的关系。我于2011年到2012年参与了该IDE的开发,使用的编程语言是C#。
Cloud Application Studio工做原理和ABAP Development Tools相似,在C#端经过RFC调用ABAP后台暴露出的API。
例如在IDE里选择了右键菜单的Activate以后,
会执行下图C#代码中的ActivateContent函数进行ABAP后台对应资源的激活处理。而图中的C#代理类PDI_RI_CONTENT_ACTIVATE, 对应了ABAP后台的同名函数。一旦图中最后一行代码jsonClient.callFunctionModule(proxy)执行,ABAP后台函数PDI_RI_CONTENT_ACTIVATE就会被远程调用。
SAP WebIDE
我2014年到2016年作Fiori产品开发用的就是这个IDE。更多关于这个WebIDE的细节能够参考个人另外一篇公众号文章:
若是只是写一些小的Web程序,我也喜欢用一些其余的工具,好比CodePen https://codepen.io:
或者jsbin。这些工具都支持开发人员直接在浏览器里编码并运行,很是方便。
个人Cloud for Customer开发同事们也喜欢用Atom和WebStorm进行前端开发。
Sublime Text(文本编辑器)
该文本编辑器的一大特点是提供了很是简易的方式让编程人员自行开发能提高本身工做效率的插件。做为一个例子,您能够参考个人博客:Step by Step to develop your own Sublime Text plugin
Sublime Text另外一个我很喜欢的功能是它也具备支持ABAP语法高亮显示的插件:您能够经过这个连接得到.
Android Studio
用于SAP Cloud for Customer移动端Android平台。做为Android的脑残粉,平时写一些Android小程序,我不会打开相对比较笨重的Android Studio,而使用一些Android WebIDE,好比Cloud9:
VirtualBox + Putty
这个组合其实不能算IDE了,极大的提高了我平常工做的效率。VirtualBox里安装的ubuntu默认配置下的console模式存在一些让我以为使用起来不太方便的地方,好比不支持来自windows OS的复制粘贴,不支持自定义字体类型和大小等等,然后者对我来讲相当重要。
因而,我会选择先用VirtualBox启动ubuntu实例,而后再用Putty远程登陆上去,以后全部对ubuntu的操做都在Putty里完成。而Putty里是支持复制粘贴,自定义字体等等。
下图是VirtualBox原生的ubuntu console截图。
下图是用Putty远程登陆ubuntu以后的操做界面。
经过比较能发现,在Putty里我将字体类型改为了个人最爱Inconsolata,大小改为了20。有的朋友可能以为其实两张图看起来都差很少。好吧,做为一个程序猿,天天看着这些界面的时间比对着老婆的时间还长,多花些心思把这些界面设置成本身看起来最顺眼的样子,有助于确保我始终带着温馨的心情去编程。
固然,SAP有着众多的产品线,也就存在着形形色色的开发工具。一个程序员不可能接触到全部的开发工具。本文仅仅列出了我工做中使用到的一些IDE,感谢阅读。 要获取更多Jerry的原创技术文章,请关注公众号"汪子熙"或者扫描下面二维码: