The present invention relates to the field of translation systems. More particularly, the invention relates to a method of converting logic written in software code (e.g., that may represent smart contract and/or other block-chain based agreements and logic instruments) into text such as an ordinary text in a target language such as the English language or any other human language.
As more users are connected to the Internet and conduct their daily activities electronically, computer users may sometimes need to understand the content, meaning or logic of at least some of the software codes that they might ran into during their daily activities.
For example, distributed ledger systems provide a platform for the execution of smart contracts. Smart contracts typically include program instructions that may be executed in response to a transaction in the distributed ledger system addressed to the contract. Smart contracts may also represent legal contracts between users, with program functions of the smart contracts implementing terms, conditions, etc. of the legal contract. Unfortunately, many users of such distributed ledger systems may found the content of smart contracts and/or other block-chain based agreement and logic instruments not clear enough for them.
It is an object of the present invention to provide a system which is capable of allowing non-technical people to understand the content of software codes, e.g., set of instructions that form smart contracts.
It is another object of the present invention to provide a system which is capable of simplifying logic written as code to human language in a specific context to make it easier to examine for that specific need, for example, from a security standpoint, or a financial aspect.
Other objects and advantages of the invention will become apparent as the description proceeds.
The present invention relates to a method of converting logic written in software code into text, comprising: converting the code to a structured format that represents the logic described in each function of said code as a tree of elements, and mapping the elements of the structured format into corresponding counterparts in a target language for obtaining a text translation of the structured format.
According to an embodiment of the invention, the method further comprises applying refinement technique to increase the readability of the obtained text translation.
According to an embodiment of the invention, the structured format is an Abstract Syntax Tree (AST) structure.
According to an embodiment of the invention, the refinement technique is selected from the group comprising of: pattern matching, reordering, in-lining, flattening, or any combination thereof.
According to an embodiment of the invention, the pattern matching comprises converting a pattern into a higher-level translation that matches this pattern.
According to an embodiment of the invention, the reordering comprises changing the order of elements of the structure format.
According to an embodiment of the invention, the in-lining comprises bringing information to where it is used, thereby including a declaration of a function near where it is called.
According to an embodiment of the invention, the flattening comprises taking code that is split into several components that use inheritance and converting them to single component by flattening the hierarchy.
According to an embodiment of the invention, the logic written in software code is a smart contract of a distributed ledger system.
According to an embodiment of the invention, the method further comprises producing one or more logic diagrams describing the high-level or low-level logic of the code.
In another aspect, the present invention relates to a system, comprising: a) at least one processor; and b) a memory comprising computer-readable instructions which when executed by the at least one processor causes the processor to execute a translation process, wherein the translation process:
In the drawings:
Various terms are used throughout the description and the claims which should have conventional meanings to those with a pertinent understanding of computer programming. Additionally, various descriptive terms are used in describing the exemplary embodiments in order to facilitate an explanation of them, and to aid one's understanding. However, while the description to follow may entail terminology which is perhaps tailored to certain computing or programming environments, such as Solidity (i.e., an object-oriented, high-level language for implementing smart contracts that is designed to be executed by a block-chain-based platform such as Ethereum) or software codes at other languages andcomputer systems, it will be appreciated by a person skilled in the art that such terminology is employed in a descriptive sense and not a limiting sense. Where a confined meaning of a term is intended, it will be explicitly set forth or otherwise apparent from the disclosure.
Reference will now be made to several embodiments of the present invention, examples of which are illustrated in the accompanying figures for purposes of illustration only. One skilled in the art will readily recognize from the following description that alternative embodiments of the program modules and code-to-text conversation methods illustrated herein may be employed without departing from the principles of claimed invention.
According to an embodiment of the present invention, the process may involve the following steps:
The above steps will be described in further details hereinafter. However, while the invention will be described in the general context of program modules or codes that execute in conjunction with an application program that runs on an operating system on a computer system that is associated with smart contracts in distributed ledger systems, those skilled in the art will recognize that the invention may also be implemented in combination with other program modules. The functions described herein may be performed by executable code and instructions stored in computer readable medium and running on one or more processor-based systems. Embodiments of the invention may be implemented as a computer process, e.g., a computer system that encodes a computer program of instructions for executing the computer process.
According to an embodiment of the present invention, the translation process uses conversion of logic written in software code (e.g., a source code) to an AST structure, as a first step (step 11). An AST is an internal format used by compilers to describe code during the compilation process. A compiler converts the code, provided as text, to an AST, and then parses the AST to generate machine code in binary format. Since the AST is a structured format, it is easy for the compiler to use when generating machine code in binary format.
According to an embodiment of the present invention, converting to an AST format during translation has several uses and advantages:
AST is an internal format used by the compiler and is generally just used as a step in generating machine code.
The above conversation embodiment of a software code to a structured format in AST will be better understood through the following illustrative and non-limitative example for a pseudo-code of an “add” function (see also
A possible AST of such an “add” function could look something like (the following conversion of the software code of the “add” function is extremely simplified for readability):
This example of AST represents the logic described in the “add” function as a tree of elements. However this is a very simplified version of what an actual AST looks like.
The simplification is designed to convey that the AST contains all the information in the code in a more structured manner.
Using the AST, the translation process can generate a very technical and verbose translation by converting elements in the AST to their appropriate English counterparts (step 12).
This consists of creating a table of mappings from elements in the AST to an appropriate description/translation of their underlying intent. For example, a BinaryOperation with an operator of “+” could be translated to “the addition of {left} and {right}”.
Assuming a complete mapping of all possible elements in the AST is created, performing the conversion on the entire AST would produce a translation that is complete. That is, it includes all the logic in the original AST.
Since the translation is created directly from the AST, and is created using a direct mapping, it would create a translation that is very verbose and detailed, and in many ways difficult to read. It would still be structured like code (function invoked in one location would be defined in another place in the translation). This requires skills and approaches usually used for understanding code, and would mean the translation is not accessible to those without the skills in understanding this type of logic.
Given the above code, a possible verbose translation could look something like:
“Create a function named add that receives as parameters: ‘a’—a number, ‘b’—a number. This function performs the following steps:
Create a function named add4 that receives as parameters: ‘a’—a number, ‘b’—a number, ‘c’— a number, ‘d’—a number. This function performs the following steps:
While this translation is accurate and full, it does not clearly allow a person to understand what the add4 function does (adds 4 numbers together). As such, additional refinements are further required.
Refinement techniques are a set of methods that can be used to improve the output translation in a way that greatly impacts its usefulness for non-technical users (step 13). The goals of the refinement technique are to increase the readability of the translation as much as possible. This would, in most cases, also involve shortening the actual length of the translation text, though that is not required.
According to an embodiment of the present invention, one or more of the following techniques can be used to refine the output:
The translation process detailed above is a direct translation of code to a target language, covering the basic logic of a smart contract as defined in the source code 31. However, this translation lacks context, which can be used to greatly improve the quality of translation.
According to an embodiment of the invention, a basic form of context could be the intended use of the smart contract. The user's interest in the smart contract, and why he would like to understand the contract, allows generating translations that are more fitting to the user's needs. For example, when assessing a contract for financial viability, that is, whether the financial model makes sense, edge cases where the smart contract would behave differently are of lesser importance. On the other hand, when assessing a smart contract for bugs or security issues, these cases should be highlighted or given additional focus.
According to an embodiment of the invention, a more advanced form of context is the context of a specific operation relating to this code. While the translation described until now described the logic under all cases, a translation could translate only a single case, and how this logic would apply to it. Looking back at the example of the “add” function, our initial translation described this as a function that could add any numbers. However, when examining an actual run of this function, it doesn't add two unknown numbers—it adds two known values—and these values can be included in the translation.
Under this case, the translation logic is not translating the potential logic of a smart contract, but rather translating the logic the contract would use or has used processing a specific case. This means the translation can remove sections of the contract logic that are irrelevant in the specific context (such as an “if” statement that was not taken, its body might not really matter only why it wasn't taken).
The translation process of the present invention may translate the smart contract logic under many different contexts and assist non-programmers in understanding specific cases and how they run through the contract.
According to an embodiment of the present invention, the output language created by the translation does not necessarily need to be text. As an example, the translation could produce various logic diagrams describing the high- or low-level logic of the contract. An example of such possible output would be to produce a Business Process Model and Notation (BPMN) model out of the smart contract or any other form of graphical representation that is suitable for specifying business processes in a business process model. Such output would enable producing a model in a standard language that describes the logic of the contract.
As will be appreciated by the skilled person the process described hereinabove results in a system which is capable of allowing non-technical people to understand the content of smart contracts, as it simplifies logic written as code to human language in a specific context to make it easier to examine for that specific need, for example, from a security standpoint, or a financial aspect.
All the above description and examples have been given for the purpose of illustration and are not intended to limit the invention in any way. Many different mechanisms, methods of transforming logic written in software code into a readable text in a target language, electronic and logical elements can be employed, all without exceeding the scope of the invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/IL2019/050144 | 2/6/2019 | WO |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2019/155462 | 8/15/2019 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
9372672 | Thomas | Jun 2016 | B1 |
20040225999 | Nuss | Nov 2004 | A1 |
20060206789 | Bakman et al. | Sep 2006 | A1 |
20090064091 | Tonkin | Mar 2009 | A1 |
20090083723 | Zawawy | Mar 2009 | A1 |
20120159442 | Dearman | Jun 2012 | A1 |
20130227533 | Tonkin et al. | Aug 2013 | A1 |
20140173562 | Rothley et al. | Jun 2014 | A1 |
20160062753 | Champagne | Mar 2016 | A1 |
20170039188 | Allen | Feb 2017 | A1 |
20190236559 | Padmanabhan | Aug 2019 | A1 |
Number | Date | Country |
---|---|---|
2650785 | Oct 2010 | EP |
Entry |
---|
Matt Suiche, “Porosity: A Decompiler For Blockchain-Based Smart Contracts Bytecode”, Jul. 7, 2017, Comae Technologies (Year: 2017). |
Written Opinion of Search Authority dated Mar. 28, 2019 in International Application No. PCT/IL2019/050144. |
Number | Date | Country | |
---|---|---|---|
20200364037 A1 | Nov 2020 | US |
Number | Date | Country | |
---|---|---|---|
62627806 | Feb 2018 | US |