ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

i042416發表於2019-10-26

Jerry進入SAP成都研究院前,一直是用C/C++開發,所以剛接觸ABAP,對於她在某些語法環境下大小寫敏感,某些環境下不敏感的特性很不適應。那時候Jerry深深地懷念之前在C/C++程式設計時遵循的駝峰命名法和匈牙利命名法。

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

駝峰命名法:函式名中的每一個邏輯斷點都有一個大寫字母來標記。方法和變數名的首字母一般小寫,這叫小駝峰命名法,例如printEmployeePaychecks. 類名的首字母一般大寫,這叫大駝峰命名法,比如EmployeeBonusPlanManager.

匈牙利命名法: 變數名= 型別 + 描述。型別一般以一個或多個小寫字母開頭作為字首,後面跟著一個或多個單詞描述該變數的用途。

Jerry上大學的時候,用的C/C++教程裡的示例程式碼全部採取的匈牙利命令法。

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

這兩種命名方式各有優缺點,網上有很多文章闡述,大家感興趣的話自行查閱。

那麼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開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

通常情況下我們期望ABAP裡的變數名都統一用小寫,為此只需在SAP GUI的ABAP Editor設定裡,開啟Pretty Printer配置頁面,將Keyword Uppercase的勾打上。

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

這樣我們在使用IDE裡提供的Pretty Printer,即程式碼美化功能時,即使ABAP變數裡出現了大小寫混雜的情況,也會全部自動轉換為小寫。

然而Pretty Printer的這種行為會帶來一個小問題,如果程式碼裡訪問了某個CDS view,比如例子中的I_Product,因為它不是一個ABAP關鍵字,所以也會被轉換成全部是小寫字母的組合:i_product.

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

當時我們對這個行為有些不滿意,因為按照我們內部開發規範,CDS view的首字母和下劃線之後的第一個字母必須大寫。我們期望的結果是,當Pretty Printer執行後,程式碼中CDS view的名稱仍然是I_Product, 而不是現在的i_product.

後來Jerry想了個辦法,即修改Pretty Printer的處理邏輯:如果掃描到程式碼裡出現的單詞代表一個CDS view時,讓Pretty Printer高抬貴手,不對這個單詞進行任何操作。

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

我把這個方法分享到了SAP社群上:

Bypass CDS view name case conversion in ABAP source code pretty printer

測試結果:紅色下劃線標註的ABAP變數名被自動格式化成全部小寫,而CDS view的名稱I_Product仍然保持不變。這正是我們期望的結果。

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

兩年過去了。如今,這個問題已經有了優雅的解決方案:如果想使用駝峰命名法,只需要在ABAP Development Tool裡把Keep Camel Case Identifiers前面的勾選上即可。

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

大家可以比較一下這個勾如果不打上會是什麼樣的效果:

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

這意味著偏愛駝峰命名法的ABAP開發人員,如今也可以在IDE的支援下進行ABAP程式碼編寫了。

SAP社群上有ABAP開發人員聲稱,這是他們盼望了很久的功能:

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了 ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了

注意:目前這個功能只在S/4HANA和SAP雲平臺ABAP程式設計環境可用。

要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":

ABAP開發環境終於支援以駝峰命名法自動格式化ABAP變數名了


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2661541/,如需轉載,請註明出處,否則將追究法律責任。

相關文章