JP2019040399A - Converter and conversion method - Google Patents
Converter and conversion method Download PDFInfo
- Publication number
- JP2019040399A JP2019040399A JP2017161973A JP2017161973A JP2019040399A JP 2019040399 A JP2019040399 A JP 2019040399A JP 2017161973 A JP2017161973 A JP 2017161973A JP 2017161973 A JP2017161973 A JP 2017161973A JP 2019040399 A JP2019040399 A JP 2019040399A
- Authority
- JP
- Japan
- Prior art keywords
- conversion
- source
- converted
- manual correction
- cobol
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000006243 chemical reaction Methods 0.000 title claims abstract description 477
- 238000000034 method Methods 0.000 title claims description 28
- 238000012360 testing method Methods 0.000 claims abstract description 46
- 238000012937 correction Methods 0.000 claims description 142
- 238000013461 design Methods 0.000 claims description 69
- 238000012790 confirmation Methods 0.000 claims description 37
- 230000007547 defect Effects 0.000 claims description 34
- 230000008569 process Effects 0.000 claims description 13
- 238000012795 verification Methods 0.000 claims description 2
- 238000011161 development Methods 0.000 abstract description 43
- 230000007704 transition Effects 0.000 abstract 1
- 230000018109 developmental process Effects 0.000 description 42
- 230000008014 freezing Effects 0.000 description 11
- 238000007710 freezing Methods 0.000 description 11
- 230000008859 change Effects 0.000 description 7
- 238000012986 modification Methods 0.000 description 7
- 230000004048 modification Effects 0.000 description 7
- 101150073162 spa1 gene Proteins 0.000 description 5
- 238000012545 processing Methods 0.000 description 4
- 238000013509 system migration Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 3
- 230000009467 reduction Effects 0.000 description 3
- 238000007493 shaping process Methods 0.000 description 3
- 230000010365 information processing Effects 0.000 description 2
- 238000012423 maintenance Methods 0.000 description 2
- 238000013508 migration Methods 0.000 description 2
- 230000005012 migration Effects 0.000 description 2
- 230000008901 benefit Effects 0.000 description 1
- 230000002950 deficient Effects 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 235000019580 granularity Nutrition 0.000 description 1
- 230000008676 import Effects 0.000 description 1
- 238000009495 sugar coating Methods 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
- 238000013519 translation Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/51—Source to source
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
- G06F8/76—Adapting program code to run in a different environment; Porting
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Devices For Executing Special Programs (AREA)
- Stored Programmes (AREA)
- Debugging And Monitoring (AREA)
Abstract
Description
本発明は、変換装置および変換方法に関する。 The present invention relates to a conversion device and a conversion method.
現行システムから新システムへのシステム移行において、例えば、プログラムのコンバージョン開発という作業がある。コンバージョン開発では、現行システムに用いられる現行プログラムソース(変換元ソース)のプログラム言語(例:COBOL(COmmon Business Oriented Language))を別のプログラム言語(例:JAVA(登録商標))に置き換えて、新システムに用いられる新プログラムソース(変換後ソース)を作成する。 In the system migration from the current system to the new system, for example, there is a work of conversion development of a program. In conversion development, the program language of the current program source (conversion source source) used in the current system (eg COBOL (COmmon Business Oriented Language)) is replaced with another program language (eg JAVA (registered trademark)) Create a new program source (source after conversion) used in the system.
従来のコンバージョン開発では、例えば、言語文法上の命令単位や構文単位で言語変換を行う変換ツールを複数種類用意し、変換元ソースに対して各変換ツールを順次実行することで、言語変換がなされた変換後ソースを作成していた。このとき、費用対コストの理由等で、変換元ソースの一部に対しては変換ツールを実行できない場合がある。この場合、手修正で当該一部に対して言語変換を行い、言語変換が完全になされた変換後ソースを得る。 In conventional conversion development, for example, multiple types of conversion tools that perform language conversion in language grammar instruction units and syntax units are prepared, and language conversion is performed by sequentially executing each conversion tool on the source of conversion. Was creating a source after conversion. At this time, the conversion tool may not be executed on a part of the conversion source source due to cost vs. cost. In this case, language conversion is performed on the part by manual correction, and a post-conversion source in which language conversion is completely performed is obtained.
また、コンバージョン開発では、得られた変換後ソースに不良があるか否かを確認するための確認テスト(実機確認)が行われる。具体的には、変換元ソースおよび変換後ソースに同じ入力値を入力し、両者間で同じ出力値が得られれば不良なし、異なる出力値が得られれば不良ありと判定する。コンバージョン開発では、変換後ソースに不良がある場合、不良原因を作り込んだ変換ツールまたは手修正を特定し、特定した変換ツールまたは手修正を修正して不良原因を取り除くことになる。 In conversion development, a confirmation test (actual machine confirmation) is performed to confirm whether or not the obtained converted source has a defect. Specifically, the same input value is input to the conversion source source and the converted source, and if the same output value is obtained between them, it is determined that there is no defect, and if a different output value is obtained, it is determined that there is a defect. In conversion development, when there is a defect in the converted source, the conversion tool or manual correction that has created the cause of the defect is identified, and the identified conversion tool or manual correction is corrected to remove the defect cause.
一般的に、変換後ソースについて、不良原因となる行を特定することはできる。しかし、変換ツールの順次実行と手修正との組合せによる従来の言語変換では、不良原因を作り込んだ変換ツールまたは手修正を特定することは、有識者による検討が必要となるほど困難であり、大きな不良対応コストを必要とする。結果的に、従来のコンバージョン開発における不良対応コストは大きい。 In general, it is possible to identify a line that causes a defect in the converted source. However, in the conventional language conversion that combines the sequential execution of conversion tools and manual correction, it is difficult to identify the conversion tool or manual correction that has created the cause of the defect, and it is difficult to identify by the expert. Needs corresponding costs. As a result, defect handling costs in conventional conversion development are high.
特許文献1には、「メインフレーム系のデータをオープン系のデータに変換する変換手段と、入力データのバイトごとに色を割り当てる割り当て手段と、前記割り当て手段によりバイトごとに色を割り当てられた前記入力データを表示する表示手段と、を有し、前記メインフレーム系のデータが入力データとして入力された場合、前記割り当て手段は、前記メインフレーム系のデータのバイトごとに色を割り当て、前記表示手段は、前記割り当て手段によりバイトごとに色を割り当てられた前記メインフレーム系のデータを表示し、前記オープン系のデータが入力データとして入力された場合、前記割り当て手段は、前記オープン系のデータごとに色を割り当て、前記表示手段は、前記割り当て手段によりバイトごとに色を割り当てられた前記オープン系のデータを表示する情報処理装置。」について開示されている。
特許文献1によれば、メインフレーム系のデータに相当する変換元ソースから、オープン系のデータに相当する変換後ソースへの変換が適切に行われたか否かを概略的に確認可能とし、変換後ソースについて、不良原因となる行を表示することは可能と思われる。しかし、特許文献1には、不良原因を作り込んだデータの変換を特定することについては記載も示唆もされていない。そのため、特許文献1では、コンバージョン開発における不良対応コストを削減することはできない。
According to
本発明は、このような事情に鑑みて、コンバージョン開発等のシステム移行における不良対応コストを削減することを課題とする。 In view of such circumstances, an object of the present invention is to reduce the cost of handling defects in system migration such as conversion development.
前記課題を解決するために、本発明は、
変換元ソースを変換後ソースに変換する変換装置であって、
前記変換元ソースの一部を前記変換後ソースの一部に変換して生成される変換途中ソースの集合について、前記変換途中ソースの各々への変換に関するメタ情報を管理するメタ情報管理部と、
前記変換後ソースの確認テストで不良があった場合、前記メタ情報を参照して、前記不良の不良原因を作り込んだ変換を特定するテスト部と、を備える、
ことを特徴とする。
その他の発明については、後記する。
In order to solve the above problems, the present invention provides:
A conversion device for converting a conversion source source into a converted source,
A meta information management unit for managing meta information related to conversion to each of the conversion-in-progress sources for a set of conversion-sources generated by converting a part of the conversion source source into a part of the converted source;
When there is a defect in the confirmation test of the converted source, a test unit that identifies the conversion that created the cause of the defect by referring to the meta information,
It is characterized by that.
Other inventions will be described later.
本発明によれば、コンバージョン開発等のシステム移行における不良対応コストを削減することができる。 ADVANTAGE OF THE INVENTION According to this invention, the defect handling cost in system transfer, such as conversion development, can be reduced.
続いて、本発明の実施形態について、図面を参照して説明する。本実施形態の変換装置は、入力部、出力部、制御部、および記憶部といったハードウェアを含むコンピュータである。例えば、制御部がCPU(Central Processing Unit)から構成される場合、その制御部を含むコンピュータによる情報処理は、CPUによるプログラム実行処理で実現される。また、そのコンピュータが含む記憶部は、CPUの指令により、そのコンピュータの機能を実現するためのさまざまなプログラムを記憶する。これによりソフトウェアとハードウェアの協働が実現される。前記プログラムは、記録媒体に記録したり、ネットワークを経由したりすることで提供することができる。 Next, embodiments of the present invention will be described with reference to the drawings. The conversion device of this embodiment is a computer including hardware such as an input unit, an output unit, a control unit, and a storage unit. For example, when the control unit is configured by a CPU (Central Processing Unit), information processing by a computer including the control unit is realized by program execution processing by the CPU. The storage unit included in the computer stores various programs for realizing the functions of the computer in accordance with instructions from the CPU. This realizes cooperation between software and hardware. The program can be provided by being recorded on a recording medium or via a network.
≪構成≫
図1に示すように、本実施形態の変換装置1は、コンバータc1〜cnと、コンバータ別変換結果リポジトリr11〜r1nと、バージョン管理ツール10と、メタ情報DB(DataBase)11と、マージツールm1と、機械変換結果リポジトリr2と、手修正管理ツール20と、手修正実施用ワークスペース21と、手修正結果リポジトリr3と、マージツールm2と、変換結果リポジトリr4と、テストツール30と、を備える。
≪Configuration≫
As shown in FIG. 1, the
図1中の変換元COBOLソースs1は、COBOLで記述されたCOBOLコード(「COBOL1」、「COBOL2」、・・・、「COBOLN」、「COBOLX」)を記録したソースコードであり、顧客が現行システムを運用するために実行される。
また、図1中の変換後Javaソースs2は、JAVAで記述されたJAVAコード(「Java1」、「Java2」、・・・、「JavaN」、「JavaX」)を記録したソースコードであり、顧客が新システムを運用するために実行される。
図1中の各種の変換途中ソースs31〜s3n,s4,s5については後記する。
The conversion source COBOL source s1 in FIG. 1 is a source code in which a COBOL code described in COBOL (“COBOL 1”, “COBOL 2”,..., “COBOL N”, “COBOL X”) is recorded. It is executed to operate the system.
Further, the converted Java source s2 in FIG. 1 is a source code in which JAVA codes described in JAVA (“Java1”, “Java2”,..., “JavaN”, “JavaX”) are recorded. Is executed to operate the new system.
Various conversion sources s31 to s3n, s4, and s5 in FIG. 1 will be described later.
[コンバータc1〜cn]
コンバータc1〜cnは、変換元COBOLソースs1のCOBOLコードの一部をJAVAコードに機械的に変換する。コンバータc1〜cnの各々が変換するCOBOLコードとしての文字列は予め決められており、例えば、命令語単位で用意することができる(例:COBOLコードの「MOVE」をJAVAコードの「set」に変換するコンバータ)。また、コンバータc1〜cnは、構文単位で用意することもでき、言語文法上のさまざまな粒度で設計することができる。
[Converters c1 to cn]
The converters c1 to cn mechanically convert a part of the COBOL code of the conversion source COBOL source s1 into a JAVA code. A character string as a COBOL code to be converted by each of the converters c1 to cn is determined in advance, and can be prepared, for example, in units of instruction words (eg, “MOVE” of the COBOL code is changed to “set” of the JAVA code). Converter to convert). Further, the converters c1 to cn can be prepared in units of syntax, and can be designed with various granularities in the language grammar.
なお、コンバータc1〜cnの各々は、変換元COBOLソースs1の同じ行を重複して変換することが無いように設計されている。図1に示すように、コンバータc1が変換元COBOLソースs1の「COBOL1」を「Java1」に変換するが、コンバータc2などが同じ変換をすることは無い。同様にして、コンバータc2〜cnの各々は、変換元COBOLソースs1の「COBOL2」〜「COBOLN」の各々を、「Java2」〜「JavaN」に変換する。変換元COBOLソースs1の「COBOLX」は、手修正されるCOBOLコードであるが、詳細は、後記する。 Each of converters c1 to cn is designed so as not to convert the same row of conversion source COBOL source s1 redundantly. As shown in FIG. 1, the converter c1 converts “COBOL1” of the conversion source COBOL source s1 into “Java1”, but the converter c2 and the like do not perform the same conversion. Similarly, each of converters c2 to cn converts each of “COBOL2” to “COBOLN” of conversion source COBOL source s1 into “Java2” to “JavaN”. “COBOLX” of the conversion source COBOL source s1 is a manually corrected COBOL code, details of which will be described later.
[コンバータ別変換結果リポジトリr11〜r1n]
コンバータ別変換結果リポジトリr11〜r1nの各々は、変換元COBOLソースs1に対してコンバータc1〜cnの各々を実行することでCOBOLコードの一部がJAVAコードに変換された変換途中ソースs31〜s3nの各々を格納する。
[Conversion result repository by converter r11 to r1n]
Each of the conversion result repositories r11 to r1n classified by converter executes the converters c1 to cn with respect to the conversion source COBOL source s1 to convert part of the COBOL code into JAVA code. Store each one.
[バージョン管理ツール10]
バージョン管理ツール10は、コンバータc1〜cnの各々が変換元COBOLソースs1から変換途中ソースs31〜s3nの各々に変換したときの変換に関する情報をメタ情報として取得して管理する。メタ情報は、例えば、変換ごとに、変換元COBOLコードと変換後JAVAコードとの対応、変換を実行したコンバータのID(Identifier)、変換の内容(例:「MOVE」→「set」)、変換設計のID、変換の実行の日時、補足説明としてのコメントを含むが、これらに限定されない。本実施形態のバージョン管理ツール10は、Gitなどの分散型バージョン管理ツールとして実装することができる。
[Version management tool 10]
The
[メタ情報DB11]
メタ情報DB11は、バージョン管理ツール10が取得したメタ情報を格納する。なお、本実施形態の変換装置1に、TortoiseGitなどのGUI(Graphic User Interface)を備え、メタ情報や変換途中ソースs31〜s3nを視覚的に追跡可能としてもよい。
[Meta information DB11]
The meta information DB 11 stores the meta information acquired by the
[マージツールm1]
マージツールm1は、コンバータ別変換結果リポジトリr11〜r1nが格納する変換途中ソースs31〜s3nに対してマージ処理をする。マージ処理は、例えば、分散型バージョン管理ツールで用いられる3方向マージ(周知であり、詳細な説明は省略)を用いることができる。
[Merge tool m1]
The merge tool m1 performs a merge process on the conversion intermediate sources s31 to s3n stored in the converter-specific conversion result repositories r11 to r1n. For the merge process, for example, a three-way merge (a well-known and detailed description is omitted) used in a distributed version management tool can be used.
例えば、マージツールm1は、変換元COBOLソースs1を親とし、親から派生した変換途中ソースs31〜s3nのいずれか2つを子として3方向マージをし、2つの子の変換箇所を親に反映した結果物(変換がより進んだ変換途中ソース)を得る。2つの子の変換箇所が同じ行であれば3方向マージは失敗するが(コリジョン)、本実施形態のコンバータc1〜cnは、変換箇所が唯一となるように設計されているため、2つの子の変換箇所が同じ行になることはない。 For example, the merge tool m1 performs a three-way merge with the conversion source COBOL source s1 as a parent and any two of the conversion intermediate sources s31 to s3n derived from the parent as a child, and reflects the conversion points of the two children in the parent Result (conversion source with more advanced conversion). If the conversion locations of the two children are the same row, the three-way merge will fail (collision), but the converters c1 to cn of this embodiment are designed so that the conversion locations are unique, so the two children Will not be on the same line.
例えば、マージツールm1は、まず、変換元COBOLソースs1を親とし、変換途中ソースs31,s32を第1の子、第2の子として3方向マージをし、第1の結果物を得る。次に、マージツールm1は、変換元COBOLソースs1を親とし、第1の結果物を第1の子、変換途中ソースs33を第2の子として3方向マージをし、第2の結果物を得る。上記のように3方向マージを多段的に実行することで、コンバータc1〜cnによる機械的な変換がすべて実行された変換途中ソースs4(「Java1」、「Java2」、・・・、「JavaN」、「COBOLX」)を得ることができる。
また、マージツールm1は、マージ処理として、変換途中ソースs31〜s3nを一括してマージし、変換途中ソースs4を得ることもできる。
For example, the merge tool m1 first performs a three-way merge using the conversion source COBOL source s1 as a parent, the conversion source sources s31 and s32 as a first child, and a second child, and obtains a first result. Next, the merge tool m1 performs a three-way merge with the conversion source COBOL source s1 as the parent, the first result as the first child, and the conversion intermediate source s33 as the second child, and the second result as the second result. obtain. By executing the three-way merging in multiple stages as described above, the conversion source s4 (“Java1”, “Java2”,..., “JavaN”) in which all the mechanical conversions by the converters c1 to cn are executed. , “COBOLX”).
Further, the merge tool m1 can also merge the conversion sources s31 to s3n at a time as a merge process to obtain the conversion source s4.
[機械変換結果リポジトリr2]
機械変換結果リポジトリr2は、マージツールm1によって、機械的な変換の結果がすべてマージされた変換途中ソースs4を格納する。
[Machine conversion result repository r2]
The machine conversion result repository r2 stores the conversion source s4 in which all the results of the mechanical conversion are merged by the merge tool m1.
[手修正管理ツール20]
手修正管理ツール20は、変換元COBOLソースs1の一部から変換後Javaソースs2の一部への変換を行うための手修正を管理する。具体的には、手修正管理ツール20は、変換元COBOLソースs1のCOBOLコード「COBOLX」を、変換後Javaソースs2のJAVAコード「JavaX」に手修正で変換する。
また、手修正管理ツール20は、バージョン管理ツール10に対して、手修正の変換に関する情報をメタ情報として出力する。
[Hand correction management tool 20]
The manual
In addition, the manual
なお、COBOLコードからJAVAコードへの変換を手修正で行う場合とは、言語仕様の相違に起因して、同じCOBOLコードであれば同じ機械変換を行うというルールがあてはまらない場合である。具体的には、以下の手修正必要例1〜3に該当する場合である。
手修正必要例1:複数の同じデータ項目名の存在
手修正必要例2:明確なデッドコード(到達不能コード)の存在
手修正必要例3:複数の同じ分岐条件の存在
The case where the conversion from the COBOL code to the JAVA code is performed by manual correction is a case where the same machine conversion is not applied to the same COBOL code due to a difference in language specifications. Specifically, this is a case corresponding to the following manual correction required examples 1 to 3.
Manual correction required example 1: Existence of multiple data item names Manual correction required example 2: Presence of clear dead code (unreachable code) Manual correction required example 3: Existence of multiple identical branch conditions
手修正必要例1に関しては、例えば、
〔COBOLコード〕
01 D1 PICTURE X(2) VALUES ‘AZ’.
01 D1 PICTURE 9(2) VALUES 10.
を機械変換した場合には、
〔JAVAコード〕
String d1 = “AZ”
int d1 10;
が作成される。上記のCOBOLコードは、COBOLの文法上問題はないが、上記のJAVAコードは、JAVAでは変数名重複によるコンパイルエラーとなってしまう。
Regarding the manual correction example 1, for example,
[COBOL code]
01 D1 PICTURE X (2) VALUES 'AZ'.
01 D1 PICTURE 9 (2)
Is machine converted,
[JAVA code]
String d1 = “AZ”
Is created. The above COBOL code has no problem in the syntax of COBOL, but the above JAVA code causes a compilation error due to variable name duplication in JAVA.
手修正必要例2に関しては、例えば、
〔COBOLコード〕
EXIT.
MOVE A TO B.
を機械変換した場合には、
〔JAVAコード〕
return;
b.set(a);
が作成される。上記のCOBOLコードは、COBOLの文法上問題はないが、上記のJAVAコードは、JAVAでは明確なデッドコードによるコンパイルエラーとなってしまう。
With regard to Manual Correction Need Example 2, for example,
[COBOL code]
EXIT.
MOVE A TO B.
Is machine converted,
[JAVA code]
return;
b.set (a);
Is created. The above COBOL code has no problem in the syntax of COBOL, but the above JAVA code causes a compilation error due to a clear dead code in JAVA.
手修正必要例3に関しては、例えば、
〔COBOLコード〕
EVALUATE A
WHEN 0
〜〜
CONTINUE
WHEN 0
〜〜
END EVALUATE.
を機械変換した場合には、
〔JAVAコード〕
switch(a){
case 0:
〜〜〜;
break;
case 0:
〜〜〜;
:
}
が作成される。上記のCOBOLコードは、COBOLの文法上問題はないが、上記のJAVAコードは、JAVAでは分岐条件の重複によるコンパイルエラーとなってしまう。
With regard to Manual Correction Need Example 3, for example,
[COBOL code]
EVALUATE A
WHEN 0
~~
CONTINUE
WHEN 0
~~
END EVALUATE.
Is machine converted,
[JAVA code]
switch (a) {
case 0:
~~~;
break;
case 0:
~~~;
:
}
Is created. The above COBOL code has no problem in the syntax of COBOL, but the above JAVA code causes a compilation error due to duplication of branch conditions in JAVA.
手修正必要例1〜3に該当する場合には、同じCOBOLコードであっても、JAVAコードにおいて同じ動作をするように、異なる手修正結果を作成する。 When the manual correction required examples 1 to 3 are applicable, different manual correction results are created so that the same operation is performed in the JAVA code even if the COBOL code is the same.
[手修正実施用ワークスペース21]
手修正実施用ワークスペース21は、手修正管理ツール20による手修正を実行するための作業領域である。
[
The manual
[手修正結果リポジトリr3]
手修正結果リポジトリr3は、変換元COBOLソースs1に対して手修正管理ツール20による手修正を実行することでCOBOLコードの一部がJAVAコードに変換した変換途中ソースs5を格納する。
[Manual correction result repository r3]
The manual correction result repository r3 stores the conversion source s5 in which a part of the COBOL code is converted into the JAVA code by executing the manual correction by the manual
[マージツールm2]
マージツールm2は、機械変換結果リポジトリr2に格納された変換途中ソースs4と、手修正結果リポジトリr3に格納された変換途中ソースs5とをマージする。具体的には、マージツールm2は、変換元COBOLソースs1を親とし、変換途中ソースs4を第1の子、変換途中ソースs5を第2の子として3方向マージをし、変換後Javaソースs2を得る。
また、マージツールm1およびマージツールm2が、マージ処理として、変換途中ソースs31〜s3n、および、変換途中ソースs5を一括してマージし、変換後Javaソースs2を得ることもできる。
[Merge tool m2]
The merge tool m2 merges the conversion intermediate source s4 stored in the machine conversion result repository r2 and the conversion intermediate source s5 stored in the manual correction result repository r3. Specifically, the merge tool m2 performs a three-way merge with the conversion source COBOL source s1 as a parent, the conversion intermediate source s4 as a first child, and the conversion intermediate source s5 as a second child, and the converted Java source s2 Get.
Further, the merge tool m1 and the merge tool m2 can merge the conversion source s31 to s3n and the conversion source s5 at a time as a merge process to obtain a converted Java source s2.
[変換結果リポジトリr4]
変換結果リポジトリr4は、マージツールm2によって、機械的な変換、および、手修正の変換がなされ、JAVAコードのみを記録した変換後Javaソースs2を格納する。
[Conversion result repository r4]
The conversion result repository r4 stores the converted Java source s2 that is subjected to mechanical conversion and manual correction conversion by the merge tool m2 and in which only the JAVA code is recorded.
[テストツール30]
テストツール30は、変換後Javaソースs2の確認テスト(実機確認)を行う。確認テストでは、例えば、変換元COBOLソースs1および変換後Javaソースs2に同じ入力値を入力し、両者間で同じ出力値が得られれば不良なし、異なる出力値が得られれば不良ありと判定する。テストツール30は、不良があった場合、不良箇所情報を元に、メタ情報DB11を参照して、不良を作り込んだ変換を特定する。
[Test tool 30]
The
例えば、図1に示すように、テストツール30が確認テストを実行した結果、不良ありと判定し、変換後Javaソースs2のJAVAコード「Java2」が不良原因であったと判明したとする。具体的には、コンバージョン開発者にとっては予め智得している、「Java2」の行の動作を正常にする正しいコードと、マージツールm2が出力した変換後Javaソースs2内に記述されているJAVAコード「Java2」との相違点が判明したとする。この場合、テストツール30は、メタ情報DB11を参照して、COBOLコード「COBOL2」からJAVAコード「Java2」への変換に関するメタ情報を取得する。テストツール30は、取得したメタ情報を解析することで、JAVAコード「Java2」への変換を実行したコンバータc2自体に問題がある、JAVAコード「Java2」への変換に係る変換設計に問題がある、などの不良原因の詳細を特定することができる。
For example, as shown in FIG. 1, it is assumed that, as a result of the
≪処理≫
次に、本実施形態の変換装置1が実行する処理として、COBOLからJAVAへの異言語変換処理について、図2を参照して説明する。説明の際、図1も適宜参照する。
<< Process >>
Next, a different language conversion process from COBOL to JAVA will be described with reference to FIG. 2 as a process executed by the
まず、変換装置1は、変換元COBOLソースs1に対して、フォーマット整形を行う(ステップS1)。具体的には、変換装置1は、変換元COBOLソースs1のCOBOLコードについて、分かち書きの1行化、大文字小文字の統一など、コンバータc1〜cnでの変換を容易にする整形を行う。
First, the
次に、変換装置1は、変換元COBOLソースs1に対して、定義部DB化をする(ステップS2)。具体的には、変換装置1は、変換元COBOLソースs1のCOBOLコードを解析し、データ項目の定義情報をDB(図1には図示しない記憶部)へ格納する。
Next, the
次に、変換装置1は、変換元COBOLソースs1に対して、文法上整形を行う(ステップS3)。具体的には、変換装置1は、糖衣構文を正規記法に統一するなど、変換元COBOLソースs1の構文を、コンバータc1〜cnへの入力を前提とする構文へ整形する。
Next, the
次に、変換装置1は、変換元COBOLソースs1に対して、JAVA言語への共通的変換を行う(ステップS4)。具体的には、変換装置1は、JAVAのimport文やmainメソッドの記述など、変換設計の特性に関係なく、コンバータc1〜cn間で共通で必要となる変換設計を適用する。ステップS4によれば、コンバータc1〜cnの各々の変換設計には、コンバータc1〜cn間で共通の変換設計を含ませないようにすることができ、コンバータc1〜cn各々の変換設計を簡易にすることができる。
Next, the
次に、変換装置1は、変換元COBOLソースs1に対して、JAVA言語への順序依存変換を行う(ステップS5)。具体的には、変換装置1は、変換元COBOLソースs1から変換後Javaソースs2への変換に関する複数種類の変換設計について、1つの変換設計の実行結果が、他の変換設計の実行結果に依存する場合には、その依存に関係する変換設計を適用し、実行順序依存性を持つ変換を行う。ステップS5によれば、実行順序依存性を持つ変換を予め実行することで、コンバータc1〜cnの各々による変換の間で、実行順序依存性を持たせないようにすることができ、コンバータc1〜cn各々の変換設計を簡易にすることができる。
Next, the
次に、変換装置1は、変換元COBOLソースs1に対して、JAVA言語へのパラレル変換を行う(ステップS6)。具体的には、変換装置1は、コンバータc1〜cnの各々の変換設計を適用するとともに、コンバータc1〜cnによる変換で対処しない、または、対処できない変換については、手修正管理ツール20による手修正の変換設計を適用する。
Next, the
図2に示すように、ステップS6は、例えば、コンバータc1〜cnの各々に対応する個別命令語変換(1)〜(N)(ステップS6−1〜S6−N)、および、手修正に対応する手修正変換(ステップS6−X)に分けることができる。個別命令語変換(1)〜(N)は、COBOLの命令語の種類ごとに、JAVAへの機械的な変換を行う処理である(例:「MOVE」→「set」)。コンバータc1〜cn間の変換が他の変換に影響を及ぼすことの無いように設計されているため、個別命令語変換(1)〜(N)は、機械的、かつ、並行に行うことができる。なお、個別命令語変換(1)〜(N)のように命令語単位で変換を行うのではなく、例えば、構文単位で個別に機械的な変換を行ってもよい。手修正変換(S6−X)は、手修正管理ツール20による変換である。
As shown in FIG. 2, step S6 corresponds to, for example, individual instruction word conversions (1) to (N) (steps S6-1 to S6-N) corresponding to each of converters c1 to cn and manual correction. Can be divided into hand correction conversion (step S6-X). The individual instruction word conversions (1) to (N) are processes for performing mechanical conversion to JAVA for each type of COBOL instruction words (for example, “MOVE” → “set”). Since the conversion between the converters c1 to cn is designed not to affect other conversions, the individual instruction word conversions (1) to (N) can be performed mechanically and in parallel. . In addition, instead of performing conversion in units of instruction words as in individual instruction word conversions (1) to (N), for example, mechanical conversion may be performed individually in units of syntax. Manual correction conversion (S6-X) is conversion by the manual
ステップS6において、バージョン管理ツール10は、コンバータc1〜cnの各々に対応する個別命令語変換(1)〜(N)に関するメタ情報、および、手修正に対応する手修正変換に関するメタ情報を取得し、メタ情報DB11に格納する。
In step S6, the
次に、変換装置1は、ステップS6のパラレル変換の変換結果をマージする(ステップS7)。具体的には、変換装置1は、マージツールm1,m2によって、コンバータc1〜cnによって変換された変換途中ソースs31〜s3n(または変換途中ソースs4)、および、手修正管理ツール20によって変換された変換途中ソースs5に対してマージ処理をし、変換後Javaソースs2を生成する。
Next, the
次に、変換装置1は、テストツール30によって、変換後Javaソースs2の確認テストを行う(ステップS8)。テストツール30は、確認テストで不良があった場合、不良箇所情報を元に、メタ情報DB11に格納された該当のメタ情報を参照して、不良の不良原因を作り込んだ変換を特定する。
Next, the
コンバージョン開発では、不良原因を作り込んだ変換を行うコンバータを修正した後、図2の異言語変換処理を再度行う。このとき、各コンバータ間の変換が他のコンバータの変換に影響を及ぼすことはないので、ステップS6のパラレル変換では、修正したコンバータに対応する個別命令語変換を行いさえすれば良く、他の個別命令語変換を行う必要はない。よって、ステップS7のマージでは、修正していないコンバータに対応する個別命令語変換済みの変換結果を流用することができ、不良対応後の再変換工数の削減に寄与し、図2の処理に要する負担を低減させたり、時間を短縮させたりすることができる。 In the conversion development, after correcting the converter that performs conversion incorporating the cause of the defect, the different language conversion process of FIG. 2 is performed again. At this time, the conversion between the respective converters does not affect the conversion of the other converters. Therefore, in the parallel conversion in step S6, it is only necessary to perform the individual instruction word conversion corresponding to the corrected converter, and the other individual conversions. There is no need to perform instruction word conversion. Therefore, in the merge in step S7, the conversion result after individual instruction word conversion corresponding to the converter that has not been corrected can be diverted, contributing to the reduction in the number of re-conversion steps after dealing with defects, and required for the processing of FIG. The burden can be reduced and the time can be shortened.
図2の処理によれば、変換元COBOLソースs1を変換後Javaソースs2に変換する際、バージョン管理ツール10がメタ情報を管理することによって、変換の履歴を辿ることができる。その結果、変換後Javaソースs2に不良があったときの不良原因の特定は、メタ情報の参照で十分に達成することができ、従来のような有識者の検討を必要とせず、容易となる。
したがって、コンバージョン開発における不良対応コストを削減することができる。
According to the processing in FIG. 2, when the conversion source COBOL source s1 is converted into the converted Java source s2, the
Therefore, it is possible to reduce defect handling costs in conversion development.
≪追いつき作業での手修正結果流用≫
顧客が提供する変換元ソースを変換後ソースに変換するコンバージョン開発では、不良対応や法改正対応などの保守開発上の理由から、コンバージョン開発の進捗とは無関係に、顧客が変換元ソースを修正し仕様変更を行う場合がある。その場合、初回のコンバージョン開発の完了後に、再度のコンバージョン開発を実施し、変換後ソースに仕様変更を取り込む必要がある。初回のコンバージョン開発の完了とは、変換後ソースの確認テストにおける不良なしでの完了を意味し、「凍結」と呼ぶ場合がある。また、再度のコンバージョン開発における凍結後の仕様変更対応作業を「追いつき作業」と呼ぶ場合がある。
≪Use of hand correction results in catch-up work≫
In conversion development, where the conversion source provided by the customer is converted to the converted source, the customer modifies the conversion source regardless of the progress of conversion development due to maintenance development reasons such as defect handling and legal revision. The specification may be changed. In that case, after the completion of the first conversion development, it is necessary to carry out conversion development again and incorporate the specification changes into the converted source. Completion of the first conversion development means completion without defect in the verification test of the converted source, and it is sometimes called “freezing”. Also, there is a case in which the specification change handling work after freezing in the second conversion development is called “catch-up work”.
追いつき作業は、必須であるとはいえ、コンバージョン開発の作業量を増大させ、システム移行の遅延化を招くので、作業工数を低減化し早期に終了させたいという要望がある。しかし、従来では、変換元ソースに対して、例えば、先述した手修正必要例1〜3に該当し、初回のコンバージョン開発で該当行の手修正をした場合には、追いつき作業でも同じ行を手修正しなければならず、非効率であった。
また、従来では、変換後ソースのうち手修正による変換箇所については、凍結前に確認テストを行っていたとしても、追いつき作業ではほぼ同様の確認テストを再度行う必要があり、追いつき作業のテスト工数を低減させることができなかった。
Although the catch-up work is indispensable, it increases the amount of conversion development work and delays the system migration, so there is a demand to reduce the work man-hours and end it early. However, conventionally, for example, when the conversion source source corresponds to the above-mentioned manual correction necessity examples 1 to 3 and the corresponding line is manually corrected in the first conversion development, the same line is handled in the catch-up operation. It had to be corrected and was inefficient.
In addition, in the past, even if a confirmation test was performed before freezing for the converted part of the source after conversion, it is necessary to perform almost the same confirmation test again in the catch-up work, and the test man-hour for the catch-up work Could not be reduced.
つまり、一般的には、顧客側の保守開発では、仕様変更のコード修正が機能単位で済む場合が多いため、コード修正による新システムへの影響は大抵は局所的で済む。一方、コンバージョン開発では、(機械的であっても手修正であっても)変換が変換観点単位(構文単位)であるため、変換による新システムへの影響は全体的に及ぶ。このため、手修正による変換に対する確認テストの確認項目が新システム全体に分散する傾向がある。その結果、手修正が少量であったとしても、手修正による変換に対する確認テストの確認項目の数が少量となるわけではなく、凍結前のテスト工数とほぼ同程度のテスト工数が要求される。このような事情は、手修正による変換箇所が、顧客側の修正の影響が及ぶ箇所であるか否かにかかわらず存在する。 That is, generally, in the maintenance development on the customer side, the code modification of the specification change is often performed on a functional unit basis, and therefore the influence of the code modification on the new system is usually local. On the other hand, in conversion development, since conversion is a conversion viewpoint unit (syntax unit) (whether mechanical or manual correction), the conversion affects the entire new system. For this reason, the confirmation items of the confirmation test for the conversion by manual correction tend to be distributed throughout the new system. As a result, even if the amount of manual correction is small, the number of confirmation items in the confirmation test for the conversion by manual correction is not small, and a test man-hour approximately equal to the test man-hour before freezing is required. Such a situation exists regardless of whether or not the conversion location by manual correction is affected by the correction on the customer side.
本実施形態の変換装置1は、マージツールm1,m2が行った3方向マージを用いて、追いつき作業において、顧客側の仕様変更の修正とは無関係となる、凍結前の手修正結果を機械的に流用する。本実施形態では、手修正結果を対象にした3方向マージは、マージツールm2が行い、以下の説明でもマージツールm2による3方向マージとして説明するが、マージツールm1でも同様に行うことができる。
The
図3に示すように、変換元ソースspと、修正版変換元ソースsc1と、手修正ソースsc2とを用意する。
変換元ソースspは、COBOLで記述されたCOBOLコード(1行目「COBOL1」、2行目「COBOL2」、3行目「COBOL3」)を記録したソースコードである。変換元ソースspは、コンバージョン開発側が顧客から元々提供されたコンバージョン開発対象である。変換元ソースspは、図1の変換元COBOLソースs1に相当する。
As shown in FIG. 3, a conversion source source sp, a modified version conversion source source sc1, and a manual correction source sc2 are prepared.
The conversion source source sp is a source code in which a COBOL code described in COBOL (first line “
修正版変換元ソースsc1は、COBOLで記述されたCOBOLコード(1行目「COBOL1」、2行目「COBOL2」、3行目「COBOLA」)を記録したソースコードである。修正版変換元ソースsc1は、変換元ソースspに対し、顧客側の仕様変更の修正分(「COBOL3」(特定行)→「COBOLA」)が反映されたものに等しい。修正版変換元ソースsc1は、追いつき作業の際、つまり凍結後に顧客から提供される。
The modified version conversion source source sc1 is a source code in which a COBOL code described in COBOL (first line “
手修正ソースsc2は、手修正管理ツール20によって変換元ソースspのCOBOLコードの一部をJAVAコード(「COBOL2」→「Java2」)に変換したソースコードである。手修正ソースsc2は、初回のコンバージョン開発において、つまり凍結前に作成されたものである。
The manual correction source sc2 is a source code obtained by converting a part of the COBOL code of the conversion source source sp into a JAVA code (“COBOL2” → “Java2”) by the manual
バージョン管理ツール10は、変換元ソースspと、修正版変換元ソースsc1と、手修正ソースsc2に関するメタ情報を管理し、変換元ソースspと、修正版変換元ソースsc1と、手修正ソースsc2の内容を管理することができる。
The
マージツールm2は、変換元ソースspをマージの親、修正版変換元ソースsc1をマージの子(第1の子)、手修正ソースsc2をマージの子(第2の子)とした3方向マージを行う。結果的に、図3に示す手修正流用ソースsdを得る。バージョン管理ツール10は、手修正流用ソースsdに関するメタ情報を取得して管理する。
The merge tool m2 performs a three-way merge with the conversion source source sp as the merge parent, the corrected version conversion source source sc1 as the merge child (first child), and the manual correction source sc2 as the merge child (second child). I do. As a result, the hand correction diversion source sd shown in FIG. 3 is obtained. The
修正版変換元ソースsc1と手修正流用ソースsdとを比較すると、2行目「COBOL2」のコードは、3行目「COBOL3」に対する顧客の修正の影響を受けることなく、「Java2」に変換されており、修正版変換元ソースsc1に対して、手修正ソースsc2による手修正結果を流用できているといえる。従来では、追いつき作業にて、修正版変換元ソースsc1に対して、手修正で「COBOL2」→「Java2」という変換をしていたが、本発明では、その変換の手間を省くことができる。結果的に、追いつき作業での手修正の対象は、凍結前に手修正がなされたCOBOLコードのうち、顧客側の仕様変更の修正がなされたCOBOLコードに絞られる。 When the modified version conversion source source sc1 and the manually modified diversion source sd are compared, the code of the second line “COBOL2” is converted to “Java2” without being affected by the customer's modification to the third line “COBOL3”. Therefore, it can be said that the manual correction result by the manual correction source sc2 can be used for the corrected version conversion source source sc1. Conventionally, in the catch-up operation, the corrected version conversion source source sc1 is manually converted from “COBOL2” to “Java2”. However, in the present invention, the conversion effort can be saved. As a result, the target of manual correction in the catch-up operation is limited to the COBOL code in which the specification change on the customer side is corrected among the COBOL codes that have been manually corrected before freezing.
また、手修正ソースsc2による手修正結果を含む変換後ソースに対する凍結前の確認テストはすでに済んでおり、その手修正結果を流用している。このため、追いつき作業において、手修正流用ソースsdを用いてマージ処理をした変換後ソース(顧客修正反映済み)の確認テストを行う際、流用した手修正による変換に対する確認テストの確認項目は省略することができる。その結果、追いつき作業のテスト工数を低減させることができる。 Further, the confirmation test before freezing on the converted source including the manual correction result by the manual correction source sc2 has already been completed, and the manual correction result is used. For this reason, in the catch-up work, when performing a confirmation test of the converted source (customer correction reflected) that has been merged using the manually corrected diversion source sd, the confirmation items of the confirmation test for the conversion by the diverted manual correction are omitted. be able to. As a result, the test man-hour for the catch-up work can be reduced.
なお、3方向マージで得られた手修正流用ソースsdの3行目「COBOLA」のJAVAコードへの変換については、「COBOLA」が機械変換可能なCOBOLコードである場合は、コンバータc1〜cnのいずれかによって変換され、結果物が機械変換結果リポジトリr2に格納される。一方、「COBOLA」が、手修正が必要なCOBOLコードである場合は、手修正流用ソースsdを対象にして手修正管理ツール20によって手修正を行い、結果物が手修正結果リポジトリr3に格納される。その後は、すでに説明した手順(図2のステップS7など)に従う。
Regarding the conversion of the third line “COBOLA” of the hand-corrected diversion source sd obtained by the three-way merge into a JAVA code, if “COBOLA” is a COBOL code that can be machine-converted, the converters c1 to cn The result is converted by either of them, and the result is stored in the machine conversion result repository r2. On the other hand, if “COBOL” is a COBOL code that requires manual correction, the manual
≪片方優先3方向マージ≫
追いつき作業において、変換元ソースに対する顧客側の修正箇所(特定行)と、変換元ソースに対する凍結前の手修正が行われた箇所(手修正行)とが重複している場合がある。この場合、手修正結果流用の3方向マージを行うと、コンフリクトが発生してしまい、マージすることができない。
≪One-way priority three-way merge≫
In the catch-up operation, there are cases where the customer's correction part (specific line) for the conversion source and the part where the correction before the freezing for the conversion source (hand correction line) is duplicated. In this case, if the three-way merging using the hand correction result is performed, a conflict occurs and the merging cannot be performed.
そこで、顧客側の修正行と手修正行とが重複している場合、マージツールm2は、顧客側の修正行を優先する片方優先3方向マージを行う。
図4に示すように、変換元ソースspと、修正版変換元ソースsc1aと、手修正ソースsc2とを用意した場合について説明する。図4の変換元ソースspおよび手修正ソースsc2は、図3に示す変換元ソースspおよび手修正ソースsc2と同じである。
Therefore, when the customer correction line and the manual correction line overlap, the merge tool m2 performs one-way priority three-way merging that prioritizes the customer correction line.
As shown in FIG. 4, a case where a conversion source source sp, a corrected version conversion source source sc1a, and a manual correction source sc2 are prepared will be described. The conversion source source sp and the manual correction source sc2 in FIG. 4 are the same as the conversion source source sp and the manual correction source sc2 shown in FIG.
修正版変換元ソースsc1aは、COBOLで記述されたCOBOLコード(1行目「COBOL1」、2行目「COBOLA」、3行目「COBOL3」)を記録したソースコードである。修正版変換元ソースsc1aは、変換元ソースspに対し、顧客側の仕様変更の修正分(「COBOL2」→「COBOLA」)が反映されたものに等しい。修正版変換元ソースsc1aは、追いつき作業の際、つまり凍結後に顧客から提供される。
バージョン管理ツール10は、修正版変換元ソースsc1aに関するメタ情報を管理し、修正版変換元ソースsc1aの内容を管理することができる。
The modified version conversion source source sc1a is a source code in which the COBOL code described in COBOL (first line “COBOL1”, second line “COBOL”, third line “COBOL3”) is recorded. The corrected version conversion source source sc1a is equivalent to the conversion source source sp reflecting the correction of the specification change on the customer side (“
The
変換元ソースspと、修正版変換元ソースsc1aと、手修正ソースsc2に対して、図3の3方向マージを仮に行った場合、変換元ソースspの2行目「COBOL2」に対する顧客修正(「COBOLA」(特定行))と、手修正(「Java2」(手修正行))とがコンフリクト(重複)しマージ不可となる。 If the three-way merging of FIG. 3 is performed on the conversion source source sp, the corrected version conversion source source sc1a, and the manual correction source sc2, the customer correction for the second line “COBOL2” of the conversion source source sp (“ COBOLA "(specific line)) and manual correction (" Java2 "(manual correction line)) conflict (overlap) and cannot be merged.
そこで、図4に示すように、マージツールm2は、変換元ソースspをマージの親、修正版変換元ソースsc1aをマージの子(第1の子)、手修正ソースsc2をマージの子(第2の子)とした片方優先3方向マージを行う。結果的に、手修正結果(「Java2」)を含まず、顧客修正(「COBOLA」)を含む顧客修正優先ソースsda(1行目「COBOL1」、2行目「COBOLA」、3行目「COBOL3」)を得る。バージョン管理ツール10は、顧客修正優先ソースsdaに関するメタ情報を取得して管理する。
Therefore, as shown in FIG. 4, the merge tool m2 uses the conversion source source sp as the parent of the merge, the corrected version conversion source source sc1a as the child of the merge (first child), and the manual correction source sc2 as the child of the merge (first). One-way priority three-way merging is performed. As a result, the customer correction priority source sda that does not include the manual correction result (“
本実施形態の片方優先3方向マージによれば、手修正と顧客修正とがコンフリクトするとしても、3方向マージの結果物に顧客修正を確実に反映させることができ。顧客の本来的な要求を確実に満たすことができる。 According to the one-way priority three-way merge of the present embodiment, even if manual correction and customer correction conflict, the customer correction can be reliably reflected in the result of the three-way merge. The customer's original requirements can be reliably met.
なお、片方優先3方向マージで得られた顧客修正優先ソースsdaの2行目「COBOLA」のJAVAコードへの変換については、「COBOLA」が機械変換可能なCOBOLコードである場合は、コンバータc1〜cnのいずれかによって変換され、結果物が機械変換結果リポジトリr2に格納される。一方、「COBOLA」が、手修正が必要なCOBOLコードである場合は、顧客修正優先ソースsdaを対象にして手修正管理ツール20によって手修正を行い、結果物が手修正結果リポジトリr3に格納される。その後は、すでに説明した手順(図2のステップS7など)に従う。
Regarding conversion of the second line “COBOLA” of the customer modification priority source sda obtained by the one-way priority three-way merge into a JAVA code, if “COBOLA” is a machine-convertible COBOL code, the converter c1 The result is converted by any of cn, and the result is stored in the machine conversion result repository r2. On the other hand, if “COBOL” is a COBOL code that requires manual correction, the manual
≪追いつき作業におけるテスト作業工数削減≫
追いつき作業は、本質的には、変換元ソースに対して顧客が行った(概ね小規模の)修正分に対して再度のコンバージョン開発を行えば十分である。追いつき作業で行う必要があるテストの確認項目の大部分は、追いつき作業前の初回コンバージョン開発ですでに行ったテストの確認項目と重複する。よって、初回コンバージョン開発でのテストの確認結果を流用して、追いつき作業でのテスト作業工数を削減する、というアイデアが成立し、以下、その方法について具体的に説明する。
≪Reduction of test work man-hours in catch-up work≫
The catch-up work is essentially sufficient if a conversion conversion is performed again for the (generally small-scale) corrections made by the customer to the conversion source source. Most of the confirmation items of the test that need to be performed in the catch-up work overlap with the confirmation items of the test already performed in the initial conversion development before the catch-up work. Therefore, the idea of reducing the test work man-hours in the catch-up work by diverting the test confirmation result in the initial conversion development has been established, and the method will be specifically described below.
図5に示すように、追いつき作業前の異言語変換では、つまり、初回コンバージョン開発では、本実施形態の変換装置1が、変換元ソースsp(例えば、COBOL)を変換後ソースsq(例えば、JAVA)に変換する際に、変換設計設定(ステップS11)と、コンバータ生成(ステップS12)と、機械変換+手修正(ステップS13)と、3方向マージ(ステップS14)とが実行される。
As shown in FIG. 5, in different language conversion before the catch-up work, that is, in the first conversion development, the
変換設計設定(ステップS11)は、コンバージョン開発側で変換元ソースspを解析し、変換元ソースspに対して、変換後ソースsqの作成に必要となる変換設計を1または複数種類設定するステップである。変換設計とは、変換対象のコード文字列をどのように書き換えるかを規定する枠組みである。必要となる変換設計の種類については、例えば、コンバージョン開発側で適宜決定してもよいが、決定の方法はこれに限らない。 The conversion design setting (step S11) is a step of analyzing the conversion source source sp on the conversion development side and setting one or a plurality of types of conversion designs necessary for creating the converted source sq for the conversion source source sp. is there. Conversion design is a framework that defines how to rewrite a code string to be converted. The type of conversion design required may be determined as appropriate on the conversion development side, for example, but the determination method is not limited to this.
図5の例では、変換元ソースspに対して、変換対象ごとに変換設計A1〜E1の5種類が設定されたとする。変換設計A1〜C1は、コンバータ(図1のコンバータc1〜cnに相当)による機械変換に係る変換設計である。変換設計D1、E1は、手修正(図1の手修正管理ツール20が行う手修正に相当)による変換に係る変換設計である。
In the example of FIG. 5, it is assumed that five types of conversion designs A1 to E1 are set for each conversion target for the conversion source source sp. Conversion designs A1 to C1 are conversion designs related to mechanical conversion by a converter (corresponding to converters c1 to cn in FIG. 1). The conversion designs D1 and E1 are conversion designs related to conversion by manual correction (corresponding to manual correction performed by the manual
コンバータ生成(ステップS12)は、設定された変換設計のうち、機械変換に係る変換設計に関連付けられるコンバータを生成するステップである。図5では、機械変換に係る変換設計A1〜C1の各々に対し、変換設計A1向けコンバータA2と、変換設計B1向けコンバータB2と、変換設計C1向けコンバータC2とが生成される。変換設計A1向けコンバータA2、変換設計B1向けコンバータB2、変換設計C1向けコンバータC2は、図1のコンバータc1〜cnと同じ機能を有する。 The converter generation (step S12) is a step of generating a converter associated with the conversion design related to the mechanical conversion among the set conversion designs. In FIG. 5, converter A2 for conversion design A1, converter B2 for conversion design B1, and converter C2 for conversion design C1 are generated for each of conversion designs A1 to C1 related to mechanical conversion. Converter A2 for conversion design A1, converter B2 for conversion design B1, and converter C2 for conversion design C1 have the same functions as converters c1 to cn of FIG.
機械変換+手修正(ステップS13)は、変換設計に従う機械変換および手修正を実行するステップである。図5では、コンバータA2〜C2の各々が、変換元ソースsp中の変換対象の各々に対して、変換設計A1〜C1に従う機械変換を実行し、変換結果A3〜C3を出力する。また、手修正管理ツール20(図1)が、変換元ソースsp中の変換対象の各々に対して、変換設計D1,E1に従う手修正を実行し、変換結果D3,E3を出力する。変換結果A3〜E3は、図1に示す変換途中ソースs31〜s3n,s4,s5に相当する。 Machine conversion + hand correction (step S13) is a step of executing machine conversion and manual correction according to the conversion design. In FIG. 5, each of converters A <b> 2 to C <b> 2 performs mechanical conversion according to conversion designs A <b> 1 to C <b> 1 for each conversion target in conversion source source sp, and outputs conversion results A <b> 3 to C <b> 3. Further, the manual correction management tool 20 (FIG. 1) executes manual correction according to the conversion designs D1 and E1 for each of the conversion targets in the conversion source source sp, and outputs conversion results D3 and E3. The conversion results A3 to E3 correspond to the conversion intermediate sources s31 to s3n, s4, and s5 shown in FIG.
なお、図1に示すように、本実施形態の変換装置1は、コンバータc1〜cnによる変換結果を、コンバータごとにリポジトリ内で管理し(図1のコンバータ別変換結果リポジトリr11〜r1n)、手修正による変換結果を、1つのリポジトリ内にまとめて管理した(図1の手修正結果リポジトリr3)。しかし、リポジトリによる管理単位は任意に設定することができる。そこで、図5、図6を参照する説明については、本実施形態の変換装置1は、変換設計ごとに、変換結果をリポジトリ内で管理することにする。つまり、図5に示す変換結果A3〜E3は、変換設計A1〜E1の各々に対して用意したリポジトリ(図5中図示せず)内に管理される。なお、リポジトリとして、変換設計ごとに用意したリポジトリではなく、複数の変換設計をまとめたものに対するリポジトリを用意してもよい。
As shown in FIG. 1, the
コンバージョン開発側は、変換結果A3〜E3に対して机上確認を行う。机上確認は、周知の手法であり説明は省略する。本実施形態では、変換結果A3〜E3に対する机上確認の結果は良好であったとする。 The conversion development side performs desktop confirmation on the conversion results A3 to E3. The desk check is a well-known method and will not be described. In this embodiment, it is assumed that the result of the desktop confirmation for the conversion results A3 to E3 is good.
3方向マージ(ステップS14)は、機械変換+手修正(ステップS13)で得られた変換結果に対して3方向マージを行うステップである。3方向マージ(ステップS14)は、図1に示すマージツールm1、m2が実行する。図5では、変換結果A3〜E3に対して3方向マージを実行することで変換後ソースsqが得られる。 The three-way merging (step S14) is a step for performing the three-way merging on the conversion result obtained by the machine conversion + hand correction (step S13). The three-way merge (step S14) is executed by the merge tools m1 and m2 shown in FIG. In FIG. 5, a post-conversion source sq is obtained by performing a three-way merge on the transformation results A3 to E3.
コンバージョン開発側は、変換後ソースsqに対して実機確認を行う。実機確認は、図1に示すテストツール30の確認テストに相当する。以上で、初回コンバージョン開発が完了する。
The conversion development side checks the actual machine against the converted source sq. The actual machine confirmation corresponds to the confirmation test of the
初回コンバージョン開発の完了後、顧客が変換元ソースを修正したため、追いつき作業を実行する。図6に示すように、追いつき作業では、本実施形態の変換装置1が、顧客の修正分spa1を含む変換元ソースspa(修正版変換元ソースに相当)を、修正分spa1に対応する修正分sqa1を含む変換後ソースsqaに変換する。この変換の際、図6に示す変換設計設定(ステップS21)と、コンバータ生成(ステップS22)と、機械変換+手修正(ステップS23)と、3方向マージ(ステップS24)とが実行される。
After the completion of the initial conversion development, the customer modified the source of the conversion, so the catch-up work is executed. As shown in FIG. 6, in the catch-up operation, the
変換設計設定(ステップS21)は、図5の変換設計設定(ステップS11)と同じステップである。図6に示すように、変換設計設定(ステップS21)では、変換元ソースspaに修正分spa1が含まれたことに応じて、変換設計B1,D1(図5)をそれぞれ、変換設計B11,D11に代え、変換元ソースspaに対して、変換対象ごとに変換設計A1,B11,C1,D11,E1の5種類が設定されたとする。変換設計B11は、機械変換に係る変換設計である。変換設計D11は、手修正による変換に係る変換設計である。 The conversion design setting (step S21) is the same step as the conversion design setting (step S11) in FIG. As shown in FIG. 6, in the conversion design setting (step S21), conversion designs B1 and D1 (FIG. 5) are converted into conversion designs B11 and D11, respectively, in accordance with the fact that the correction source spa1 is included in the conversion source source spa. Instead, it is assumed that five types of conversion designs A1, B11, C1, D11, and E1 are set for each conversion target for the conversion source source spa. The conversion design B11 is a conversion design related to machine conversion. The conversion design D11 is a conversion design related to conversion by manual correction.
コンバータ生成(ステップS22)は、図5のコンバータ生成(ステップS12)と同じステップである。図6に示すように、すでに生成された変換設計A1向けコンバータA2(図5)と、変換設計C1向けコンバータC2(図5)に加え、新たに設定された変換設計B11に対し、変換設計B11向けコンバータB21が新たに生成される。変換設計B11向けコンバータB21は、図1のコンバータc1〜cnと同じ機能を有する。 The converter generation (step S22) is the same step as the converter generation (step S12) of FIG. As shown in FIG. 6, in addition to the converter A2 for the conversion design A1 (FIG. 5) and the converter C2 for the conversion design C1 (FIG. 5) that have already been generated, the conversion design B11 A new converter B21 is generated. Converter B21 for conversion design B11 has the same function as converters c1 to cn of FIG.
機械変換+手修正(ステップS23)は、図5の機械変換+手修正(ステップS13)と同じステップである。図6では、機械変換ですでに生成された変換結果A3,C3(図5)に加え、変換設計B11向けコンバータB21が、変換元ソースsp中の変換対象に対して、変換設計B11に従う機械変換を実行し、変換結果B31を新たに出力する。また、図6では、手修正ですでに生成された変換結果E3(図5)に加え、手修正管理ツール20(図1)が、変換元ソースsp中の変換対象に対して、変換設計D11に従う手修正を実行し、変換結果D31を新たに出力する。変換結果B31,D31は、図1に示す変換途中ソースs31〜s3n,s4,s5に相当する。 The machine conversion + hand correction (step S23) is the same step as the machine conversion + hand correction (step S13) in FIG. In FIG. 6, in addition to the conversion results A3 and C3 (FIG. 5) already generated by the machine conversion, the converter B21 for the conversion design B11 converts the conversion target in the conversion source source sp according to the conversion design B11. And the conversion result B31 is newly output. In FIG. 6, in addition to the conversion result E3 (FIG. 5) already generated by manual correction, the manual correction management tool 20 (FIG. 1) applies the conversion design D11 to the conversion target in the conversion source source sp. The hand correction according to the above is executed, and the conversion result D31 is newly output. The conversion results B31 and D31 correspond to the conversion intermediate sources s31 to s3n, s4, and s5 shown in FIG.
コンバージョン開発側は、新たな変換結果B31,D31に対して机上確認を行う。すでに生成した変換結果A3,C3,E3については、机上確認が済んでいるため(図5)、追いつき作業では省略する。よって、変換設計ごとに変換結果を管理することで、追いつき作業における机上確認のテスト工数を削減することができる。また、本実施形態では、変換結果B31,D31に対する机上確認の結果は良好であったとする。 The conversion development side performs desktop confirmation on the new conversion results B31 and D31. Since the conversion results A3, C3, and E3 that have already been generated have been confirmed on the desk (FIG. 5), they are omitted in the catch-up operation. Therefore, managing the conversion result for each conversion design can reduce the number of test steps for desktop confirmation in the catch-up work. Further, in the present embodiment, it is assumed that the result of desktop confirmation for the conversion results B31 and D31 is good.
3方向マージ(ステップS24)は、図5の3方向マージ(ステップS14)と同じステップである。図6では、変換結果A3,B31,C3,D31,E3に対して3方向マージを実行することで、修正分spa1に対応する修正分sqa1を含む変換後ソースsqaが得られる。 The three-way merge (step S24) is the same step as the three-way merge (step S14) in FIG. In FIG. 6, by performing a three-way merge on the conversion results A3, B31, C3, D31, and E3, a post-conversion source sqa that includes the correction part sqa1 corresponding to the correction part spa1 is obtained.
コンバージョン開発側は、変換後ソースsqaに対して実機確認を行う。この実機確認においては、すべての確認項目のうち、修正分sqa1が影響しない確認項目(修正分spa1に応じて変更した変換設計B11、D11以外の変換設計A1,C1,E1に関係する確認項目)は、追いつき作業前にすでに確認済みであるため(図5)、追いつき作業では省略しても差し支えない。よって、図5、図6の例に示すように、変換設計ごとに変換結果を管理することで、実機確認のすべての確認項目のうち、修正分sqa1が影響する確認項目についてのみ確認すればよい。その結果、追いつき作業における実機確認のテスト工数を削減することができる。 The conversion development side checks the actual machine for the converted source sqa. In this actual machine confirmation, among all the confirmation items, the confirmation items that are not affected by the correction portion sqa1 (confirmation items related to the conversion designs A1, C1, and E1 other than the conversion designs B11 and D11 changed according to the correction portion spa1) Is already confirmed before the catch-up work (FIG. 5), and can be omitted in the catch-up work. Therefore, as shown in the examples of FIGS. 5 and 6, by managing the conversion results for each conversion design, it is only necessary to check the confirmation items affected by the correction sqa1 among all the confirmation items of the actual machine confirmation. . As a result, it is possible to reduce the number of test steps for checking the actual machine in the catch-up work.
≪変形例≫
以上、本発明の実施形態について説明したが、本発明は前記実施形態に限定されず、本発明の要旨を逸脱しない範囲で適宜変更可能である。例えば、コンバージョン開発における変換元ソースのプログラム言語は、COBOLに限らず、他のプログラム言語でもよい。また、コンバージョン開発における変換後ソースのプログラム言語は、JAVAに限らず、他のプログラム言語でもよい。
≪Modification≫
As mentioned above, although embodiment of this invention was described, this invention is not limited to the said embodiment, In the range which does not deviate from the summary of this invention, it can change suitably. For example, the conversion source program language in conversion development is not limited to COBOL, but may be another program language. Further, the program language of the converted source in the conversion development is not limited to JAVA, but may be another program language.
また、コンバージョン開発における言語変換は、本実施形態で採り上げたCOBOLからJAVAへの変換といった異なる種類のプログラム言語への変換に限らず、ホスト系COBOLからオープン系COBOLへの変換といった同じ種類のプログラム言語への変換でもよい。 In addition, the language conversion in the conversion development is not limited to a different type of programming language such as conversion from COBOL to JAVA adopted in the present embodiment, but the same type of programming language such as conversion from the host system COBOL to the open system COBOL. Conversion to
また、本発明は、プログラム言語の変換に関するコンバージョン開発に限らず、現行アプリケーションが処理するデータを新アプリケーションに移行するデータマイグレーション開発など、システム移行に伴う種々のマイグレーション開発に適用することができる。 The present invention is not limited to conversion development related to program language conversion, but can be applied to various migration developments accompanying system migration, such as data migration development for migrating data processed by the current application to a new application.
また、本発明は、従来のように、変換元ソースに対して複数種類用意した変換ツールを順次実行する方法に対しても適用することができる。また、従来では、プログラム言語を機械的に変換するツールとして、コードをパース(構文木解釈)して置き換えるツールがある。このツールは、ほぼすべての言語の変換に対応可能となる1つの(または少数の)ツールとして構成され、概して大規模かつ複雑である。本発明は、このようなツールに対しても適用することができ、不良原因の特定や、追いつき作業でのテスト工数削減などに資する。 The present invention can also be applied to a method of sequentially executing a plurality of types of conversion tools prepared for a conversion source source as in the prior art. Conventionally, as a tool for mechanically converting a programming language, there is a tool for replacing code by parsing (syntactic tree interpretation). This tool is configured as one (or a small number) of tools that can accommodate almost any language translation and is generally large and complex. The present invention can also be applied to such a tool, which contributes to the identification of the cause of failure and the reduction of test man-hours in catch-up work.
本実施形態で説明した種々の技術を適宜組み合わせた技術を実現することもできる。
本実施形態で説明したソフトウェアをハードウェアとして実現することもでき、ハードウェアをソフトウェアとして実現することもできる。
その他、ハードウェア、ソフトウェア、フローチャートなどについて、本発明の趣旨を逸脱しない範囲で適宜変更が可能である。
A technique obtained by appropriately combining various techniques described in the present embodiment can also be realized.
The software described in this embodiment can be realized as hardware, and the hardware can also be realized as software.
In addition, hardware, software, flowcharts, and the like can be changed as appropriate without departing from the spirit of the present invention.
1 変換装置
c1〜cn コンバータ
10 バージョン管理ツール(メタ情報管理部)
11 メタ情報DB
20 手修正管理ツール(手修正管理部)
21 手修正実施用ワークスペース
30 テストツール(テスト部)
m1,m2 マージツール(マージ部)
r11〜r1n コンバータ別変換結果リポジトリ
r2 機械変換結果リポジトリ
r3 手修正結果リポジトリ
r4 変換結果リポジトリ
s1 変換元COBOLソース(変換元ソース)
s2 変換後Javaソース(変換後ソース)
s31〜s3n,s4,s5 変換途中ソース
sc1,sc1a 修正版変換元ソース
sp,spa 変換元ソース
sq,sqa 変換後ソース
A1〜E1,B11,D11 変換設計
A2 変換設計A1向けコンバータ
B2 変換設計B1向けコンバータ
B21 変換設計B11向けコンバータ
C2 変換設計C1向けコンバータ
A3〜E3,B31,D31 変換結果
1 conversion device c1 to
11 Meta information DB
20 Manual Correction Management Tool (Manual Correction Management Department)
21 Workspace for
m1, m2 Merge tool (merge part)
r11-r1n Converter-specific conversion result repository r2 Machine conversion result repository r3 Manual modification result repository r4 Conversion result repository s1 Conversion source COBOL source (conversion source source)
s2 Java source after conversion (source after conversion)
s31 to s3n, s4, s5 Conversion source sc1, sc1a Modified version conversion source source sp, spa Conversion source source sq, sqa Source after conversion A1 to E1, B11, D11 Conversion design A2 Conversion design A1 converter B2 Conversion design B1 Converter B21 Conversion design B11 converter C2 Conversion design C1 converter A3 to E3, B31, D31 Conversion result
Claims (8)
前記変換元ソースの一部を前記変換後ソースの一部に変換して生成される変換途中ソースの集合について、前記変換途中ソースの各々への変換に関するメタ情報を管理するメタ情報管理部と、
前記変換後ソースの確認テストで不良があった場合、前記メタ情報を参照して、前記不良の不良原因を作り込んだ変換を特定するテスト部と、を備える、
ことを特徴とする変換装置。 A conversion device for converting a conversion source source into a converted source,
A meta information management unit for managing meta information related to conversion to each of the conversion-in-progress sources for a set of conversion-sources generated by converting a part of the conversion source source into a part of the converted source;
When there is a defect in the confirmation test of the converted source, a test unit that identifies the conversion that created the cause of the defect by referring to the meta information,
A conversion device characterized by that.
前記変換元ソースの一部から前記変換後ソースの一部への変換を行うための手修正を管理する手修正管理部と、
前記変換途中ソースの集合に対してマージ処理をするマージ部と、をさらに備える、
ことを特徴とする請求項1に記載の変換装置。 Prepared for each character string in the conversion source, a plurality of types of converters that perform mechanical and parallel conversion from a part of the conversion source to a part of the converted source, and
A manual correction management unit for managing manual correction for performing conversion from a part of the conversion source source to a part of the converted source;
A merge unit that performs a merge process on the set of sources in the middle of the conversion, and
The conversion device according to claim 1.
前記マージ部は、
前記変換元ソースを親とし、前記修正版変換元ソースを第1の子とし、前記変換途中ソースのうち前記手修正による変換が行われたものを第2の子とする3方向マージをする、
ことを特徴とする請求項2に記載の変換装置。 If there is a modified version of the conversion source source in which the specific line of the conversion source source has been corrected,
The merge unit
Three-way merging with the conversion source source as a parent, the corrected version conversion source source as a first child, and the one that has been converted by the manual correction among the conversion intermediate sources as a second child,
The conversion device according to claim 2.
前記修正版変換元ソースにおいて修正されていた前記特定行と、前記手修正による変換が行われた前記変換途中ソースにおいて前記手修正がなされた手修正行とが重複する場合、前記3方向マージにおいて、前記特定行を優先する、
ことを特徴とする請求項3に記載の変換装置。 The merge unit
In the three-way merge, the specific line that has been corrected in the corrected version conversion source source and the manual correction line that has been manually corrected in the conversion intermediate source that has been converted by the manual correction overlap. , Giving priority to the specific line,
The conversion device according to claim 3.
ことを特徴とする請求項3または請求項4に記載の変換装置。 When the conversion intermediate source is generated for each conversion design set for the conversion source source, a new conversion is performed for the conversion design changed according to the correction of the corrected version conversion source source. Generate source on the way,
5. The conversion device according to claim 3 or 4, wherein:
ことを特徴とする請求項1から請求項5のいずれか1項に記載の変換装置。 The conversion from the conversion source source to the converted source is a program language conversion.
The conversion device according to any one of claims 1 to 5, wherein
異なる種類のプログラム言語への変換、または、同じ種類のプログラム言語への変換である、
ことを特徴とする請求項6に記載の変換装置。 The programming language conversion is
Conversion to a different type of programming language or to the same type of programming language,
The conversion device according to claim 6.
前記変換元ソースの一部を前記変換後ソースの一部に変換して生成される変換途中ソースの集合について、前記変換途中ソースの各々への変換に関するメタ情報を登録するステップと、
前記変換後ソースの確認テストを行い、不良があった場合、前記メタ情報を参照して前記不良の不良原因を作り込んだ変換を特定するステップと、を備える、
ことを特徴とする変換方法。 A conversion method in a conversion device for converting a conversion source source to a converted source,
Registering meta information related to conversion to each of the conversion-in-progress sources for a set of conversion-sources generated by converting a part of the conversion source source into a part of the converted source;
Performing a verification test of the post-conversion source, and if there is a defect, refer to the meta information to identify the conversion that has created the cause of failure of the defect, and
A conversion method characterized by that.
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2017161973A JP6944838B6 (en) | 2017-08-25 | 2017-08-25 | Conversion device and conversion method |
PCT/JP2018/030483 WO2019039394A1 (en) | 2017-08-25 | 2018-08-17 | Conversion device and conversion method |
CN201880055029.6A CN111052077B (en) | 2017-08-25 | 2018-08-17 | Conversion device and conversion method |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2017161973A JP6944838B6 (en) | 2017-08-25 | 2017-08-25 | Conversion device and conversion method |
Publications (3)
Publication Number | Publication Date |
---|---|
JP2019040399A true JP2019040399A (en) | 2019-03-14 |
JP6944838B2 JP6944838B2 (en) | 2021-10-06 |
JP6944838B6 JP6944838B6 (en) | 2021-11-02 |
Family
ID=65439075
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2017161973A Active JP6944838B6 (en) | 2017-08-25 | 2017-08-25 | Conversion device and conversion method |
Country Status (3)
Country | Link |
---|---|
JP (1) | JP6944838B6 (en) |
CN (1) | CN111052077B (en) |
WO (1) | WO2019039394A1 (en) |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2004334325A (en) * | 2003-04-30 | 2004-11-25 | Nri & Ncc Co Ltd | File conversion system and method |
JP2014215938A (en) * | 2013-04-30 | 2014-11-17 | 株式会社システムズ | Information processing apparatus, information processing method and program |
US20160350204A1 (en) * | 2015-05-27 | 2016-12-01 | Oracle International Corporation | System and method for providing automated computer language translation and verification |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN100337203C (en) * | 2004-04-05 | 2007-09-12 | 中国科学院计算技术研究所 | Control flow conversion in course of heritage code into modern language |
JP4724387B2 (en) * | 2004-06-24 | 2011-07-13 | 富士通株式会社 | Program conversion program, program conversion apparatus, and program conversion method |
US8438551B2 (en) * | 2005-06-27 | 2013-05-07 | Csc Technology Singapore Pte Ltd | Code transformation |
CN101105814A (en) * | 2007-09-11 | 2008-01-16 | 金蝶软件(中国)有限公司 | Method and device for converting Script language to SQL language |
CN104391730B (en) * | 2014-08-03 | 2017-07-11 | 浙江网新恒天软件有限公司 | A kind of software source codes language translation system and method |
-
2017
- 2017-08-25 JP JP2017161973A patent/JP6944838B6/en active Active
-
2018
- 2018-08-17 CN CN201880055029.6A patent/CN111052077B/en active Active
- 2018-08-17 WO PCT/JP2018/030483 patent/WO2019039394A1/en active Application Filing
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2004334325A (en) * | 2003-04-30 | 2004-11-25 | Nri & Ncc Co Ltd | File conversion system and method |
JP2014215938A (en) * | 2013-04-30 | 2014-11-17 | 株式会社システムズ | Information processing apparatus, information processing method and program |
US20160350204A1 (en) * | 2015-05-27 | 2016-12-01 | Oracle International Corporation | System and method for providing automated computer language translation and verification |
Also Published As
Publication number | Publication date |
---|---|
CN111052077A (en) | 2020-04-21 |
JP6944838B6 (en) | 2021-11-02 |
CN111052077B (en) | 2023-09-29 |
WO2019039394A1 (en) | 2019-02-28 |
JP6944838B2 (en) | 2021-10-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8583413B2 (en) | Computer method and apparatus for chaining of model-to-model transformations | |
US8005788B2 (en) | System and method for legacy system component incremental migration | |
US20150106790A1 (en) | Detecting merge conflicts and compilation errors in a collaborative integrated development environment | |
US20070169023A1 (en) | Restructuring computer programs | |
US8924923B2 (en) | Apparatus and method of generating multi-level test case from unified modeling language sequence diagram based on multiple condition control flow graph | |
Baresi et al. | Dynamically evolving the structural variability of dynamic software product lines | |
JP6268029B2 (en) | Test case generation apparatus and test case generation method | |
EP2799981A1 (en) | Method for providing code, code generator and software development environment | |
CN107656734A (en) | Update method, system, computer-readable recording medium and the storage control of code release information | |
JP2018185809A (en) | Natural language translation and localization | |
JPWO2006095434A1 (en) | Software construction program, recording medium recording the program, software construction method, and software construction system | |
JP6944838B2 (en) | Conversion device and conversion method | |
WO2018154657A1 (en) | Equivalence checking device and equivalence checking program | |
JPH08241196A (en) | Branch instruction processing system | |
JP5374405B2 (en) | Model debugging apparatus and model debugging method | |
CN112114817A (en) | COBOL language-based data dictionary field information acquisition method and device | |
EP3301527A2 (en) | Method to extend mes functionalities in a message routing system | |
US11789727B2 (en) | Conversion apparatus, conversion method and program | |
US11119889B1 (en) | Automated software program repair | |
JP6653205B2 (en) | Program source conversion method, program source conversion device, information processing device, information processing method, and program | |
US10169015B2 (en) | Compact data marshaller generation | |
JP2022118310A (en) | Compilation method, development supporting device, and control system | |
JPH01230132A (en) | Generator | |
Hayashi et al. | Agile stock assessment | |
CN113672239A (en) | Visual algorithm package development method based on language analysis |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20200824 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20210831 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20210913 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 6944838 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |