ABAP的語法高亮是如何在瀏覽器裏顯示的

這篇文章的原文我發表在SAP官方社區上:https://blogs.sap.com/2018/03/09/how-abap-syntax-highlight-is-implemented-in-webide-launched-via-browser/

在S/4HANA裏,我們現在能在瀏覽器裏寫ABAP了,並且支持語法高亮。
ABAP的語法高亮是如何在瀏覽器裏顯示的

你也許會問,ABAP的語法高亮是如何在瀏覽器裏顯示的?下面跟我一起來通過調試的方式自己找到問題的答案。

(1). 在瀏覽器裏敲個ABAP的關鍵字,比如data。發現被高亮了。通過Chrome開發工具發現高亮是通過一個叫ace_keyword的css類實現的。

ABAP的語法高亮是如何在瀏覽器裏顯示的

在Chrome開發工具裏以關鍵字".ace_keyword"搜索: 發現這個css類是硬編碼在theme-sap-cumulus.js裏的。

ABAP的語法高亮是如何在瀏覽器裏顯示的

(2). 現在需要找到瀏覽器裏進行ABAP代碼編輯的編輯器的實現。在Chrome開發工具裏Network tab裏輸入“.xml”作爲過濾條件,於是找到編輯器的Fiori實現: Editor.view.xml

ABAP的語法高亮是如何在瀏覽器裏顯示的

具體的編輯器是實現在命名空間reuse的ABAPWrapper標籤裏。

ABAP的語法高亮是如何在瀏覽器裏顯示的

根據這個命名空間找到實現ABAP編輯器的UI5應用,如下圖: nw_aps_ext_lib.

ABAP的語法高亮是如何在瀏覽器裏顯示的

ABAP的語法高亮是如何在瀏覽器裏顯示的

打開ABAPWrapper-dbg.js, 在第68行設置斷點。這個函數負責從ABAP後臺取PAD文件,該文件和語法高亮有關。

ABAP的語法高亮是如何在瀏覽器裏顯示的

刷新ABAP編輯器頁面,斷點觸發,在調試器裏觀察PAD文件的內容:

ABAP的語法高亮是如何在瀏覽器裏顯示的

所有的ABAP關鍵字都列在該PAD文件裏,這樣UI5就知道編輯器裏哪些字符串應該做高亮顯示。

ABAP的語法高亮是如何在瀏覽器裏顯示的

ABAP的語法高亮是如何在瀏覽器裏顯示的

(3). 最後一個問題就是,比如當我敲了一個ABAP關鍵字"new"之後,UI5應用具體哪行代碼將對應的css類加到這個字符串對應的DOM節點上?

如下圖,一旦我敲了一個字符w之後,字符串new作爲一個關鍵字需要被高亮:

ABAP的語法高亮是如何在瀏覽器裏顯示的

具體邏輯如下圖:一旦敲入字符"w"後,onInput作爲事件處理函數觸發:

ABAP的語法高亮是如何在瀏覽器裏顯示的

函數$renderLine負責生成對應的HTML源代碼。輸入字符"new"被傳入函數getLineTokens來計算該字符串是關鍵字還是普通變量。

ABAP的語法高亮是如何在瀏覽器裏顯示的

在文件AceRndTokenizer.js裏, ABAP解析器按照我們期望的將“new”解析成關鍵字,因爲解析器擁有PAD文件的引用,因此它知道哪些字符串是關鍵字,哪些是普通變量。

ABAP的語法高亮是如何在瀏覽器裏顯示的

(4). DOM節點的源代碼在此處生成,"ace"和“keyword"做連接操作,生成最後我們在Chrome開發工具裏看到的完整css類ace_keyword.

ABAP的語法高亮是如何在瀏覽器裏顯示的

ABAP的語法高亮是如何在瀏覽器裏顯示的

謎底就這樣揭曉了。
要獲取更多Jerry的原創技術文章,請關注公衆號"汪子熙"或者掃描下面二維碼:

ABAP的語法高亮是如何在瀏覽器裏顯示的

ABAP的語法高亮是如何在瀏覽器裏顯示的

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章