NEXT社區|小課堂
由于近期NEXT社區加入很多新的小伙伴,有在校大學生,有對區塊鏈感興趣的傳統企業從業者。為了更方便、更系統的讓NEXT社區的伙伴們了解NEO的技術知識,因此我們開設了小課堂,每周3節,向大家普及NEO相關的知識要點!
NEXT社區小課堂|第十三課
NEOPython編譯器介紹
neo-boa編譯器介紹
neo-boa編譯器可將Python文件編譯為.avm格式,在NEO虛擬機中運行。NEO虛擬機可在NEO區塊鏈上執行合約。
編譯器支持Python語言子集。
1、目前功能
·?將Python語言子集編譯成.avm格式,在NEO虛擬機上運行
·??適用于Python3.4與3.5
2、未來功能
·?編譯更廣泛的Python語言子集
·??適用于Python3.6
3、已支持的Python功能
下文為目前支持的Python功能一覽。詳細介紹請參見boa.tests.src目錄中的案例
4、流控制
If、Else、Elif、While、Break、Methodcalls、Lamdbas、forxin
5、用于整數運算的算數運算符與相等運算符
ADD、SUB、MUL、DIV、ABS、LSHIFT、RSHIFT、AND、OR、XOR、MODULO、INVERT、GT、GTE、LT、LTE、EQ、NOTEQ
6、使用自定義內置功能進行列表創建。注意列表一經創建,其長度便不可更改。
fromboa.code.builtinsimportlist
#thisworks
x=list(length=10)
x=84
#thisalsoworks
x=
#thisdoesNOTwork
x=
x.append(1)
#支持列表操作
x=
y=x
#在可能的情況下,Python的某些__builtins__
5000萬枚USDT從Kraken轉到Bitfinex:金色財經報道,WhaleAlert監測數據顯示, 有5000萬枚USDT(約50,030,000美元)從Kraken轉到Bitfinex。[2023/5/25 10:39:54]
#已經根據NEO虛擬機的特點以自定義的方式實現
fromboa.code.builtinsimportrange
xrange=range(1,30)
#thisalsoworks
foriinrange(2,21):
i=i1
安裝
1、使用pip
pipinstallneo-boa
2、手動安裝
克隆存儲庫,進入項目目錄后創建Python3虛擬環境,并通過以下指令激活。
python3?-mvenvvenvsourcevenv/bin/activate
或單獨安裝Python3.5
virtualenv?-p?/usr/local/bin/python3.5venvsourcevenv/bin/activate
或單獨安裝Python3.5
virtualenv?-p?/usr/local/bin/python3.5venvsourcevenv/bin/activate
接著,通過以下指令安裝需求
pipinstall?-rrequirements.txt
3、基本用途
編譯器使用指南如下
fromboa.compiler?import?CompilerCompiler.load_and_save('path/to/your/file.py')
4、許可證
·開源MIT?
·主作者為localhuman
5、boa.compiler.Compiler
下文將介紹Compiler的具體實現細則。
6、classboa.compiler.Compiler
主編譯器接口類
通過下列程序加載python文件,編譯為.avm格式,并與python文件存儲在一個地方。
62,000,000 USDT從未知錢包轉移到Bitfinex:金色財經報道,Whale Alert數據顯示,62,000,000 USDT從未知錢包轉移到Bitfinex。[2023/3/6 12:43:58]
fromboa.compilerimportCompilerCompiler.load_and_save(‘path/to/your/file.py’)#returnthecompilerobjectforinspectioncompiler=Compiler.load(‘path/to/your/file.py’)#retrievethedefaultmoduleforinpectiondefault_module=compiler.default#retreivethedefault/entrymethodforthesmartcontractentry_method=default_module.main
7、defaule
取回默認或“入口”模塊。
返回值:默認反回值為boa.code.Module對象,異常時無返回值
8、staticinstance()
取回當前編譯器對象的實例,否則創建一個實例
返回值:編譯器對象的單個實例
9、staticload(path)
調用load來加載需編譯但無需寫為.avm格式的Python文件
參數:path–Python文件的編譯路徑
返回值:編譯器實例
用途:通過下述程序返回編譯器對象進行檢查
fromboa.compiler?import?Compilercompiler?=?Compiler.load(‘path/to/your/file.py’)
10、staticload_and_save(path,output_path=None)
調用load_and_save來加載需編譯為.avm格式的Python文件,并保存結果。
默認情況下,最終生成的.avm文件將與源文件存儲在一個地方。
參數:
·path——Python文件的編譯路徑
·output_path——已編譯的.avm文件的可選保存路徑
Nexo:多數加密投資者僅長期持有BTC和ETH:加密貨幣貸款公司Nexo的聯合創始人Antoni Trenchev日前表示:“有一個投資者部落,其中許多是千禧一代,他們將投資視為一種事業,一種運動,狗狗幣是發生在我們眼前的新時代潮流。”雖然狗狗幣的粉絲不斷掀起波瀾,一些加密貨幣投資者也提出了謹慎的想法。Wave Financial的高級交易員Justin Chuh認為,大多數加密貨幣投資者僅僅會長期持有比特幣和以太坊,而其他加密貨幣的上漲僅僅是“曇花一現”。(智通財經)[2021/4/21 20:41:53]
返回值:返回編譯器實例
用途:通過下述代碼返回編譯器對象進行檢查
fromboa.compilerimportCompiler
Compiler.load_and_save(‘path/to/your/file.py’)
11、write()
返回值:已編譯的Python程序的字節串
12、staticwrite_file(data,path)
通過指定路徑將輸出數據存儲至文件系統
參數:
·data——待寫入磁盤的數據字節串
·path——文件寫入路徑
13、boa.code.module.Module
下文將介紹Module的具體實現細則。
14、classboa.code.module.Module(path,module_name=”,is_sys_module=False,items_to_import=None)
模塊是包含代碼對象的頂層組件。例如,在path/to/my/file.py的編譯過程中,file.py中包含的項目即為模塊。一個可執行項可包含多個模塊。上述案例中的“默認”或“入口”模塊即為file.py。
調用Compiler.load_and_save(‘path/to/file.py’)時會專門為file.py創建一個模塊。若file.py導入了其他任何功能,那些模塊也會被添加至可執行項中,并置于Module.loaded_modules屬性中。
在模塊被當做方法處理,方法被當做基本塊處理,基本塊被處理為標記后,主模塊或default模塊的write()方法即被調用,將可執行項寫為字節串,返回磁盤并存儲。
公告 | Bitfinex將開通AST、AFR及FOAM相關交易對:據Bitfinex官方公告,加密貨幣交易所Bitfinex將開通 AST/USD、AST/ETH、AFR/USD、AFR/ETH、FOAM/USD及FOAM/ETH交易對。[2019/5/28]
如果您想檢查模塊內容,可使用Compiler.load(‘path/to/file.py’),該功能將返回一個編譯器實例。獲取該實例后,您便可以訪問編譯器的default模塊,從而訪問該默認模塊中裝入的其他模塊。
各模塊均包含byteplay3對象bp的引用,該對象包含可在Python解釋器中顯示的指令集。
您可對具備bp屬性的任意對象調用print(module.bp.code),結果將輸出一段Python解釋器代碼。
fromboa.compilerimportCompiler
module=Compiler.load
(‘./boa/tests/src/AddTest1.py’).default
print(module.bp.code)
LOAD_CONST
LOAD_CONST‘Main’
MAKE_FUNCTION0
STORE_NAMEMain
LOAD_CONSTNone
RETURN_VALUE
對可執行項進行處理與標記化后,便會生成虛擬機標記集,虛擬機標記雖與byteplay3標記相類似,但仍存在顯著區別。這些標記均包含在該模塊的all_vm_tokens屬性中。
您可調用module.to_s()來查看該程序,因為該程序已根據NEO虛擬機的特點進行了標記化。
>>>module.to_s()
LOAD_FAST?
LOAD_CONST
BINARY_MULTIPL??
STORE_FAST?
LOAD_FAST?
LOAD_CONST?
BINARY_ADD????
LOAD_FAST
LOAD_CONST
動態 | Bitfinex錢包僅剩約300萬枚USDT:據cryptovest報道,今日有另外1億枚USDT離開市場,被Bitfinex轉入Tether Treasury錢包,將USDT的存儲量提升至6.66億美元以上。在最新轉賬之后,Bitfinex的錢包中只剩下約300萬枚USDT。然而,即使有三分之一的USDT供應從市場上消失,普遍缺乏流動性仍使超過19%的交易都是與USDT的。例如,ONT和EOS的交易中超過25%是與USDT。此外,交易機制有助于支撐USDT的價格,這表明供應減少會造成稀缺。但是,這還不足以重建對USDT的信任。[2018/10/31]
BINARY_TRUE_DIVIDE
STORE_FAST?
LOAD_FAST?
LOAD_CONST?
BINARY_SUBTRACT
STORE_FAST
b''
LOAD_FAST
LOAD_FAST
BINARY_ADD????
LOAD_FAST?
BINARY_ADD
LOAD_FAST?
BINARY_ADD
NOP
15、add_method(method)
在模塊中添加方法如下:
Parameters:?method(boa.code.method.Method)——模塊中待添加的方法對象
返回值:顯示是否已添加該方法
返回值類型:布爾值
16、build()
將bp.code對象拆分成行,并合并多行,生成不同的項目。
17、link_methods()
關聯各方法地址
18、main
返回該模塊的默認方法
返回值:該模塊的默認方法
返回值類型:boa.code.method.Method
19、method_by_name(method_name)
在模塊的methods列表中查找方法名稱:parammethod_name:
待查找的方法名稱:typemethod_name:str
返回值:方法
返回值類型:boa.code.method.Method
20、module_path
返回該模塊的文件路徑
返回值:模塊路徑
返回值類型:str
21、orderered_methods
方法序列表
返回值:該模塊中的方法序列表
返回值類型:列表
22、process_action(lineset)
處理模塊中的動作,樣本如下,其目的類似于創建下列事件:
fromboa.blockchain.vm.Neo.ActionimportRegisterAction
#Registertheaction.
onRefund=RegisterAction(‘refund’,’to_address’,’amount’)
#Dispatchanaction.
onRefund(my_address,100)
參數:lineset(list)–包含應用程序調用注冊功能的行集
23、process_import(import_item)
處理該模塊中的導入語句
Parameters:?import_item(boa.code.items.Importsubclass)–
24、process_method(lineset)
處理包含byteplay3代碼對象的行集
參數:lineset(list)–需處理與添加的行集
25、process_smart_contract_app_registration(lineset)?
在智能合約中調用另一個智能合約時處理智能合約應用程序注冊事宜:
fromboa.blockchain.vm.Neo.AppimportRegisterAppCall
#registerthecontract
otherContract=RegisterAppCall(‘contract_hash’,’param1′,’param2′)
#callthecontract
result=otherContract(a,b)
參數:lineset(list)–包含應用程序調用注冊功能的行集
26、split_lines()
將模塊中的行集拆分成可編譯的對象集
27、to_s()
該方法的目的在于以可讀/標記化的格式打印可執行項的輸出值,樣本如下:
>>>fromboa.compilerimportCompiler
>>>module=Compiler.
load('./boa/tests/src/LambdaTest.py').default
>>>module.write()
>>>module.to_s()
LOAD_CONST
STORE_FAST
LOAD_FAST
CALL_FUNCTION?Main..
q_1
STORE_FAST
b''
m??
NOP?
RETURN_VALUE??
b''?
LOAD_FAST?x?
LOAD_CONST?
BINARY_ADD??
NOP????
RETURN_VALUE?
28、tokenize()
將boa.code.pytoken.PyToken對象集轉化為boa.code.vmtoken.VMToken對象。
29、total_lines
獲取該方法的總行數
返回值:總行數
返回值類型:int
30、total_module_variables
獲取局部變量總數
返回值:該模塊中的變量總數
返回值類型:int
31、vm_tokens
返回該方法中的虛擬機標記列表
返回值:該方法中的虛擬機標記列表
返回值類型:列表
32、write()
將標記器當前的狀態寫為字節串
返回值:當前標記器的字節串
返回值類型:字節
原文鏈接:https://github.com/localhuman/neo-python
往期精彩內容
NEXT社區小課堂|第五課:NEO-共識算法dBFT源碼解析
NEXT社區小課堂|第八課:如果往錯誤的NEO地址轉賬會發生什么
NEXT社區小課堂|第十課:如何正確理解NEO平臺上的GAS
NEXT社區小課堂|第十一課:NEO中數字的表達和運算
??
聯系我們?
微博:https://weibo.com/u/6724929880
官網:https://neonext.club/
QQ群:612334080
電報:https://t.me/neonextop
twitter:https://twitter.com/NE0NEXT
關注NEONEXT官方公眾號
獲取更多一手社區資訊
6月4日凌晨,波場TRON創始人孫宇晨在個人微博上宣布,以破記錄高價456.7888萬美元拍下今年“巴菲特慈善午餐”,成為第20屆“巴菲特慈善午餐”的最終競拍贏家.
1900/1/1 0:00:00平行鏈公平分配的計劃草案,以及波卡未來將如何處理額外的平行鏈插槽可用性的說明。隨著波卡主網發布時間的接近,Web3基金會收到了很多關于平行鏈的問題:如何進行初始分配以及如何成為平行鏈.
1900/1/1 0:00:00我們都知道,區塊鏈上的數據是不可篡改且永久存儲的,所以有的人將愛慕之情寫在區塊鏈上,有的人將產權寫在區塊鏈上.
1900/1/1 0:00:005月,隨著比特幣的暴漲,區塊鏈的監管及扶持政策也產生了一些變化。據互鏈脈搏不完全統計,5月份,國內外區塊鏈扶持相關的政策信息數量均下降,而監管方面的政策信息數量基本持平,且各國的監管力度加強.
1900/1/1 0:00:00月報摘要“投資者調研”:近70%的數字資產投資者于5月獲利或持平,超70%的投資者認為,6月BTC價格僅會出現小范圍波動.
1900/1/1 0:00:00或許人就是這樣, 越害怕什么, 就越容易被什么吸引。 蕾秋·喬伊斯《一個人的朝圣》|孫宇晨成功拍下巴菲特的午宴||加密貨幣支持者與反對者的會面?|一向“愛蹭熱度”的孫宇晨再次憑借天價拍下巴菲特慈.
1900/1/1 0:00:00