ABAP开发环境终于支持以驼峰命名法自动格式化ABAP变量名了
Jerry進入SAP成都研究院前,一直是用C/C++開發,所以剛接觸ABAP,對于她在某些語法環境下大小寫敏感,某些環境下不敏感的特性很不適應。那時候Jerry深深地懷念之前在C/C++編程時遵循的駝峰命名法和匈牙利命名法。
駝峰命名法:函數名中的每一個邏輯斷點都有一個大寫字母來標記。方法和變量名的首字母一般小寫,這叫小駝峰命名法,例如printEmployeePaychecks. 類名的首字母一般大寫,這叫大駝峰命名法,比如EmployeeBonusPlanManager.匈牙利命名法: 變量名= 類型 + 描述。類型一般以一個或多個小寫字母開頭作為前綴,后面跟著一個或多個單詞描述該變量的用途。
Jerry上大學的時候,用的C/C++教程里的示例代碼全部采取的匈牙利命令法。
這兩種命名方式各有優缺點,網上有很多文章闡述,大家感興趣的話自行查閱。
那么ABAP呢?在Jerry的文章 SAP官方發布的ABAP編程規范 里能夠發現,ABAP的變量命名采取的是一種綜合了匈牙利命名法和下劃線命名法的混合方式。有的時候,這種命名方式會給ABAP開發人員帶來一些煩惱。看一個實際的例子,來自2017年Jerry還在SAP成都研究院CRM開發團隊工作時,大家討論的一個變量命名的問題。
假設有這樣一段簡單的ABAP代碼,通過OPEN SQL從名為I_Product的CDS view里讀取數據到內表lt_table里。
ABAP變量名是大小寫無關的,下圖紅色下劃線lt_table是一個“匈牙利命名法+下劃線命名法”的例子,lt是local table的縮寫, 說明這個變量是一個局部內表變量。
通常情況下我們期望ABAP里的變量名都統一用小寫,為此只需在SAP GUI的ABAP Editor設置里,打開Pretty Printer配置頁面,將Keyword Uppercase的勾打上。
這樣我們在使用IDE里提供的Pretty Printer,即代碼美化功能時,即使ABAP變量里出現了大小寫混雜的情況,也會全部自動轉換為小寫。
然而Pretty Printer的這種行為會帶來一個小問題,如果代碼里訪問了某個CDS view,比如例子中的I_Product,因為它不是一個ABAP關鍵字,所以也會被轉換成全部是小寫字母的組合:i_product.
當時我們對這個行為有些不滿意,因為按照我們內部開發規范,CDS view的首字母和下劃線之后的第一個字母必須大寫。我們期望的結果是,當Pretty Printer執行后,代碼中CDS view的名稱仍然是I_Product, 而不是現在的i_product.
后來Jerry想了個辦法,即修改Pretty Printer的處理邏輯:如果掃描到代碼里出現的單詞代表一個CDS view時,讓Pretty Printer高抬貴手,不對這個單詞進行任何操作。
我把這個方法分享到了SAP社區上:
Bypass CDS view name case conversion in ABAP source code pretty printer
測試結果:紅色下劃線標注的ABAP變量名被自動格式化成全部小寫,而CDS view的名稱I_Product仍然保持不變。這正是我們期望的結果。
兩年過去了。如今,這個問題已經有了優雅的解決方案:如果想使用駝峰命名法,只需要在ABAP Development Tool里把Keep Camel Case Identifiers前面的勾選上即可。
大家可以比較一下這個勾如果不打上會是什么樣的效果:
這意味著偏愛駝峰命名法的ABAP開發人員,如今也可以在IDE的支持下進行ABAP代碼編寫了。
SAP社區上有ABAP開發人員聲稱,這是他們盼望了很久的功能:
注意:目前這個功能只在S/4HANA和SAP云平臺ABAP編程環境可用。要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":
總結
以上是生活随笔為你收集整理的ABAP开发环境终于支持以驼峰命名法自动格式化ABAP变量名了的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: resolveType - when i
- 下一篇: dynamic change date