JP2012048329A - オブジェクト指向プログラム生成装置、その方法、プログラム - Google Patents

オブジェクト指向プログラム生成装置、その方法、プログラム Download PDF

Info

Publication number
JP2012048329A
JP2012048329A JP2010187732A JP2010187732A JP2012048329A JP 2012048329 A JP2012048329 A JP 2012048329A JP 2010187732 A JP2010187732 A JP 2010187732A JP 2010187732 A JP2010187732 A JP 2010187732A JP 2012048329 A JP2012048329 A JP 2012048329A
Authority
JP
Japan
Prior art keywords
diagram
class
consistency
oriented program
state machine
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.)
Pending
Application number
JP2010187732A
Other languages
English (en)
Inventor
Takeshi Miyazaki
剛 宮崎
Kazuhiko Sugino
一彦 杉野
Kazuhiro Soyama
和弘 曽山
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Fuji Electric Co Ltd
Original Assignee
Fuji Electric Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Fuji Electric Co Ltd filed Critical Fuji Electric Co Ltd
Priority to JP2010187732A priority Critical patent/JP2012048329A/ja
Publication of JP2012048329A publication Critical patent/JP2012048329A/ja
Pending legal-status Critical Current

Links

Landscapes

  • Stored Programmes (AREA)

Abstract

【課題】設計ドキュメントからオブジェクト指向のプログラムコードを自動で生成するオブジェクト指向プログラム生成装置、その方法、プログラムを提供する。
【解決手段】エディタなどの入力装置によって開発対象システムのUMLモデル図を作成する各UMLモデル図作成部41〜44と、各UMLモデル図の情報51〜54を記憶するUMLモデル図記憶部91と、前記UMLモデル図記憶部91から前記UMLモデル図の情報を読み出し、UMLモデル図間の整合性をチェックするUMLモデル図判別部60と、整合性に問題が無ければオブジェクト指向プログラムを自動で生成するプログラムコード生成部70とを備える。
【選択図】図1

Description

本発明は、設計ドキュメントからオブジェクト指向のプログラムコードを自動で生成するオブジェクト指向プログラム生成装置、その方法、プログラムに関する。
オブジェクト指向をベースとするシステム開発において、分析・設計段階ではシステムの構造をソースコードよりも抽象化した形でモデリングする必要がある。モデリングとは、対象をある目的または観点から眺め、整理し表現することであり、このモデリングした結果作成されたものをモデルと呼ぶ。
モデリングの表記方法を統一化することにより、分析の明確化や適切な設計、情報の共有化・再利用を行うことがきる。
統一モデリング言語としてUML(Unified Modeling Language)が知られている。UMLは、業務及びソフトウェアを記述するための図式記法として、オブジェクト指向の標準化団体である米国のOMG(オブジェクト・マネジメント・グループ)で制定された規格である。既に、デファクトスタンダードとして世界で受け入れられており、国際規格(ISO/IEC 19501)としても制定されている。
また、UMLはグラフィカルな記述で抽象化したシステムのモデルを生成する汎用モデリング言語であり、その実施において、複数種類の図が用いられている。UMLで用いられる図(以降、UMLモデル図と表記する)は、開発対象システムの分析や設計を行う際に作成される。また、UMLモデル図は、システムの静的な構造をモデルで表現する構造図とシステムの振る舞いをモデルで表現する振る舞い図に大別される。
構造図としては、クラス図、オブジェクト図などがある。振る舞い図としては、ステートマシン図(ステートチャート図や状態遷移図とも表現される)、シーケンス図、などがある。
ところで、従来のオブジェクト指向プログラム開発においては、市販のUMLモデリングツールを用いて、UMLモデル図を作成し、作成したUMLモデル図からプログラムコードを自動で生成することで、ソフトウェアの生産性向上が図られてきた。
しかしながら、市販のUMLモデリングツールを用いて、自動生成できるUMLモデル図は構造図のみであり、振る舞い図からプログラムコードを自動生成することまではできていない。そのため、プログラム開発者は市販のUMLモデリングツールを用いて作成した振る舞い図を元に、手入力で振る舞い図に対応したプログラムコードを生成する必要があった。
また、特許文献1では、構造図だけではなく、振る舞い図であるステートマシン図(ステートチャート図)とアクティビティ図からプログラムコードを自動で生成するオブジェクト指向プログラムの自動生成装置を提供している。
特開2002−116911号公報
しかしながら、特許文献1のオブジェクト指向プログラムの自動生成装置では、構造図と振る舞い図からプログラムコードを自動生成するものの、UMLモデル図間の整合性については何らチェックを行っていない。
従って、上述した自動生成装置を用いたシステム開発において、UMLモデル図から自動生成させたプログラムは、設計上の不具合を内在させたものとなる。また、プログラムの設計上の不具合はテスト工程にならないと発見できず、完了した設計工程に再び作業を戻して、UMLモデル図の不整合を修正することになり、開発作業の効率を低下させるという問題がある。
上記の課題を解決するために、本発明では、UMLモデル図(クラス図、オブジェクト図、ステートマシン図、シーケンス図)間の整合性をチェックし、整合性に問題が無い場合にのみプログラムコードを自動で生成する装置、方法、プログラムを提供することを目的とする。
上記課題を解決するために、本発明に係るオブジェクト指向プログラム生成装置は、開発対象システムの複数種類の設計ドキュメントを作成する設計ドキュメント作成部と、前記設計ドキュメント作成部により作成された設計ドキュメントの情報を記憶する設計ドキュメント記憶部と、前記設計ドキュメント記憶部から複数種類の前記設計ドキュメントの情報を各々読み出し、これら設計ドキュメント間の整合性をチェックする設計ドキュメント判別部と、前記設計ドキュメント判別部で整合性に問題が無いと判別されたときオブジェクト指向プログラムを生成するプログラムコード生成部とを備えることを特徴とする。
また、本発明に係るオブジェクト指向プログラム生成装置は、前記設計ドキュメントが、少なくともステートマシン図またはシーケンス図を含むUMLモデル図であることを特徴とする。
また、本発明に係るオブジェクト指向プログラム生成装置は、前記UMLモデル図が、クラス図、オブジェクト図を含み、前記設計ドキュメント判別部が、オブジェクト図に記載されている全てのオブジェクトがクラス図に記載されているクラスのインスタンスであるか否かの整合性、ステートマシン図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるか否かと、ステートマシン図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるか否かの整合性、シーケンス図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるか否かと、シーケンス図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるか否かの整合性、シーケンス図に記載されている全てのオブジェクトがオブジェクト図に記載されているオブジェクトであるか否かの整合性、または、シーケンス図に記載されている全ての状態がステートマシン図に記載されている状態であるか否かの整合性の少なくともいずれかの整合性のチェックをすることを特徴とする。
尚、ここでは、クラス図作成部、オブジェクト図作成部、ステートマシン図作成部、及び、シーケンス図作成部は別々の手段としているが、クラス図、オブジェクト図、ステートマシン図、及び、シーケンス図の全てを同一の環境で作成できる手段であってもよい。
また、ここでは、装置として表現されているが、方法、プログラムにより実現されるとしてもよい。
本発明によれば、オブジェクト指向プログラム開発において、開発者は設計ドキュメントであるUMLモデル図からプログラムが自動で生成されるので、プログラム作成作業が大幅に軽減され、また、本発明により、プログラムコードを自動で生成する前に、UMLモデル図間の整合性をチェックすることにより、ソフトウェアテスト時の不具合を未然に防ぐことができ、結果としてプログラムの作成作業が大幅に軽減され、オブジェクト指向プログラム開発のトータル作業工数を大幅に削減することができる。
本発明におけるオブジェクト指向プログラム生成装置の一例を示す図である。 クラス図の一例を示す図である。 オブジェクト図の一例を示す図である。 ステートマシン図(クラス名が”ClassA”であるクラス)の一例を示す図である。 ステートマシン図(クラス名が”ClassB”であるクラス)の一例を示す図である。 ステートマシン図(クラス名が”ClassC”であるクラス)の一例を示す図である。 シーケンス図の一例を示す図である。 UMLモデル図判別部にて、UMLモデル図の整合性に問題がないかどうかを判別する際の処理を示すフローチャート図である。 異常なオブジェクト図の一例を示す図である。 異常なオブジェクト図の一例を示す図である。 異常なステートマシン図(クラス名が”ClassA”であるクラス)の一例を示す図である。 異常なステートマシン図(クラス名が”ClassA”であるクラス)の一例を示す図である。 異常なシーケンス図の一例(異常パターン1)を示す図である。 異常なシーケンス図の一例(異常パターン2)を示す図である。 異常なシーケンス図の一例(異常パターン3)を示す図である。 異常なシーケンス図の一例(異常パターン4)を示す図である。 異常なシーケンス図の一例(異常パターン5)を示す図である。 本発明におけるオブジェクト指向プログラム生成装置によってクラス図とステートマシン図から作成されるプログラムコードの一例を示す図である。 本発明におけるオブジェクト指向プログラム生成装置によってオブジェクト図、ステートマシン図、及び、シーケンス図から作成されるプログラムコードの一例を示す図である。
以下、本発明の実施の形態について、詳細に説明する。
図1は、本発明におけるオブジェクト指向プログラム生成装置の一例を示す図である。
図1に示すように、オブジェクト指向プログラム生成装置は、エディタなどの入力装置によって開発対象システムのクラス構造を表現するクラス図を作成するクラス図作成部41、エディタなどの入力装置によって開発対象システムのオブジェクト構造を表現するオブジェクト図を作成するオブジェクト図作成部42、エディタなどの入力装置によって開発対象システムの各クラスにおける状態の変化を表現するステートマシン図を作成するステートマシン図作成部43、エディタなどの入力装置によって開発対象システムのオブジェクト間のメッセージの流れを表現するシーケンス図を作成するシーケンス図作成部44、上記で作成したUMLモデル図の情報(クラス図51、オブジェクト図52、ステートマシン図53、シーケンス図54)を記憶するUMLモデル図記憶部91、UMLモデル図記憶部91から、UMLモデル図の情報を読み出しUMLモデル図間の整合性をチェックし問題がないかどうかを判別するUMLモデル図判別部60、及び、UMLモデル図間の整合性に問題がない場合に上記により作成されたUMLモデル図からプログラムコードを自動で生成するプログラムコード生成部70、生成されたプログラムコード80を記憶するプログラムコード記憶部92とで構成されている。
また、図示はしていないが、オブジェクト指向プログラム生成装置の機能を実現するためにオブジェクト指向プログラム生成装置本体10は、一般的なコンピュータのハードウェア資源として、例えば、CPU、記憶装置、入出力装置、各種インターフェースなど、を周知の構成として備えており、また当然ながら、上記のごとき機能を実現させるためのプログラムを上記記憶装置内に格納している。UMLモデル図記憶部91、プログラム記憶部92は上述の記憶装置により実現され、また、上述の各種作成部(41〜44)、UMLモデル図判別部60、プログラムコード生成部70内の各構成は、上述のCPU、記憶装置、各種インターフェース等のハードウェア資源と後述する処理フローを実行する各種プログラムにより実現される。
さらに、オブジェクト指向プログラム生成装置は、キーボード、マウス、タッチパネル等のインターフェースを用いて実現される入力部20と、液晶または有機EL等からなる表示パネルや音声出力用のスピーカー等を有し、各種情報を出力する出力部30を備える。
また、入力部20及び出力部30は、オブジェクト指向プログラム生成装置本体10のクライアント端末(図示せず)にその機能があってもよい。このときは、ネットワークを介してオブジェクト指向プログラム生成装置本体10とクライアント端末が通信可能に接続されている。なお、ネットワークは、有線、無線を問わず既存の公衆網、LAN、WANなどを用いることができる。
図2は、本発明におけるクラス図の一例を示す図である。クラス図は、クラス図作成部41を用いて作成される。
図2に示すように、各クラスは、クラス名、属性、及び、操作の区画から構成される。また、操作は、ステレオタイプなどを使用し、処理関数とイベントに分類される。
図2に示す例では、クラス名が”ClassA”であるクラスは、属性として、int型である変数”a”、及び、char型である変数”b”を持つ。また、処理関数として、返り値の型が”void”である処理関数”Ma1”、及び、”Ma2”を持つ。また、イベントとして、返り値の型が”void”であるイベント”Ea1”、”Ea2”、及び、”Ea3”を持つ。
さらに、クラス名が”ClassB”であるクラスは、属性を持っていない。また、処理関数として、返り値の型が”void”である処理関数”Mb1”を持つ。また、イベントとして、返り値の型が”void”であるイベント”Eb1”、及び、”Eb2”を持つ。
さらに、クラス名が”ClassC”であるクラスは、属性を持っていない。また、処理関数として、返り値の型が”void”である処理関数”Mc1”、”Mc3”、及び、”Mc4”を持つ。また、イベントとして、返り値の型が”void”であるイベント”Ec1”、”Ec2”、”Ec3”、及び、”Ec4”を持つ。
図3は、本発明におけるオブジェクト図の一例を示す図である。オブジェクト図は、オブジェクト図作成部42を用いて作成される。
図3に示すように、各オブジェクトは、オブジェクト名、及び、クラス名によって表現される。
図3に示す例では、オブジェクト名が”objectA1”であるオブジェクトとオブジェクト名が”objectA2”であるオブジェクトは、クラス名が”ClassA”であるクラスのインスタンスであることを示している。
さらに、オブジェクト名が”objectB1”であるオブジェクトは、クラス名が”ClassB”であるクラスのインスタンスであることを示している。
さらに、オブジェクト名が”objectC1”であるオブジェクトは、クラス名が”ClassC”であるクラスのインスタンスであることを示している。
図4、図5、及び、図6は、本発明におけるステートマシン図の一例を示す図である。また、図4はクラス名が”ClassA”であるクラスのステートマシン図であり、図5はクラス名が”ClassB”であるクラスのステートマシン図であり、図6はクラス名が”ClassC”であるクラスのステートマシン図である。ステートマシン図は、ステートマシン図作成部43を用いて作成される。
図4、図5、及び、図6に示すように、各ステートマシン図は、開始(図中に●で表示)、状態、及び、遷移を持つ。
図4に示す例では、状態として、”StateA1”、”StateA2”、及び、”StateA3”を持ち、初期状態(開始からの遷移で表現される)は”StateA1”である。また、遷移として、3つの遷移を持つ。
1つ目の遷移では、”StateA1”の状態でイベント”Ea1”を受け取ると、処理関数”Ma1”を実行し、”StateA2”へ状態を遷移する。
2つ目の遷移では、”StateA2”の状態でイベント”Ea2”を受け取ると、処理関数”Ma2”を実行し、”StateA3”へ状態を遷移する。
3つ目の遷移では、”StateA3”の状態でイベント”Ea3”を受け取ると、何も処理を実行することなく、”StateA1”へ状態を遷移する。
図5に示す例では、状態として、”StateB1”、及び、”StateB2”を持ち、初期状態は”StateB1”である。また、遷移として、2つの遷移を持つ。
1つ目の遷移では、”StateB1”の状態でイベント”Eb1”を受け取ると、処理関数”Mb1”を実行し、”StateB2”へ状態を遷移する。
2つ目の遷移では、”StateB2”の状態でイベント”Eb2”を受け取ると、処理関数”Mb1”を実行し、”StateB1”へ状態を遷移する。
図6に示す例では、状態として、”StateC1”、”StateC2”、”StateC3”、及び、”StateC4”を持ち、初期状態は”StateC1”である。また、遷移として、6つの遷移を持つ。
1つ目の遷移では、”StateC1”の状態でイベント”Ec1”を受け取ると、処理関数”Mc1”を実行し、”StateC2”へ状態を遷移する。
2つ目の遷移では、”StateC1”の状態でイベント”Ec3”を受け取ると、処理関数”Mc3”を実行し、”StateC4”へ状態を遷移する。
3つ目の遷移では、”StateC2”の状態でイベント”Ec2”を受け取ると、何も処理を実行することなく、”StateC3”へ状態を遷移する。
4つ目の遷移では、”StateC3”の状態でイベント”Ec3”を受け取ると、何も処理を実行することなく、”StateC4”へ状態を遷移する。
5つ目の遷移では、”StateC4”の状態でイベント”Ec1”を受け取ると、処理関数”Mc1”を実行し、”StateC2”へ状態を遷移する。
6つ目の遷移では、”StateC4”の状態でイベント”Ec4”を受け取ると、処理関数”Mc4”を実行し、状態は遷移しない。
図7は、本発明におけるシーケンス図の一例を示す図である。シーケンス図は、シーケンス図作成部44を用いて作成される。
図7に示すように、シーケンス図は、メッセージ終了点(図中に●で表示)、ライフライン、及び、メッセージを持つ。また、各シーケンスは、メッセージ終了点からあるライフライン(以降、ライフライン1と表記する)に対してメッセージを送信し、そのメッセージを送信されたライフライン1からあるライフライン(以降、ライフライン2と表記する)に対してメッセージを送信するように表記される。
図7に示す例では、1つ目のシーケンスでは、オブジェクト名が”objectA1”であるオブジェクトが”StateA1”の状態でイベント”Ea1”を受け取ると、オブジェクト名が”objectB1”であるオブジェクトに対してイベント”Eb1”を送信し、オブジェクト名が”objectC1”であるオブジェクトに対してイベント”Ec1”を送信する。
2つ目のシーケンスでは、オブジェクト名が”objectA2”であるオブジェクトが”StateA1”の状態でイベント”Ea1”を受け取ると、オブジェクト名が”objectB1”であるオブジェクトに対してイベント”Eb1”を送信する。
3つ目のシーケンスでは、オブジェクト名が”objectA2”であるオブジェクトが”StateA2”の状態でイベント”Ea2”を受け取ると、オブジェクト名が”objectB1”であるオブジェクトに対してイベント”Eb2”を送信し、オブジェクト名が”objectC1”であるオブジェクトに対してイベント”Ec2”を送信する。
4つ目のシーケンスでは、オブジェクト名が”objectB1”であるオブジェクトが”StateB1”の状態でイベント”Eb2”を受け取ると、オブジェクト名が”objectA1”であるオブジェクトに対してイベント”Ea3”を送信し、オブジェクト名が”objectA2”であるオブジェクトに対してイベント”Ea3”を送信する。
5つ目のシーケンスでは、オブジェクト名が”objectC1”であるオブジェクトが処理関数”Mc1”を実行すると、オブジェクト名が”objectA1”であるオブジェクトに対してイベント”Ea2”を送信し、オブジェクト名が”objectA2”であるオブジェクトに対してイベント”Ea2”を送信し、オブジェクト名が”objectB1”であるオブジェクトに対してイベント”Eb1”を送信する。
図8は、UMLモデル図判別部60にて、UMLモデル図間の整合性に問題がないかどうかを判別する際の処理を示すフローチャート図である。
UMLモデル図判別処理では、オブジェクト図とクラス図の関係に問題がないかどうかをチェックする(S801)。オブジェクト図とクラス図の関係に問題がある場合、異常で終了する。S801では、オブジェクト図に記載されている全てのオブジェクトがクラス図に記載されているクラスのインスタンスであるかどうかをチェックする。
ここでS801の詳細について図2、図3、図9、図10を例に説明する。
例えば、図3に記載されている全てのオブジェクトは図2に記載されているクラスのインスタンスであるため、図3に示すオブジェクト図と図2に示すクラス図の関係には問題がないと判別し、処理を続行する。
また、図9に記載されているオブジェクト名が”objectX1”であるオブジェクトは、クラス名が”ClassX”であるクラスのインスタンスであり、クラス名が”ClassX”であるクラスは図2に記載されていないため、図9に示すオブジェクト図と図2に示すクラス図の関係には問題があると判別し、異常で終了する。
また、図10に記載されているオブジェクト名が”objectX2”であるオブジェクトは、クラスのインスタンスではないため、図10に示すオブジェクト図と図2に示すクラス図の関係には問題があると判別し、異常で終了する。
図8に戻って、続いて、ステートマシン図とクラス図の関係に問題がないかどうかをチェックする(S802)。ステートマシン図とクラス図の関係に問題がある場合、異常で終了する。S802では、ステートマシン図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるかどうかをチェックする。また、S802では、ステートマシン図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるかどうかをチェックする。
ここでS802の詳細について図2、図4、図5、図6、図11、図12を例に説明する。
例えば、図4、図5、及び、図6に記載されている全てのイベントは図2に記載されているクラスのイベントであり、図4、図5、及び、図6に記載されている全ての処理関数は図2に記載されているクラスの処理関数であるため、図4、図5、及び、図6に示すステートマシン図と図2に示すクラス図の関係には問題がないと判別し、処理を続行する。
また、図11に記載されているステートマシン図は、クラス名が”ClassA”であるクラスのステートマシン図であるが、図11において、状態”StateA1”から状態”StateA2”への遷移で使用されているイベント”Ex1”は図2に記載されているクラス名が”ClassA”であるクラスのイベントではないため、図11に示すステートマシン図と図2に示すクラス図の関係には問題があると判別し、異常で終了する。
また、図12に記載されているステートマシン図は、クラス名が”ClassA”であるクラスのステートマシン図であるが、図12において、状態”StateA2”から状態”StateA3”への遷移で使用されている処理関数”Mx1”は図2に記載されているクラス名が”ClassA”であるクラスの処理関数ではないため、図12に示すステートマシン図と図2に示すクラス図の関係には問題があると判別し、異常で終了する。
図8に戻って、続いて、シーケンス図とクラス図の関係に問題がないかどうかをチェックする(S803)。シーケンス図とクラス図の関係に問題がある場合、異常で終了する。S803では、シーケンス図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるかどうかをチェックする。また、S803では、シーケンス図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるかどうかをチェックする。
ここでS803の詳細について図2、図7、図13、図14、図15を例に説明する。
例えば、図7に記載されている全てのイベントは図2に記載されているクラスのイベントであり、図7に記載されている全ての処理関数は図2に記載されているクラスの処理関数であるため、図7に示すシーケンス図と図2に示すクラス図の関係には問題がないと判別し、処理を続行する。
また、図13に記載されているシーケンス図において、オブジェクト名が”objectA1”であるオブジェクトが”StateA1”の状態で受け取るイベント”Ex2”は図2に記載されているクラス名が”ClassA”であるクラスのイベントではないため、図13に示すシーケンス図と図2に示すクラス図の関係には問題があると判別し、異常で終了する。
また、図14に記載されているシーケンス図において、オブジェクト名が”objectA1”であるオブジェクトがオブジェクト名が”objectB1”であるオブジェクトに対して送信するイベント”Ex3”は図2に記載されているクラス名が”ClassB”であるクラスのイベントではないため、図14に示すシーケンス図と図2に示すクラス図の関係には問題があると判別し、異常で終了する。
また、図15に記載されているシーケンス図において、オブジェクト名が”objectC1”であるオブジェクトが処理を実行する処理関数”Mx2”は図2に記載されているクラス名が”ClassC”であるクラスの処理関数ではないため、図15に示すシーケンス図と図2に示すクラス図の関係には問題があると判別し、異常で終了する。
図8に戻って、続いて、シーケンス図とオブジェクト図の関係に問題がないかどうかをチェックする(S804)。シーケンス図とオブジェクト図の関係に問題がある場合、異常で終了する。S804では、シーケンス図に記載されている全てのオブジェクトがオブジェクト図に記載されているオブジェクトであるかどうかをチェックする。
ここでS804の詳細について図3、図7、図16を例に説明する。
例えば、図7に記載されている全てのオブジェクトは、図3に記載されているオブジェクトであるため、図7に示すシーケンス図と図3に示すオブジェクト図の関係には問題がないと判別し、処理を続行する。
また、図16に記載されているシーケンス図において、オブジェクト名が”objectX3”であるオブジェクトは図3に記載されていないため、図16に示すシーケンス図と図3に示すオブジェクト図の関係には問題があると判別し、異常で終了する。
図8に戻って、続いて、シーケンス図とステートマシン図の関係に問題がないかどうかをチェックする(S805)。シーケンス図とステートマシン図の関係に問題がある場合、異常で終了する。S805では、シーケンス図に記載されている全ての状態がステートマシン図に記載されている状態であるかどうかをチェックする。
ここでS805の詳細について図4、図5、図6、図7、図17を例に説明する。
例えば、図7に記載されている全ての状態は図4、図5、及び、図6に記載されている状態であるため、図7に示すシーケンス図と図4、図5、及び、図6に示すステートマシン図の関係には問題がないと判別し、正常で終了する。
また、図17に記載されているシーケンス図において、オブジェクト名が”objectA1”であるオブジェクトがイベント”Ea1”を受け取る状態”StateX1”は図4に記載されているクラス名が”ClassA”であるクラスの状態ではないため、図17に示すシーケンス図と図4に示すステートマシン図の関係には問題があると判別し、異常で終了する。
以上により、UMLモデル図間の整合性をチェックし問題がないかどうかを判別する。なお、ここでは、UMLモデル図間の整合性のチェックの順番をオブジェクト図とクラス図、ステートマシン図とクラス図、シーケンス図とクラス図、シーケンス図とオブジェクト図、シーケンス図とステートマシン図のようにしているが、順番は任意であってもよい。また、作成しないUMLモデル図の種類がある場合は、その含まれるUMLモデル図間の整合性のチェックを飛ばして次のチェックを行ってもよい。
図18は、本発明におけるクラス図とステートマシン図から作成されるプログラムコードの一例を示す図である。図18に示すプログラムコードは、プログラムコード生成部70を用いて自動で作成される。また、生成されたプログラムコード80は、プログラム記憶部92に記憶される。
図18に示すプログラムコードは、クラス名が”ClassA”であるクラスのプログラムコードである。図18において、4行目〜6行目、14行目、及び、31行目〜41行目は図4に示すステートマシン図から作成され、2行目、9行目〜11行目、17行目〜18行目、45行目〜47行目、及び、49行目〜51行目は図2に示すクラス図から作成される。
同様に、クラス名が”ClassB”であるクラス、及び、クラス名が”ClassC”であるクラスのプログラムコードもプログラムコード生成部70を用いて自動で作成される。
図19は、本発明におけるオブジェクト図、ステートマシン図、及び、シーケンス図から作成されるプログラムコードの一例を示す図である。プログラムコードは、プログラムコード生成部70を用いて自動で作成される。また、生成されたプログラムコード80は、プログラム記憶部92に記憶される。
図19は、処理の流れを表わしたプログラムコードである。図19において、6行目〜9行目は図3に示すオブジェクト図から作成され、19行目〜26行目は図4に示すステートマシン図から作成され、35行目〜61行目は図7に示すシーケンス図から作成される。
なお、ここでは、プログラムコードをJava(登録商標)言語を用いて表記しているが、その他の言語(C言語、C++言語など)を用いて表記してもよい。
以上のように、本発明を適用することにより、オブジェクト指向プログラム開発において、クラス図、オブジェクト図、ステートマシン図、及び、シーケンス図を作成し、オブジェクト指向プログラム生成装置を使用することで、プログラムコードが自動で生成されるため、プログラム作成作業が大幅に軽減され、トータル作業工数を大幅に削減することが可能となった。
また、本発明を適用することにより、UMLモデル図間の整合性をチェックすることにより、ソフトウェアテスト時の不具合を未然に防ぐことができ、テスト作業を軽減することが可能となった。
さらに、特許文献1のオブジェクト指向プログラムの自動生成装置では、振る舞い図として、各クラスにおける状態の変化を表現するステートマシン図(ステートチャート図)とステートマシン図の一種であるアクティビティ図のみを対象としていたが、本実施例では、オブジェクト間のメッセージの流れを時間軸に沿って表現するシーケンス図についても対象としており、複数種類のUMLモデル図を使ったオブジェクト指向のシステム開発において、トータル作業工数を大幅に削減することが可能となった。
10 オブジェクト指向プログラム生成装置本体
20 入力部
30 出力部
41 クラス図作成部
42 オブジェクト図作成部
43 ステートマシン作成部
44 シーケンス図作成部
51 クラス図データ
52 オブジェクト図データ
53 ステートマシン図データ
54 シーケンス図データ
60 UMLモデル図判別部
70 プログラムコード生成部
80 プログラムコード
91 UMLモデル図記憶部
92 プログラム記憶部

Claims (7)

  1. オブジェクト指向プログラムを生成するオブジェクト指向プログラム生成装置であって、
    開発対象システムの複数種類の設計ドキュメントを作成する設計ドキュメント作成部と、
    前記設計ドキュメント作成部により作成された設計ドキュメントの情報を記憶する設計ドキュメント記憶部と、
    前記設計ドキュメント記憶部から複数種類の前記設計ドキュメントの情報を各々読み出し、これら設計ドキュメント間の整合性をチェックする設計ドキュメント判別部と、
    前記設計ドキュメント判別部で整合性に問題が無いと判別されたときオブジェクト指向プログラムを生成するプログラムコード生成部と
    を備えることを特徴とするオブジェクト指向プログラム生成装置。
  2. 請求項1記載のオブジェクト指向プログラム生成装置において、
    前記設計ドキュメントは、少なくともステートマシン図またはシーケンス図を含むUMLモデル図であることを特徴とするオブジェクト指向プログラム生成装置。
  3. 請求項2記載のオブジェクト指向プログラム生成装置において、
    前記UMLモデル図は、クラス図、オブジェクト図を含み、
    前記設計ドキュメント判別部は、
    オブジェクト図に記載されている全てのオブジェクトがクラス図に記載されているクラスのインスタンスであるか否かの整合性、
    ステートマシン図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるか否かと、ステートマシン図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるか否かの整合性、
    シーケンス図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるか否かと、シーケンス図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるか否かの整合性、
    シーケンス図に記載されている全てのオブジェクトがオブジェクト図に記載されているオブジェクトであるか否かの整合性、
    または、シーケンス図に記載されている全ての状態がステートマシン図に記載されている状態であるか否かの整合性の少なくともいずれかの整合性のチェックをすることを特徴とするオブジェクト指向プログラム生成装置。
  4. オブジェクト指向プログラムを自動的に生成するオブジェクト指向プログラムの生成方法であって、
    入力された開発対象システムにおける複数の設計ドキュメント間の整合性をチェックするステップと、
    チェックした結果、問題が無ければオブジェクト指向プログラムを自動生成するステップと
    を備えることを特徴とするオブジェクト指向プログラム生成方法。
  5. 請求項4記載のオブジェクト指向プログラム生成方法において、
    前記複数の設計ドキュメント間の整合性をチェックするステップは、
    オブジェクト図に記載されている全てのオブジェクトがクラス図に記載されているクラスのインスタンスであるか否かの整合性、
    ステートマシン図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるか否かと、ステートマシン図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるか否かの整合性、
    シーケンス図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるか否かと、シーケンス図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるか否かの整合性、
    シーケンス図に記載されている全てのオブジェクトがオブジェクト図に記載されているオブジェクトであるか否かの整合性、
    または、シーケンス図に記載されている全ての状態がステートマシン図に記載されている状態であるか否かの整合性の少なくともいずれかの整合性のチェックをすることを特徴とするオブジェクト指向プログラム生成方法。
  6. オブジェクト指向プログラムを自動的に生成するオブジェクト指向プログラム生成装置に、
    入力された開発対象システムの複数の設計ドキュメント間の整合性をチェックするステップと、
    チェックした結果、問題が無ければオブジェクト指向プログラムを自動生成するステップ、
    を実行させることを特徴とするオブジェクト指向プログラム生成プログラム。
  7. 請求項6記載のオブジェクト指向プログラム生成プログラムにおいて、
    前記複数の設計ドキュメント間の整合性をチェックするステップは、
    オブジェクト図に記載されている全てのオブジェクトがクラス図に記載されているクラスのインスタンスであるか否かの整合性、
    ステートマシン図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるか否かと、ステートマシン図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるか否かの整合性、
    シーケンス図に記載されている全てのイベントがクラス図に記載されているクラスのイベントであるか否かと、シーケンス図に記載されている全ての処理関数がクラス図に記載されているクラスの処理関数であるか否かの整合性、
    シーケンス図に記載されている全てのオブジェクトがオブジェクト図に記載されているオブジェクトであるか否かの整合性、
    または、シーケンス図に記載されている全ての状態がステートマシン図に記載されている状態であるか否かの整合性の少なくともいずれかの整合性のチェックを実行させることを特徴とするオブジェクト指向プログラム生成プログラム。

JP2010187732A 2010-08-25 2010-08-25 オブジェクト指向プログラム生成装置、その方法、プログラム Pending JP2012048329A (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2010187732A JP2012048329A (ja) 2010-08-25 2010-08-25 オブジェクト指向プログラム生成装置、その方法、プログラム

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2010187732A JP2012048329A (ja) 2010-08-25 2010-08-25 オブジェクト指向プログラム生成装置、その方法、プログラム

Publications (1)

Publication Number Publication Date
JP2012048329A true JP2012048329A (ja) 2012-03-08

Family

ID=45903163

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2010187732A Pending JP2012048329A (ja) 2010-08-25 2010-08-25 オブジェクト指向プログラム生成装置、その方法、プログラム

Country Status (1)

Country Link
JP (1) JP2012048329A (ja)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2014153783A (ja) * 2013-02-05 2014-08-25 Fuji Electric Co Ltd オブジェクト指向プログラム生成装置、オブジェクト指向プログラム生成方法およびオブジェクト指向プログラム生成用プログラム
JP2014222482A (ja) * 2013-05-14 2014-11-27 富士電機株式会社 オブジェクト指向プログラム生成装置、オブジェクト指向プログラム生成方法、およびオブジェクト指向プログラム生成用プログラム
JP2015026139A (ja) * 2013-07-24 2015-02-05 富士電機株式会社 プログラム生成装置、プログラム生成方法、およびプログラム生成用プログラム

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004070810A (ja) * 2002-08-08 2004-03-04 Nippon Telegr & Teleph Corp <Ntt> ビジュアルプログラミングシステム、ビジュアルプログラミング方法、ビジュアルプログラミング用プログラム及びそのプログラムを記録した記録媒体
JP2009289162A (ja) * 2008-05-30 2009-12-10 Toshiba Mitsubishi-Electric Industrial System Corp 制御プログラム及び試験方案自動作成装置

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004070810A (ja) * 2002-08-08 2004-03-04 Nippon Telegr & Teleph Corp <Ntt> ビジュアルプログラミングシステム、ビジュアルプログラミング方法、ビジュアルプログラミング用プログラム及びそのプログラムを記録した記録媒体
JP2009289162A (ja) * 2008-05-30 2009-12-10 Toshiba Mitsubishi-Electric Industrial System Corp 制御プログラム及び試験方案自動作成装置

Non-Patent Citations (8)

* Cited by examiner, † Cited by third party
Title
CSNA200303935001; SEWB+ オブジェクト指向分析・設計支援 使用の手引 第3版, 199811, p.84-85, 株式会社日立製作所 *
CSNB200700610001; 藤倉 俊幸, 他9名: 組み込みシステム開発者&LSI設計者のための UMLガイド, Design Wave Magazine , 20070501, p.7-11, CQ出版株式会社 *
CSND200500974015; 井上 樹: 'UMLモデリング向上委員会 第11回 ダイヤグラム間の整合性' DB Magazine 第14巻, 第14号, 20050301, p.153-159, 株式会社翔泳社 *
CSNG200000628017; 大西 淳, 他1名: 'UML法におけるモデル整合性検証支援手法' オブジェクト指向最前線 , 19970630, p.120-127, 株式会社朝倉書店 *
JPN6013026692; SEWB+ オブジェクト指向分析・設計支援 使用の手引 第3版, 199811, p.84-85, 株式会社日立製作所 *
JPN6013026694; 井上 樹: 'UMLモデリング向上委員会 第11回 ダイヤグラム間の整合性' DB Magazine 第14巻, 第14号, 20050301, p.153-159, 株式会社翔泳社 *
JPN6013026697; 大西 淳, 他1名: 'UML法におけるモデル整合性検証支援手法' オブジェクト指向最前線 , 19970630, p.120-127, 株式会社朝倉書店 *
JPN6013045003; 藤倉 俊幸, 他9名: 組み込みシステム開発者&LSI設計者のための UMLガイド, Design Wave Magazine , 20070501, p.7-11, CQ出版株式会社 *

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2014153783A (ja) * 2013-02-05 2014-08-25 Fuji Electric Co Ltd オブジェクト指向プログラム生成装置、オブジェクト指向プログラム生成方法およびオブジェクト指向プログラム生成用プログラム
JP2014222482A (ja) * 2013-05-14 2014-11-27 富士電機株式会社 オブジェクト指向プログラム生成装置、オブジェクト指向プログラム生成方法、およびオブジェクト指向プログラム生成用プログラム
JP2015026139A (ja) * 2013-07-24 2015-02-05 富士電機株式会社 プログラム生成装置、プログラム生成方法、およびプログラム生成用プログラム

Similar Documents

Publication Publication Date Title
US10797958B2 (en) Enabling real-time operational environment conformity within an enterprise architecture model dashboard
US8984489B2 (en) Quality on submit process
US9021440B1 (en) System and method for automated test script generation
US8490050B2 (en) Automatic generation of user interfaces
US8156473B2 (en) Model oriented debugging
US8910166B2 (en) Automatic transcoding and semantic adaptation between scripting and workflow systems
US8640084B2 (en) Generating validation test suites
US10185644B2 (en) Service implementation based debugger for service oriented architecture projects
US20210304142A1 (en) End-user feedback reporting framework for collaborative software development environments
JP5396979B2 (ja) ソフトウェア開発支援装置、システム、ソフトウェア開発支援装置の機能拡張方法、及びプログラム
US8918762B2 (en) Generating test plans and test cases from service-oriented architecture and process models
US9965252B2 (en) Method and system for generating stateflow models from software requirements
US8086997B2 (en) Detecting aspectual behavior in unified modeling language artifacts
US8584080B2 (en) Modeling and generating computer software product line variants
CN115292058A (zh) 一种业务场景级别服务拓扑生成方法、装置及电子设备
JP2015026139A (ja) プログラム生成装置、プログラム生成方法、およびプログラム生成用プログラム
US8448143B2 (en) System and method for message choreographies of services
JP2012048329A (ja) オブジェクト指向プログラム生成装置、その方法、プログラム
JP2013235508A (ja) オブジェクト指向プログラム生成装置、その方法、プログラム
Schumm et al. State Propagation for Business Process Monitoring on Different Levels of Abstraction
US20130111432A1 (en) Validation of a system model including an activity diagram
CN113378007A (zh) 数据回溯方法及装置、计算机可读存储介质、电子设备
US11182272B2 (en) Application state monitoring
Farah-Stapleton et al. Behavioral modeling of software intensive system architectures
JP5644599B2 (ja) オブジェクト指向モデル設計支援装置

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20120913

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20130528

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20130611

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130808

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20130910

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20140204