[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

JP7322255B2 - Electronic computer, method and program - Google Patents

Electronic computer, method and program Download PDF

Info

Publication number
JP7322255B2
JP7322255B2 JP2022109585A JP2022109585A JP7322255B2 JP 7322255 B2 JP7322255 B2 JP 7322255B2 JP 2022109585 A JP2022109585 A JP 2022109585A JP 2022109585 A JP2022109585 A JP 2022109585A JP 7322255 B2 JP7322255 B2 JP 7322255B2
Authority
JP
Japan
Prior art keywords
function
diagram
source code
code
displayed
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.)
Active
Application number
JP2022109585A
Other languages
Japanese (ja)
Other versions
JP2022125274A (en
Inventor
浩隆 戸谷
翼 青木
宏 藤本
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.)
Toshiba Corp
Original Assignee
Toshiba Corp
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
Priority claimed from JP2018229591A external-priority patent/JP7105683B2/en
Application filed by Toshiba Corp filed Critical Toshiba Corp
Priority to JP2022109585A priority Critical patent/JP7322255B2/en
Publication of JP2022125274A publication Critical patent/JP2022125274A/en
Application granted granted Critical
Publication of JP7322255B2 publication Critical patent/JP7322255B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Stored Programmes (AREA)

Description

本発明の実施形態は、電子計算機、方法及びプログラムに関する。 The embodiments of the present invention relate to electronic computers, methods and programs.

一般に、例えばレガシーコードと称される仕様が不明なソフトウェアを運用及び保守するためには、プログラム言語で記述されたソースコードの内容を理解する必要がある。 In general, it is necessary to understand the contents of source code written in a programming language in order to operate and maintain software whose specifications are unknown, which is called legacy code.

しかしながら、膨大なソースコードの内容を理解すること(以下、コードリーディングと表記)は困難であり、非常に時間がかかる。 However, it is difficult and extremely time consuming to understand the contents of a huge amount of source code (hereinafter referred to as code reading).

“Doxygen”、[online]、14 Feb,2011、[平成30年11月20日検索]、インターネット〈URL:http://www.doxygen.jp/〉"Doxygen", [online], 14 Feb, 2011, [searched November 20, 2018], Internet <URL: http://www.doxygen.jp/>

そこで、本発明が解決しようとする課題は、コードリーディングを支援することが可能な電子計算機、方法及びプログラムを提供することにある。 Therefore, the problem to be solved by the present invention is to provide a computer, method, and program capable of supporting code reading.

実施形態に係る電子計算機は、表示処理手段と、編集処理手段とを具備する。前記表示処理手段は、ソースコードを表示する第1領域及び前記ソースコードの少なくとも一部を表すダイアグラムを表示する第2領域が配置された画面を表示する。前記編集処理手段は、前記第2領域に表示されているダイアグラムを編集する。前記ソースコードには、複数の関数が記述されている。前記編集処理手段は、前記第1領域に表示されているソースコードに記述されている少なくとも1つの関数が電子計算機を使用するユーザによって指定された場合に、当該関数を表す関数シンボルを前記第2領域に表示されているダイアグラムに追加する。前記表示処理手段は、前記第1領域に表示されているソースコード中の前記ユーザによって指定された位置に第1コメントが作成された場合、前記第2領域に表示されている関数シンボルのうちの当該ソースコード中の当該ユーザによって指定された位置に記述されている関数を表す関数シンボルに前記第1コメントを付加して表示し、前記第2領域に表示された関数シンボルのうちの前記ユーザによって指定された関数シンボルに第2コメントが作成された場合、前記第1領域に表示されているソースコード中の当該関数シンボルによって表される関数が記述されている位置に前記第2コメントを付加して表示する。 A computer according to an embodiment includes display processing means and editing processing means. The display processing means displays a screen on which a first area displaying source code and a second area displaying a diagram representing at least part of the source code are arranged. The editing processing means edits the diagram displayed in the second area. A plurality of functions are described in the source code. When at least one function described in the source code displayed in the first area is designated by a user using a computer, the editing processing means converts the function symbol representing the function into the second area. Add to the diagram displayed in the area. The display processing means, when a first comment is created at a position specified by the user in the source code displayed in the first area, displays function symbols displayed in the second area. The first comment is added to the function symbol representing the function described at the position specified by the user in the source code, and the function symbol displayed in the second area is displayed by the user. When the second comment is created for the designated function symbol, the second comment is added to the position where the function represented by the function symbol is described in the source code displayed in the first area. displayed.

実施形態に係るコードリーディング支援装置の機能構成の一例を示すブロック図。1 is a block diagram showing an example of the functional configuration of a code reading assistance device according to an embodiment; FIG. コードリーディング支援装置のシステム構成の一例を示す図。The figure which shows an example of the system configuration|structure of a code reading assistance apparatus. コード解析情報に含まれる関数情報のデータ構造の一例を示す図。4 is a diagram showing an example of the data structure of function information included in code analysis information; FIG. コード解析情報に含まれるコードブロック情報のデータ構造の一例を示す図。A diagram showing an example of the data structure of code block information included in code analysis information. コード付加情報のデータ構造の一例を示す図。The figure which shows an example of the data structure of code addition information. ダイアグラム情報のデータ構造の一例を示す図。The figure which shows an example of the data structure of diagram information. ダイアグラム付加情報のデータ構造の一例を示す図。The figure which shows an example of the data structure of diagram additional information. ダイアグラム表示処理の処理手順の一例を示すフローチャート。4 is a flowchart showing an example of a processing procedure of diagram display processing; コードリーディング支援プログラムが起動された際の表示画面の一例を示す図。FIG. 4 is a diagram showing an example of a display screen when the code reading support program is started; コード表示領域にソースコードが表示された際の表示画面の一例を示す図。FIG. 4 is a diagram showing an example of a display screen when source code is displayed in the code display area; 関数シンボルについて具体的に説明するための図。FIG. 4 is a diagram for specifically explaining function symbols; ダイアグラム表示処理を具体的に説明するための図。FIG. 4 is a diagram for specifically explaining diagram display processing; ダイアグラム表示処理を具体的に説明するための図。FIG. 4 is a diagram for specifically explaining diagram display processing; ダイアグラム表示処理を具体的に説明するための図。FIG. 4 is a diagram for specifically explaining diagram display processing; 複数の関数が指定された後に当該関数を表す関数シンボルが追加される場合について説明するための図。FIG. 4 is a diagram for explaining a case where function symbols representing the functions are added after a plurality of functions are specified; ダイアグラムを全体的に表示するための領域が更に配置された表示画面の一例を示す図。The figure which shows an example of the display screen in which the area|region for displaying a diagram as a whole is further arranged. コメント付加処理の処理手順の一例を示すフローチャート。6 is a flowchart showing an example of a processing procedure of comment addition processing; コメント作成画面の一例を示す図。The figure which shows an example of a comment creation screen. コメント付加処理を具体的に説明するための図。FIG. 5 is a diagram for specifically explaining comment addition processing; 強調表示変更処理の処理手順の一例を示すフローチャート。5 is a flowchart showing an example of a processing procedure of highlighting change processing; 強調表示変更処理を具体的に説明するための図。FIG. 5 is a diagram for specifically explaining highlighting change processing;

以下、図面を参照して、実施形態について説明する。
本実施形態に係る電子計算機は、例えばJava(登録商標)またはC言語等のプログラム言語で記述されたソースコードの内容を理解すること(コードリーディング)を支援するために用いられる。以下、本実施形態に係る電子計算機を、便宜的に、コードリーディング支援装置と称する。
Embodiments will be described below with reference to the drawings.
The computer according to the present embodiment is used to support understanding (code reading) of source code written in a programming language such as Java (registered trademark) or C language. Hereinafter, the computer according to this embodiment will be referred to as a code reading support device for convenience.

図1は、本実施形態に係るコードリーディング支援装置の機能構成の一例を示すブロック図である。図1に示すように、コードリーディング支援装置10は、コード格納部11、ダイアグラム格納部12、コード表示処理部13、ダイアグラム表示処理部14、操作受付部15及び編集処理部16を含む。 FIG. 1 is a block diagram showing an example of the functional configuration of the code reading support device according to this embodiment. As shown in FIG. 1, the chord reading support device 10 includes a chord storage section 11, a diagram storage section 12, a chord display processing section 13, a diagram display processing section 14, an operation reception section 15 and an editing processing section 16.

コード格納部11には、例えばコードリーディング支援装置10を使用するユーザが内容を理解すべきソースコードが格納される。また、コード格納部11には、当該コード格納部11に格納されているソースコードに対する解析結果を示すコード解析情報が格納される。なお、コード格納部11には、複数のソースコード及び当該複数のソースコードの各々に対する解析結果を示すコード解析情報が格納されていてもよい。 The code storage unit 11 stores, for example, source codes whose contents should be understood by the user using the code reading support device 10 . The code storage unit 11 also stores code analysis information indicating analysis results for the source code stored in the code storage unit 11 . Note that the code storage unit 11 may store a plurality of source codes and code analysis information indicating analysis results for each of the plurality of source codes.

ここで、ソースコードには複数の関数が含まれるが、当該複数の関数の各々は、少なくとも1つのコードブロックから構成される。なお、本実施形態において、コードブロックとは、例えば複数の行に亘って記載されたコードのまとまり(ブロック)であり、上記したJavaまたはC言語等では「{」及び「}」で囲まれた部分に相当する。 Here, the source code includes a plurality of functions, each of which consists of at least one code block. In the present embodiment, a code block is, for example, a group (block) of code written over a plurality of lines. equivalent to part.

この場合、コード格納部11に格納されるコード解析情報は、当該コード格納部11に格納されているソースコードに含まれる関数及び当該関数を構成するコードブロック等を示す。 In this case, the code analysis information stored in the code storage unit 11 indicates functions included in the source code stored in the code storage unit 11, code blocks that constitute the functions, and the like.

なお、コード解析情報を得るためにはソースコードを解析する必要があるが、当該ソースコードの解析は、例えば統合開発環境において実行される。また、この統合開発環境を提供するためのコード解析ツールとしては、Eclipse JDT、Understand及びClang等が利用可能である。 To obtain the code analysis information, it is necessary to analyze the source code, and the analysis of the source code is executed in an integrated development environment, for example. Also, Eclipse JDT, Understand, Clang, etc. can be used as code analysis tools for providing this integrated development environment.

更に、コード格納部11には、当該コード格納部11に格納されているソースコードが表示される際に当該ソースコードに付加される情報(以下、コード付加情報と表記)が格納されている。 Further, the code storage section 11 stores information added to the source code stored in the code storage section 11 when the source code is displayed (hereinafter referred to as code additional information).

ダイアグラム格納部12には、コード格納部11に格納されているソースコードの少なくとも一部を表すダイアグラムを表示するために用いられるダイアグラム情報が格納される。また、ダイアグラム格納部12には、ダイアグラム情報を用いてダイアグラムが表示される際に当該ダイアグラムに付加される情報(以下、ダイアグラム付加情報と表記)が格納されている。 The diagram storage unit 12 stores diagram information used to display a diagram representing at least part of the source code stored in the code storage unit 11 . The diagram storage unit 12 also stores information added to the diagram when the diagram is displayed using the diagram information (hereinafter referred to as additional diagram information).

ここで、本実施形態に係るコードリーディング支援装置10においては、少なくともコード表示領域(第1表示領域)及びダイアグラム表示領域(第2表示領域)を含む画面が表示される。 Here, in the chord reading assistance device 10 according to the present embodiment, a screen including at least a chord display area (first display area) and a diagram display area (second display area) is displayed.

コード表示処理部13は、コード格納部11に格納されているソースコードをコード表示領域に表示する処理を実行する。なお、コード表示処理部13は、コード表示領域にソースコードを表示する際に、コード格納部11に格納されているコード付加情報を当該ソースコードに付加する。 The code display processing unit 13 executes processing for displaying the source code stored in the code storage unit 11 in the code display area. Note that the code display processing unit 13 adds code additional information stored in the code storage unit 11 to the source code when displaying the source code in the code display area.

ダイアグラム表示処理部14は、ダイアグラム格納部12に格納されているダイアグラム情報を用いて、コード表示領域に表示されているソースコードの一部を表すダイアグラムをダイアグラム表示領域に表示する処理を実行する。なお、ダイアグラム表示処理部14は、ダイアグラム表示領域にダイアグラムを表示する際に、ダイアグラム格納部12に格納されているダイアグラム付加情報を当該ダイアグラムに付加する。なお、ダイアグラム表示処理部14は、ダイアグラムを表示する際に、上記したコード格納部11に格納されているコード解析情報を利用する。 The diagram display processing unit 14 uses the diagram information stored in the diagram storage unit 12 to execute processing for displaying a diagram representing part of the source code displayed in the code display area in the diagram display area. The diagram display processing unit 14 adds the diagram additional information stored in the diagram storage unit 12 to the diagram when displaying the diagram in the diagram display area. The diagram display processing unit 14 uses the chord analysis information stored in the chord storage unit 11 when displaying the diagram.

操作受付部15は、コード表示領域に表示されたソースコード及びダイアグラム表示領域に表示されたダイアグラムに対するユーザの操作を受け付ける。 The operation reception unit 15 receives a user's operation on the source code displayed in the code display area and the diagram displayed in the diagram display area.

編集処理部16は、操作受付部15によって受け付けられるユーザの操作に基づいて、例えばダイアグラム表示領域に表示されたダイアグラムを編集する。また、編集処理部16は、操作受付部15によって受け付けられるユーザの操作に基づいて、コード格納部11に格納されているコード付加情報及びダイアグラム格納部12に格納されているダイアグラム付加情報を変更(編集)する。 The edit processing unit 16 edits the diagram displayed in the diagram display area, for example, based on the user's operation received by the operation receiving unit 15 . Further, the edit processing unit 16 changes (changes) the chord additional information stored in the chord storage unit 11 and the diagram additional information stored in the diagram storage unit 12 based on the user's operation received by the operation reception unit 15. To edit.

本実施形態に係るコードリーディング支援装置10は、ソースコードのビューア(またはエディタ)としての機能に加えて、当該ソースコードの少なくとも一部を表すダイアグラムのエディタとしての機能を有する。 The code reading support device 10 according to the present embodiment has a function as a source code viewer (or editor) and a diagram editor function that represents at least part of the source code.

図2は、図1に示すコードリーディング支援装置10のシステム構成の一例を示す。ここでは、コードリーディング支援装置10が例えばパーソナルコンピュータ(PC)等であるものとして説明するが、コードリーディング支援装置10は他の電子計算機であってもよい。 FIG. 2 shows an example of the system configuration of the code reading support device 10 shown in FIG. Although the code reading support device 10 is assumed to be, for example, a personal computer (PC), the code reading support device 10 may be another computer.

図2に示すように、コードリーディング支援装置10は、CPU101、不揮発性メモリ102、主メモリ103、BIOS-ROM104、システムコントローラ105、入力デバイス106、表示デバイス107及びエンベデッドコントローラ(EC)108等を備える。 As shown in FIG. 2, the code reading support device 10 includes a CPU 101, a nonvolatile memory 102, a main memory 103, a BIOS-ROM 104, a system controller 105, an input device 106, a display device 107, an embedded controller (EC) 108, and the like. .

CPU101は、コードリーディング支援装置10内の各コンポーネントの動作を制御するプロセッサである。CPU101は、ストレージデバイスである不揮発性メモリ102から主メモリ103にロードされる様々なプログラムを実行する。このプログラムには、オペレーティングシステム(OS)及び上記したようにコードリーディングを支援するためのプログラム(以下、コードリーディング支援プログラムと表記)等が含まれる。 A CPU 101 is a processor that controls the operation of each component in the code reading support device 10 . The CPU 101 executes various programs loaded into the main memory 103 from the non-volatile memory 102, which is a storage device. This program includes an operating system (OS), a program for supporting code reading as described above (hereinafter referred to as a code reading support program), and the like.

また、CPU101は、BIOS-ROM104に格納された基本入出力システム(BIOS)も実行する。BIOSは、ハードウェア制御のためのプログラムである。 CPU 101 also executes a basic input/output system (BIOS) stored in BIOS-ROM 104 . BIOS is a program for hardware control.

システムコントローラ105は、CPU101のローカルバスと各種コンポーネントとの間を接続するデバイスである。 A system controller 105 is a device that connects between the local bus of the CPU 101 and various components.

入力デバイス106は、例えばキーボード及びマウス等を含む。表示デバイス107は、例えば液晶表示装置のようなディスプレイ等を含む。EC108は、電力管理のためのエンベデッドコントローラを含むワンチップマイクロコンピュータである。 Input device 106 includes, for example, a keyboard and a mouse. The display device 107 includes, for example, a display such as a liquid crystal display. EC 108 is a one-chip microcomputer containing an embedded controller for power management.

なお、図2においては、CPU101、不揮発性メモリ102、主メモリ103、BIOS-ROM104、システムコントローラ105、入力デバイス106、表示デバイス107及びEC108のみが示されているが、コードリーディング支援装置10は、例えばHDD(Hard Disk Drive)及びSSD(Solid State Drive)のような他の記憶装置を備えていてもよいし、外部装置との通信を実行するように構成された通信デバイス等を備えていてもよい。 Although FIG. 2 shows only the CPU 101, the nonvolatile memory 102, the main memory 103, the BIOS-ROM 104, the system controller 105, the input device 106, the display device 107 and the EC 108, the code reading support device 10 includes: For example, it may be provided with other storage devices such as HDD (Hard Disk Drive) and SSD (Solid State Drive), or may be provided with a communication device or the like configured to execute communication with an external device. good.

本実施形態において、図1に示すコード格納部11及びダイアグラム格納部12は、例えば図2に示す不揮発性メモリ102または他の記憶装置を用いて実現される。 In this embodiment, the code storage unit 11 and the diagram storage unit 12 shown in FIG. 1 are implemented using, for example, the non-volatile memory 102 shown in FIG. 2 or other storage devices.

また、本実施形態において、図1に示す各部13~16の一部または全ては、例えば図2に示すCPU101(つまり、コードリーディング支援装置10のコンピュータ)に上記したコードリーディング支援プログラムを実行させること、すなわちソフトウェアによって実現されるものとする。なお、コードリーディング支援プログラムは、コンピュータ読み取り可能な記憶媒体に予め格納して頒布可能である。また、コードリーディング支援プログラムは、例えばネットワークを介してコードリーディング支援装置10にダウンロードされても構わない。 In the present embodiment, some or all of the units 13 to 16 shown in FIG. 1 cause the CPU 101 shown in FIG. 2 (that is, the computer of the code reading assistance device 10) to execute the code reading assistance program. , that is, implemented by software. Note that the code reading support program can be stored in advance in a computer-readable storage medium and distributed. Also, the code reading assistance program may be downloaded to the code reading assistance device 10 via a network, for example.

ここでは、各部13~16の一部または全てがソフトウェアによって実現されるものとして説明したが、当該各部13~16の一部または全ては、例えばハードウェアによって実現されてもよいし、ソフトウェア及びハードウェアの組み合わせ構成として実現されてもよい。 Here, some or all of the units 13 to 16 have been described as being realized by software, but some or all of the units 13 to 16 may be realized by hardware, for example, or software and hardware. It may also be implemented as a hardware combination configuration.

以下、上記した図1に示すコード格納部11及びダイアグラム格納部12に格納される各種情報について説明する。 Various information stored in the code storage unit 11 and the diagram storage unit 12 shown in FIG. 1 will be described below.

まず、図3及び図4を参照して、コード格納部11に格納されているコード解析情報について説明する。上記したようにコード格納部11に格納されているソースコードは複数の関数を含み、当該関数の各々は少なくとも1つのコードブロックから構成されるが、コード解析情報は、当該ソースコードに含まれる関数を示す関数情報及び当該関数を構成するコードブロックを示すコードブロック情報を含む。 First, the code analysis information stored in the code storage unit 11 will be described with reference to FIGS. 3 and 4. FIG. As described above, the source code stored in the code storage unit 11 includes a plurality of functions, each of which consists of at least one code block. and code block information indicating code blocks that constitute the function.

図3は、上記したコード解析情報に含まれる関数情報のデータ構造の一例を示す。図3に示すように、関数情報には、ソースコードID、関数ID及び位置情報が含まれる。 FIG. 3 shows an example of the data structure of function information included in the code analysis information described above. As shown in FIG. 3, the function information includes source code ID, function ID and location information.

ソースコードIDは、コード格納部11に格納されているソースコードを識別するための識別情報である。 A source code ID is identification information for identifying a source code stored in the code storage unit 11 .

関数IDは、当該関数IDに対応づけられているソースコードIDによって識別されるソースコードに含まれる関数を識別するための識別情報である。 A function ID is identification information for identifying a function included in the source code identified by the source code ID associated with the function ID.

位置情報は、コード格納部11に格納されているソースコード(つまり、当該位置情報に対応づけられているソースコードIDによって識別されるソースコード)における、当該位置情報に対応づけられている関数IDによって識別される関数の位置を示す。なお、関数情報に含まれる位置情報は、ソースコード中の関数が記述されている行番号(開始行及び終了行)等を含む。 The position information is the function ID associated with the position information in the source code stored in the code storage unit 11 (that is, the source code identified by the source code ID associated with the position information). indicates the location of the function identified by . Note that the position information included in the function information includes line numbers (start line and end line) where the function in the source code is described.

図3に示す例では、関数情報111a及び111bが示されている。関数情報111aには、ソースコードID「1」、関数ID「1」及び位置情報「x1~x2」が含まれている。この関数情報111aによれば、ソースコードID「1」によって識別されるソースコードには関数ID「1」によって識別される関数が含まれており、当該関数が当該ソースコード中のx1行目~x2行目に記述されていることが示されている。 In the example shown in FIG. 3, function information 111a and 111b are shown. The function information 111a includes a source code ID "1", a function ID "1", and position information "x1-x2". According to this function information 111a, the source code identified by the source code ID "1" includes the function identified by the function ID "1", and the function is from the x1 line in the source code. It is shown that it is described in the x2 line.

一方、関数情報111bには、ソースコードID「1」、関数ID「2」及び位置情報「y1~y2」が含まれている。この関数情報111bによれば、ソースコードID「1」によって識別されるソースコードには関数ID「2」によって識別される関数が含まれており、当該関数が当該ソースコード中のy1行目~y2行目に記述されていることが示されている。 On the other hand, the function information 111b includes source code ID "1", function ID "2", and position information "y1 to y2". According to this function information 111b, the source code identified by the source code ID "1" includes the function identified by the function ID "2", and the function is from line y1 in the source code. It is shown that it is described in the y2 line.

図3においては便宜的に関数情報111a及び111bについてのみ説明したが、コード格納部11に格納されているコード解析情報には、当該コード格納部11に格納されているソースコードに含まれる関数毎の関数情報が含まれている。 3, only the function information 111a and 111b are explained for convenience, but the code analysis information stored in the code storage unit 11 includes functions included in the source code stored in the code storage unit 11. contains function information for

図4は、コード解析情報に含まれるコードブロック情報のデータ構造の一例を示す。図4に示すように、コードブロック情報には、関数ID、コードブロックID及び位置情報が含まれる。 FIG. 4 shows an example of the data structure of code block information included in code analysis information. As shown in FIG. 4, the code block information includes function IDs, code block IDs, and position information.

関数IDは、上記した関数情報に含まれる関数IDであり、コード格納部11に格納されているソースコードに含まれる関数を識別するための識別情報である。 The function ID is a function ID included in the function information described above, and is identification information for identifying a function included in the source code stored in the code storage unit 11 .

コードブロックIDは、当該コードブロックIDに対応づけられている関数IDによって識別される関数を構成するコードブロックを識別するための識別情報である。 A code block ID is identification information for identifying a code block forming a function identified by a function ID associated with the code block ID.

位置情報は、上記したコード格納部11に格納されているソースコードにおける、当該位置情報に対応づけられているコードブロックIDによって識別されるコードブロックの位置を示す。なお、コードブロック情報に含まれる位置情報は、ソースコード中のコードブロックが記述されている行番号等を含む。 The position information indicates the position of the code block identified by the code block ID associated with the position information in the source code stored in the code storage unit 11 described above. Note that the position information included in the code block information includes line numbers where the code blocks in the source code are written.

図4に示す例では、コードブロック情報112a及び112bが示されている。コードブロック情報112aには、関数ID「1」、コードブロックID「1」及び位置情報「x11~x12」が含まれている。このコードブロック情報112aによれば、関数ID「1」によって識別される関数がコードブロックID「1」によって識別されるコードブロックから構成されており、当該コードブロックがソースコード中のx11行目~x12行目に記述されていることが示されている。 In the example shown in FIG. 4, code block information 112a and 112b are shown. The code block information 112a includes function ID "1", code block ID "1", and position information "x11 to x12". According to the code block information 112a, the function identified by the function ID "1" is composed of the code block identified by the code block ID "1", and the code block is the x11th line in the source code. It is shown that it is described in the x12th line.

一方、コードブロック情報112bには、関数ID「1」、コードブロックID「2」及び位置情報「x13~x14」が含まれている。このコードブロック情報112bによれば、関数ID「1」によって識別される関数がコードブロックID「2」によって識別されるコードブロックから構成されており、当該コードブロックがソースコード中のx13行目~x14行目に記述されていることが示されている。 On the other hand, the code block information 112b includes function ID "1", code block ID "2", and position information "x13-x14". According to the code block information 112b, the function identified by the function ID "1" is composed of the code block identified by the code block ID "2", and the code block is the x13 line in the source code. It is shown that it is described in the x14th line.

図4においては便宜的にコードブロック情報112a及び112bについてのみ説明したが、コード格納部11に格納されているコード解析情報には、当該コード格納部11に格納されているソースコードに含まれる関数を構成するコードブロック毎のコードブロック情報が含まれている。 4, only the code block information 112a and 112b are explained for convenience, but the code analysis information stored in the code storage unit 11 includes functions included in the source code stored in the code storage unit 11. contains code block information for each code block that constitutes the

なお、図4に示すように1つの関数(つまり、関数ID「1」によって識別される関数)は複数のコードブロック(つまり、コードブロックID「1」及び「2」の各々によって識別されるコードブロック)から構成されてもよいが、当該関数は、例えば1つのコードブロック内に他のコードブロックが記述されるような入れ子構造を有していてもよい。また、関数そのものを1つのコードブロックとして扱うようにしてもよい。 As shown in FIG. 4, one function (that is, the function identified by the function ID "1") corresponds to a plurality of code blocks (that is, code blocks identified by each of the code block IDs "1" and "2"). block), but the function may have a nested structure such that, for example, another code block is written within one code block. Alternatively, the function itself may be treated as one code block.

図5は、コード格納部11に格納されているコード付加情報のデータ構造の一例を示す。図5に示すように、コード付加情報には、ソースコードID、付加内容及び位置情報が含まれる。 FIG. 5 shows an example of the data structure of code additional information stored in the code storage unit 11. As shown in FIG. As shown in FIG. 5, the code additional information includes a source code ID, additional content, and position information.

ソースコードIDは、コード格納部11に格納されているソースコードを識別するための識別情報である。 A source code ID is identification information for identifying a source code stored in the code storage unit 11 .

付加内容は、当該付加内容に対応づけられているソースコードIDによって識別されるソースコードがコード表示領域に表示される際に、当該ソースコードに付加される内容を示す。なお、本実施形態において、コード表示領域に表示されるソースコードには、例えばコメント及び強調情報等が付加される。 The additional content indicates content added to the source code when the source code identified by the source code ID associated with the additional content is displayed in the code display area. Note that, in the present embodiment, comments, emphasis information, and the like, for example, are added to the source code displayed in the code display area.

位置情報は、当該位置情報に対応づけられている付加内容に従ってコメントまたは強調情報等が付加される、コード格納部11に格納されているソースコード(つまり、当該位置情報に対応づけられているソースコードIDによって識別されるソースコード)の位置(部分)を示す。なお、コード付加情報に含まれる位置情報は、上記した関数情報及びコードブロック情報に含まれる位置情報と同様に、行番号等を含む。 The position information is the source code stored in the code storage unit 11 to which comments, emphasis information, etc. are added according to the additional content associated with the position information (that is, the source code associated with the position information). Indicates the location (portion) of the source code identified by the code ID. The position information included in the code additional information includes line numbers and the like, like the position information included in the function information and code block information described above.

図5に示す例では、コード付加情報113a及び113bが示されている。コード付加情報113aには、ソースコードID「1」、付加内容「強調」及び位置情報「x1~x2」が含まれている。このコード付加情報113aによれば、ソースコードID「1」によって識別されるソースコードがコード表示領域に表示される際に、当該ソースコード中のx1行目~x2行目に強調情報が付加されることが示されている。 In the example shown in FIG. 5, code additional information 113a and 113b are shown. The code additional information 113a includes a source code ID "1", additional content "emphasis", and position information "x1 to x2". According to this code addition information 113a, when the source code identified by the source code ID "1" is displayed in the code display area, the emphasis information is added to the x1 line to the x2 line in the source code. It is shown that

なお、ソースコードに対して強調情報が付加される場合には、例えば強調されていることを表す図形、記号またはマーク等がソースコードの該当する部分(つまり、コード付加情報に含まれる位置情報によって示される位置)に付加されればよいが、当該部分(テキスト)のフォント(書体、太さ、色彩等)が変更されてもよい。すなわち、本実施形態において、「ソースコード(の部分)に対して強調情報が付加される」とは、該当するソースコードの部分が強調されていることをユーザが把握することができるように、当該ソースコードの部分に対して所定の処理を施すことをいう。以下の説明においては、ソースコードに強調情報を付加することを、便宜的にソースコードを強調表示すると表現する。 When the emphasis information is added to the source code, for example, a figure, symbol, mark, or the like indicating that the emphasis is placed on the corresponding portion of the source code (that is, by the position information included in the code addition information) indicated position), but the font (typeface, thickness, color, etc.) of the portion (text) may be changed. That is, in the present embodiment, "emphasis information is added to (the part of) the source code" means that the user can understand that the relevant source code part is emphasized. It refers to performing a predetermined process on the part of the source code. In the following description, adding highlighting information to the source code is expressed as highlighting the source code for convenience.

一方、コード付加情報113bには、ソースコードID「1」、付加内容「コメント1」及び位置情報「x15」が含まれている。このコード付加情報113bによれば、ソースコードID「1」によって識別されるソースコードがコード表示領域に表示される際に、当該ソースコード中のx15行目にコメント1が付加されることが示されている。 On the other hand, the code additional information 113b includes the source code ID "1", additional content "comment 1", and position information "x15". According to the code addition information 113b, when the source code identified by the source code ID "1" is displayed in the code display area, it is indicated that the comment 1 is added to the x15 line in the source code. It is

図5においては便宜的にコード付加情報113a及び113bについてのみ説明したが、コード格納部11には、他の付加情報が格納されていてもよい。 Although only the code additional information 113a and 113b has been described in FIG. 5 for the sake of convenience, the code storage unit 11 may store other additional information.

また、図5に示す例では付加内容としてコメント及び強調情報が付加されることについてのみ説明したが、当該付加内容は、ソースコードが表示される際に当該ソースコードに付加される(つまり、当該ソースコードの表示を変更する)ものであれば他の内容であっても構わない。 Also, in the example shown in FIG. 5, only comments and emphasis information are added as additional content, but the additional content is added to the source code when the source code is displayed (that is, the It may be other content as long as it changes the display of the source code.

次に、図6は、ダイアグラム格納部12に格納されているダイアグラム情報のデータ構造の一例を示す。図6に示すように、ダイアグラム情報には、ダイアグラムID、呼び出し元関数ID及び呼び出し先関数IDが含まれる。 Next, FIG. 6 shows an example of the data structure of diagram information stored in the diagram storage unit 12. As shown in FIG. As shown in FIG. 6, the diagram information includes diagram ID, caller function ID and callee function ID.

ダイアグラムIDは、上記したダイアグラム表示領域に表示されるダイアグラムを識別するための識別情報である。 The diagram ID is identification information for identifying the diagram displayed in the above diagram display area.

呼び出し元関数IDは、コード格納部11に格納されているソースコードに含まれる関数(第1関数)を識別するための識別情報である。呼び出し元関数IDによって識別される関数は、当該呼び出し元関数IDに対応づけられている呼び出し先関数IDによって識別される関数を含むように定義されているものとする。 The caller function ID is identification information for identifying a function (first function) included in the source code stored in the code storage unit 11 . A function identified by a caller function ID is defined to include a function identified by a callee function ID associated with the caller function ID.

呼び出し先関数IDは、コード格納部11に格納されているソースコードに含まれる関数(第2関数)を識別するための識別情報である。なお、呼び出し先関数IDによって識別される関数は、上記した当該呼び出し先関数IDに対応づけられている呼び出し元関数IDによって識別される関数内に記述された関数である。 A callee function ID is identification information for identifying a function (second function) included in the source code stored in the code storage unit 11 . The function identified by the callee function ID is a function described in the function identified by the callee function ID associated with the callee function ID.

すなわち、上記した呼び出し元関数IDによって識別される関数は呼び出し元関数であり、呼び出し先関数IDによって識別される関数は呼び出し先関数である。このため、ダイアグラム情報に含まれる呼び出し元関数ID及び呼び出し先関数IDは、当該ダイアグラム情報を用いて表示されるダイアグラムにおいて複数の関数の間の呼び出し関係を表すために用いられる。 That is, the function identified by the above caller function ID is the caller function, and the function identified by the callee function ID is the callee function. For this reason, the caller function ID and the callee function ID included in the diagram information are used to represent the calling relationship between a plurality of functions in the diagram displayed using the diagram information.

図6に示す例では、ダイアグラム情報121a及び121bが示されている。ダイアグラム情報121aには、ダイアグラムID「1」、呼び出し元関数ID「1」及び呼び出し先関数ID「2」が含まれている。このダイアグラム情報121aによれば、ダイアグラムID「1」によって識別されるダイアグラムが、呼び出し先関数ID「2」によって識別される関数が呼び出し元関数ID「1」によって識別される関数において呼び出されるという呼び出し関係を表すことが示されている。 In the example shown in FIG. 6, diagram information 121a and 121b are shown. The diagram information 121a includes diagram ID "1", caller function ID "1", and callee function ID "2". According to this diagram information 121a, the diagram identified by the diagram ID "1" is a calling function in which the function identified by the callee function ID "2" is called in the function identified by the caller function ID "1". shown to represent the relationship.

一方、ダイアグラム情報121bには、ダイアグラムID「1」、呼び出し元関数ID「2」及び呼び出し先関数ID「3」が含まれている。このダイアグラム情報121bによれば、ダイアグラムID「1」によって識別されるダイアグラムが、呼び出し先関数ID「3」によって識別される関数が呼出元関数ID「2」によって識別される関数において呼び出されるという呼び出し関係を表すことが示されている。 On the other hand, the diagram information 121b includes diagram ID "1", caller function ID "2", and callee function ID "3". According to this diagram information 121b, the diagram identified by the diagram ID "1" is a call that the function identified by the callee function ID "3" is called in the function identified by the caller function ID "2". shown to represent the relationship.

図6においては便宜的にダイアグラム情報121a及び121bについてのみ説明したが、ダイアグラム格納部12には、他のダイアグラム情報が格納されていてもよい。 Although only the diagram information 121a and 121b has been described in FIG. 6 for the sake of convenience, the diagram storage unit 12 may store other diagram information.

なお、図6に示すように、ダイアグラム(例えば、ダイアグラムID「1」によって識別されるダイアグラム)は、複数の呼び出し関係を表すものであってもよい。 Note that as shown in FIG. 6, a diagram (for example, a diagram identified by diagram ID "1") may represent a plurality of calling relationships.

図7は、ダイアグラム格納部12に格納されているダイアグラム付加情報のデータ構造の一例を示す。図7に示すように、ダイアグラム付加情報には、ダイアグラムID、付加内容及び位置情報が含まれる。 FIG. 7 shows an example of the data structure of diagram additional information stored in the diagram storage unit 12. As shown in FIG. As shown in FIG. 7, the diagram additional information includes diagram ID, additional content and position information.

ダイアグラムIDは、ダイアグラム表示領域に表示されるダイアグラムを識別するための識別情報である。 The diagram ID is identification information for identifying the diagram displayed in the diagram display area.

付加内容は、当該付加内容に対応づけられているダイアグラムIDによって識別されるダイアグラムがダイアグラム表示領域に表示される際に、当該ダイアグラムに付加される内容を示す。なお、本実施形態において、ダイアグラム表示領域に表示されるダイアグラムには、例えばコメント及び強調情報等が付加される。 The additional content indicates content added to the diagram when the diagram identified by the diagram ID associated with the additional content is displayed in the diagram display area. Note that, in the present embodiment, for example, comments and emphasis information are added to the diagrams displayed in the diagram display area.

位置情報は、当該位置情報に対応づけられている付加内容に従ってコメントまたは強調情報等が付加される、当該位置情報に対応づけられているダイアグラムIDによって識別されるダイアグラム上の位置を示す。なお、ダイアグラム付加情報に含まれる位置情報としては、例えば上記した関数ID及びコードブロック情報ID等が用いられる。 The positional information indicates a position on the diagram identified by the diagram ID associated with the positional information, to which comments, emphasis information, or the like are added according to the additional content associated with the positional information. As the position information included in the diagram additional information, for example, the function ID and code block information ID described above are used.

図7に示す例では、ダイアグラム付加情報122a及び122bが示されている。ダイアグラム付加情報122aには、ダイアグラムID「1」、付加内容「強調」及び位置情報「関数ID「1」」が含まれている。このダイアグラム付加情報122aによれば、ダイアグラムID「1」によって識別されるダイアグラムがダイアグラム表示領域に表示される際に、関数ID「1」によって識別される関数を表現する位置に強調情報が付加されることが示されている。 In the example shown in FIG. 7, additional diagram information 122a and 122b are shown. The diagram additional information 122a includes diagram ID "1", additional content "emphasis", and position information "function ID "1"". According to this diagram additional information 122a, when the diagram identified by the diagram ID "1" is displayed in the diagram display area, the emphasis information is added to the position expressing the function identified by the function ID "1". It is shown that

なお、ダイアグラムにおいて強調情報が付加される場合には、例えば強調されていることを表す色彩がダイアグラムの該当する部分(つまり、ダイアグラム情報に含まれる位置情報によって示される位置)に付加されればよいが、当該部分に強調されていることを表す記号、マークまたは模様等が付加されてもよい。すなわち、本実施形態において、「ダイアグラム(の部分)に対して強調情報が付加される」とは、該当するダイアグラムの部分が強調されていることをユーザが把握することができるように、当該ダイアグラムの部分に対して所定の処理を施すことをいう。以下の説明においては、ダイアグラムに強調情報を付加することを、便宜的にダイアグラムを強調表示すると表現する。 In addition, when emphasis information is added to the diagram, for example, a color indicating that it is emphasized may be added to the corresponding part of the diagram (that is, the position indicated by the position information included in the diagram information). However, a symbol, mark, pattern, or the like indicating that the portion is emphasized may be added. That is, in the present embodiment, "emphasis information is added to (a part of) a diagram" means that the diagram is displayed so that the user can understand that the relevant diagram part is emphasized. It means to apply a predetermined process to the part of In the following description, adding emphasis information to a diagram is referred to as highlighting the diagram for convenience.

一方、ダイアグラム付加情報122bには、ダイアグラムID「1」、付加内容「コメント2」及び位置情報「コードブロックID「1」」が含まれている。このダイアグラム付加情報122bによれば、ダイアグラムID「1」によって識別されるダイアグラムがダイアグラム表示領域に表示される際に、コードブロックID「1」によって識別されるコードブロックを表現する位置にコメント2が付加されることが示されている。 On the other hand, the diagram additional information 122b includes diagram ID "1", additional content "comment 2", and position information "code block ID "1". According to this diagram additional information 122b, when the diagram identified by the diagram ID "1" is displayed in the diagram display area, the comment 2 is placed at the position expressing the code block identified by the code block ID "1". is shown to be added.

なお、ダイアグラムにおいては、ソースコードに含まれる関数のみではなく、当該関数を構成するコードブロックをも表現することが可能であるが、当該ダイアグラムの具体例については後述する。 It should be noted that a diagram can represent not only functions included in the source code but also code blocks that constitute the functions, and a specific example of the diagram will be described later.

上記した図3~図7においては本実施形態において用いられる各種情報について説明したが、当該図3~図7において説明した情報は一例であり、当該情報の一部が省略されていてもよいし、当該情報に他の情報(項目)が含まれていてもよい。 Although various information used in the present embodiment is described in FIGS. 3 to 7 above, the information described in FIGS. 3 to 7 is an example, and part of the information may be omitted. , the information may include other information (items).

また、図3~図5に示すデータ構造は一例であり、コード格納部11に格納されるコード解析情報(関数情報及び情報)及びコード付加情報は、まとめて1つの情報として管理されていてもよい。同様に、図6及び図7に示すデータ構造は一例であり、ダイアグラム格納部12に格納されるダイアグラム情報及びダイアグラム付加情報は、まとめて1つの情報として管理されていてもよい。 The data structures shown in FIGS. 3 to 5 are only examples, and the code analysis information (function information and information) and code additional information stored in the code storage unit 11 may be collectively managed as one piece of information. good. Similarly, the data structures shown in FIGS. 6 and 7 are examples, and the diagram information and diagram additional information stored in the diagram storage unit 12 may be collectively managed as one piece of information.

次に、本実施形態に係るコードリーディング支援装置10の動作について説明する。ここでは、ソースコードの一部を表すダイアグラムを生成して表示する際の処理(以下、ダイアグラム表示処理と表記)、当該ソースコードに対してコメントを付加する際の処理(以下、コメント付加処理と表記)及び当該ソースコードに対する強調表示の有無を変更する際の処理(以下、強調表示変更処理と表記)の各々について主に説明する。 Next, the operation of the code reading assistance device 10 according to this embodiment will be described. Here, the processing for generating and displaying a diagram representing part of the source code (hereinafter referred to as diagram display processing) and the processing for adding comments to the source code (hereinafter referred to as comment addition processing). notation) and processing for changing the presence/absence of highlighting for the source code (hereinafter referred to as highlighting change processing and notation).

まず、図8のフローチャートを参照して、ダイアグラム表示処理の処理手順の一例について説明する。 First, an example of the processing procedure of the diagram display processing will be described with reference to the flowchart of FIG.

コードリーディング支援装置10を使用するユーザは、当該コードリーディング支援装置10上で上記したコードリーディング支援プログラムを起動する。 A user using the code reading support device 10 activates the above code reading support program on the code reading support device 10 .

コードリーディング支援装置10上でコードリーディング支援プログラムが起動された場合、コードリーディング支援装置10に備えられる表示デバイス107(ディスプレイ)には、図9に示すような画面が表示される。 When the code reading support program is started on the code reading support device 10, the display device 107 (display) provided in the code reading support device 10 displays a screen as shown in FIG.

図9に示すように、コードリーディング支援装置10に表示される画面(以下、表示画面と表記)200には、コード表示領域201及びダイアグラム表示領域202が含まれる。 As shown in FIG. 9 , a screen (hereinafter referred to as a display screen) 200 displayed on the chord reading support device 10 includes a chord display area 201 and a diagram display area 202 .

図9に示す例において、コード表示領域201及びダイアグラム表示領域202は、例えば上下方向に隣接するように並べて配置されている。なお、コード表示領域201及びダイアグラム表示領域202は、例えば左右方向に隣接するように配置されていてもよい。 In the example shown in FIG. 9, the chord display area 201 and the diagram display area 202 are arranged side by side, for example, vertically adjacent to each other. Note that the chord display area 201 and the diagram display area 202 may be arranged adjacent to each other in the horizontal direction, for example.

また、表示画面200には、ファイル選択領域203が更に含まれている。ユーザは、ファイル選択領域203において、例えばコード表示領域201に表示するソースコード(ファイル)を選択することができる。 In addition, the display screen 200 further includes a file selection area 203 . The user can select a source code (file) to be displayed, for example, in the code display area 201 in the file selection area 203 .

ユーザは、上記した表示画面200に対する各種操作を行うことによって、ソースコードの一部を表すダイアグラムを作成することができる。 The user can create a diagram representing part of the source code by performing various operations on the display screen 200 described above.

また、ファイル選択領域203において例えば過去に作成されたダイアグラムを表示するためのダイアグラム情報(ファイル)が選択された場合には、当該ダイアグラムをダイアグラム表示領域202に表示することも可能である。 Further, when diagram information (file) for displaying a diagram created in the past, for example, is selected in the file selection area 203, the diagram can be displayed in the diagram display area 202.

ここで、上記したようにソースコードの一部を表すダイアグラムを作成する場合、ユーザは、ファイル選択領域203において当該ソースコード(ファイル)を選択する。 Here, when creating a diagram representing part of the source code as described above, the user selects the source code (file) in the file selection area 203 .

この場合、コード表示処理部13は、ユーザによって選択されたソースコード(以下、対象ソースコードと表記)をコード表示領域201に表示する(ステップS1)。 In this case, the code display processing unit 13 displays the source code selected by the user (hereinafter referred to as the target source code) in the code display area 201 (step S1).

対象ソースコードの全てをコード表示領域201に表示することができない場合、コード表示領域201には、対象ソースコードが部分的に表示される。この場合、ユーザは、コードリーディング支援装置10に備えられる入力デバイス106(例えば、マウス及びキーボード等)を用いて当該コード表示領域201の表示をスクロールすることによって、対象ソースコードの所望の部分を表示することができるものとする。 If the entire target source code cannot be displayed in the code display area 201 , the target source code is partially displayed in the code display area 201 . In this case, the user scrolls the display of the code display area 201 using the input device 106 (for example, mouse and keyboard) provided in the code reading support device 10 to display the desired portion of the target source code. shall be able to

ステップS1の処理が実行されると、ユーザは、対象ソースコードに含まれる複数の関数をのうちの1つ(以下、第1対象関数と表記)をコード表示領域201に表示し、当該第1対象関数を指定する操作(関数追加操作と表記)を行う。ユーザは、この関数追加操作を行うことによって、第1対象関数をダイアグラムに追加することを指示することができる。なお、関数追加操作には、コード表示領域201において第1対象関数(の定義)が記述されている位置にカーソルを移動させる操作等が含まれるが、他の操作であってもよい。 When the process of step S1 is executed, the user displays one of a plurality of functions included in the target source code (hereinafter referred to as a first target function) in the code display area 201, and displays the first target function. Perform the operation to specify the target function (notation as function addition operation). The user can instruct to add the first target function to the diagram by performing this function addition operation. Note that the function addition operation includes an operation of moving the cursor to the position where (the definition of) the first target function is described in the code display area 201, but may be another operation.

操作受付部15は、上記した関数追加操作が受け付けられた(ユーザによって行われた)か否かを判定する(ステップS2)。 The operation accepting unit 15 determines whether or not the function addition operation described above has been accepted (performed by the user) (step S2).

関数追加操作が受け付けられたと判定された場合(ステップS2のYES)、編集処理部16は、上記した第1対象関数(対象ソースコードの一部)が追加されたダイアグラム(以下、対象ダイアグラムと表記)を表示するために用いられるダイアグラム情報を生成する(ステップS3)。この場合、編集処理部16は、対象ダイアグラムを識別するためのダイアグラムID及び第1対象関数を識別するための関数ID(呼び出し元関数ID)を含むダイアグラム情報を生成する。ステップS3において生成されたダイアグラム情報は、ダイアグラム格納部12に格納される。 If it is determined that the function addition operation has been accepted (YES in step S2), the editing processing unit 16 creates a diagram (hereinafter referred to as a target diagram) to which the first target function (part of the target source code) has been added. ) is generated (step S3). In this case, the edit processing unit 16 generates diagram information including a diagram ID for identifying the target diagram and a function ID (caller function ID) for identifying the first target function. The diagram information generated in step S3 is stored in the diagram storage unit 12. FIG.

次に、編集処理部16は、ステップS3において生成されたダイアグラム情報を用いて表示される対象ダイアグラムに付加されるダイアグラム付加情報を生成する(ステップS4)。この場合、編集処理部16は、例えば対象ダイアグラムを識別するためのダイアグラムID、付加内容「強調」及び第1対象関数を識別するための関数ID(位置情報)を含むダイアグラム付加情報を生成する。ステップS4において生成されたダイアグラム付加情報は、ダイアグラム格納部12に格納される。 Next, the edit processing unit 16 generates additional diagram information to be added to the target diagram to be displayed using the diagram information generated in step S3 (step S4). In this case, the edit processing unit 16 generates diagram additional information including, for example, a diagram ID for identifying the target diagram, additional content "emphasis", and a function ID (position information) for identifying the first target function. The diagram additional information generated in step S4 is stored in the diagram storage unit 12. FIG.

ステップS4の処理が実行されると、ダイアグラム表示処理部14は、ダイアグラム格納部12に格納されたダイアグラム情報及びダイアグラム付加情報に基づいて対象ダイアグラムを生成する(ステップS5)。 When the process of step S4 is executed, the diagram display processing unit 14 generates a target diagram based on the diagram information and diagram additional information stored in the diagram storage unit 12 (step S5).

なお、上記したダイアグラム情報及びダイアグラム付加情報によれば、ステップS5においては、第1対象関数が追加され、かつ、当該第1対象関数が強調表示された対象ダイアグラムが生成される。ステップS5において生成された対象ダイアグラムは、ダイアグラム表示領域202に表示される(ステップS6)。 According to the above-described diagram information and diagram additional information, in step S5, a first object function is added and an object diagram in which the first object function is highlighted is generated. The target diagram generated in step S5 is displayed in the diagram display area 202 (step S6).

また、編集処理部16は、上記した第1対象関数が対象ダイアグラムに追加されたこと(つまり、対象ダイアグラムの変更通知)に応じて、対象ソースコードに付加される付加情報(以下、コード付加情報と表記)を生成する(ステップS7)。この場合、編集処理部16は、例えばステップS1において表示された対象ソースコードを識別するためのソースコードID、付加内容「強調」及び第1対象関数が記述されている行番号(位置情報)を含むコード付加情報を生成する。ステップS7において生成されたコード付加情報は、コード格納部11に格納される。 In addition, the editing processing unit 16 adds additional information (hereinafter referred to as code additional information ) is generated (step S7). In this case, the edit processing unit 16, for example, inputs the source code ID for identifying the target source code displayed in step S1, the additional content "emphasis", and the line number (position information) where the first target function is described. Generate code additional information containing The code additional information generated in step S7 is stored in the code storage section 11. FIG.

ステップS7の処理が実行されると、コード表示処理部13は、コード格納部11に格納されたコード付加情報を、コード表示領域201に表示されている対象ソースコードに反映する(ステップS8)。上記したコード付加情報によれば、ステップS8の処理が実行されることによって、コード表示領域201に表示されている対象ソースコードの第1対象関数が記述されている部分が強調表示される。これによれば、対象ソースコードにおいて、対象ダイアグラムに追加された関数と当該対象ダイアグラムに追加されていない関数とを区別して表示することができる。 When the process of step S7 is executed, the code display processing unit 13 reflects the code additional information stored in the code storage unit 11 on the target source code displayed in the code display area 201 (step S8). According to the code additional information described above, the part where the first target function of the target source code displayed in the code display area 201 is described is highlighted by executing the process of step S8. According to this, in the target source code, functions added to the target diagram and functions not added to the target diagram can be displayed separately.

ステップS8の処理が実行されると、ステップS2に戻って処理が繰り返される。ここで、コード表示領域201には対象ソースコードの第1対象関数が記述されている部分が表示されているが、ユーザは、ステップS8の処理が実行された後に、当該第1対象関数内に記述されている他の関数(以下、第2対象関数と表記)を指定する関数追加操作を行うことができる。ユーザは、この関数追加操作を行うことによって、第2対象関数をダイアグラムに追加することを指示する。 After the process of step S8 is executed, the process returns to step S2 and the process is repeated. Here, the code display area 201 displays the part where the first target function of the target source code is described. A function addition operation can be performed to specify another function described (hereinafter referred to as a second target function). The user instructs to add the second target function to the diagram by performing this function addition operation.

ステップS2においてこのような関数追加操作が受け付けられたと判定された場合には、第2対象関数の定義が記述されている部分がコード表示領域201に表示され、ステップS3以降の処理が実行される。 When it is determined in step S2 that such a function addition operation has been accepted, the part where the definition of the second target function is described is displayed in the code display area 201, and the processes after step S3 are executed. .

なお、第2対象関数は、第1対象関数内に記述されているため、当該第1対象関数を呼び出し元関数とした場合における呼び出し先関数に相当する。この場合、ステップS3においては、対象ダイアグラムを識別するためのダイアグラムID、第1対象関数を識別するための関数ID(呼び出し元関数ID)及び第2対象関数を識別するための関数ID(呼び出し先関数ID)を含むダイアグラム情報を生成する。これによれば、対象ダイアグラムに第2対象関数を追加するとともに、当該対象ダイアグラムにおいて、第1対象関数及び第2対象関数との間の呼び出し関係を表すことができる。 Since the second target function is written in the first target function, it corresponds to the callee function when the first target function is the caller function. In this case, in step S3, the diagram ID for identifying the target diagram, the function ID for identifying the first target function (caller function ID), and the function ID for identifying the second target function (callee Generate diagram information including function ID). According to this, the second object function can be added to the object diagram, and the calling relationship between the first object function and the second object function can be expressed in the object diagram.

上記した第1対象関数(呼び出し元関数)と第2対象関数(呼び出し先関数)との関係は、例えば上記したコード格納部11に格納されているコード解析情報(つまり、各関数が記述されている位置)等によって判別可能であるが、当該関係が規定された情報(例えば対象ソースコードにおける接続行や接続先等を含む呼び出し箇所情報)がコードリーディング支援装置10内で別途管理されていてもよい。 The relationship between the first target function (caller function) and the second target function (callee function) is determined, for example, by the code analysis information stored in the code storage unit 11 (that is, each function is described). However, even if information defining the relationship (for example, call location information including connection lines and connection destinations in the target source code) is separately managed in the code reading support device 10 good.

以下に実行されるステップS4~S7の処理については上記した通りであるため、ここではその詳しい説明を省略する。 Since the processing of steps S4 to S7 executed below is as described above, detailed description thereof will be omitted here.

上記したダイアグラム表示処理によれば、対象ソースコードに含まれる関数のうちユーザによって指定された(関数追加操作が行われた)関数を対象ダイアグラムに追加するとともに、当該追加された複数の関数の間の呼び出し関係を当該対象ダイアグラムにおいて自動的に表すことができる。 According to the diagram display process described above, a function specified by the user (for which the function addition operation was performed) among the functions included in the target source code is added to the target diagram, and between the added functions can be automatically represented in the target diagram.

なお、ステップS2において関数追加操作が受け付けられていないと判定された場合(ステップS2のNO)、ダイアグラム表示処理は終了される。 If it is determined in step S2 that the function addition operation has not been accepted (NO in step S2), the diagram display processing ends.

図8においてはステップS3~S7の順に処理が実行されるものとして説明したが、当該処理の順番は適宜変更されても構わない。具体的には、例えばステップS7及びS8の処理の後にステップS3~S5の処理が実行されてもよい。 In FIG. 8, it is assumed that the processes are executed in the order of steps S3 to S7, but the order of the processes may be changed as appropriate. Specifically, for example, the processes of steps S3 to S5 may be executed after the processes of steps S7 and S8.

以下、上記したダイアグラム表示処理について具体的に説明する。図10は、上記した図8に示すステップS1の処理が実行された際のコードリーディング支援装置10に表示される画面(表示画面)の一例である。 The diagram display processing described above will be specifically described below. FIG. 10 is an example of a screen (display screen) displayed on the code reading support device 10 when the process of step S1 shown in FIG. 8 is executed.

図10に示すように、図8に示すステップS1が実行された場合、表示画面200に含まれるコード表示領域201には、対象ソースコードが表示される。なお、図10に示す例においては、対象ソースコードに含まれるmain関数の定義が記述された部分(5行目~13行目)がコード表示領域201に表示されている。なお、図10において対象ソースコードの各行の左側に付されている数値が行番号を表している。 As shown in FIG. 10, when step S1 shown in FIG. 8 is executed, the target source code is displayed in the code display area 201 included in the display screen 200. FIG. In the example shown in FIG. 10, the code display area 201 displays a portion (5th to 13th lines) where the definition of the main function included in the target source code is described. In FIG. 10, the numerical value attached to the left side of each line of the target source code represents the line number.

ユーザは、図10に示す表示画面200上で例えばmain関数を指定する関数追加操作を行うことができる。この場合、ユーザは、例えばコード表示領域201のmain関数の定義が記述された部分にカーソルを合わせることによって、当該main関数をダイアグラムに追加することを指示する。 The user can perform a function addition operation to specify, for example, the main function on the display screen 200 shown in FIG. In this case, the user instructs to add the main function to the diagram by, for example, placing the cursor on the part where the definition of the main function is written in the code display area 201 .

上記したようにmain関数が指定された場合には、上記した図8に示すステップS3~S6の処理が実行される。この場合におけるステップS3においては、main関数が追加される対象ダイアグラムを識別するためのダイアグラムID、当該main関数を識別するための関数ID(呼び出し元関数ID)を含むダイアグラム情報が生成される。なお、この時点では、呼び出し先関数に相当する関数は指定されていないため、ダイアグラム情報には呼び出し先関数IDは含まれない。 When the main function is designated as described above, the processes of steps S3 to S6 shown in FIG. 8 are executed. In step S3 in this case, diagram information including a diagram ID for identifying the target diagram to which the main function is added and a function ID (caller function ID) for identifying the main function is generated. At this point, the function corresponding to the callee function has not been specified, so the diagram information does not include the callee function ID.

また、ステップS4においては、ステップS3において生成されたダイアグラム情報に含まれるダイアグラムID(対象ダイアグラムを識別するためのダイアグラムID)、付加内容「強調」及びmain関数を識別するための関数ID(位置情報)を含むダイアグラム付加情報が生成される。 In step S4, the diagram ID (diagram ID for identifying the target diagram) included in the diagram information generated in step S3, the additional content "emphasis", and the function ID for identifying the main function (position information ) is generated.

ステップS5においては、ステップS3において生成されたダイアグラム情報及びステップS4において生成されたダイアグラム付加情報に基づいて対象ダイアグラムが生成される。なお、ステップS5においては、ダイアグラム情報に含まれる関数ID(呼び出し元関数ID)によって識別されるmain関数を表すシンボル(以下、関数シンボルと表記)を含む対象ダイアグラムが生成される。 In step S5, a target diagram is generated based on the diagram information generated in step S3 and the diagram additional information generated in step S4. In step S5, a target diagram is generated that includes a symbol (hereinafter referred to as function symbol) representing the main function identified by the function ID (caller function ID) included in the diagram information.

ここで、図11を参照して、上記した関数シンボルについて具体的に説明する。ここでは、便宜的に、上記したmain関数とは異なる関数を用いて説明するものとする。 Now, with reference to FIG. 11, the function symbols described above will be specifically described. Here, for the sake of convenience, a function different from the above-described main function will be used for explanation.

図11の左側に示す関数301(toy_call関数)は、while文に相当するコードブロック301a、if文に相当するコードブロック301b及び301cから構成されている。また、コードブロック301aには、if文に相当するコードブロック301dが更に含まれている。 A function 301 (toy_call function) shown on the left side of FIG. 11 is composed of a code block 301a corresponding to a while statement, and code blocks 301b and 301c corresponding to if statements. The code block 301a further includes a code block 301d corresponding to an if statement.

このような関数301を表す関数シンボル302は、上記した関数301全体を表現するメインシンボル301a及び当該関数301を構成するコードブロック301a~301dの各々を表すサブシンボル302b~302eから構成される。 A function symbol 302 representing such a function 301 is composed of a main symbol 301a representing the entire function 301 and sub-symbols 302b to 302e representing code blocks 301a to 301d constituting the function 301 respectively.

なお、関数シンボル302(メインシンボル302a)においてサブシンボル302b~302eが配置される位置は、コード格納部11に格納されているコード解析情報(関数情報及びコードブロック情報)に基づいて決定される。具体的には、例えばサブシンボル302bは、関数301において当該サブシンボル302bによって表されるコードブロック301aが記述されている位置に相当するメインシンボル302a上に配置される。他のサブシンボル302c~302eについても同様である。 The positions where the sub-symbols 302b to 302e are arranged in the function symbol 302 (main symbol 302a) are determined based on the code analysis information (function information and code block information) stored in the code storage section 11. FIG. Specifically, for example, the sub-symbol 302b is arranged on the main symbol 302a corresponding to the position where the code block 301a represented by the sub-symbol 302b in the function 301 is written. The same is true for other sub-symbols 302c-302e.

すなわち、本実施形態においては、ダイアグラム情報に含まれる関数ID(呼び出し元関数ID及び呼び出し先関数ID)によって識別される関数を構成するコードブロック(が記述されている位置)を当該関数IDを含むコードブロック情報に基づいて特定することによって、当該関数全体を表現するメインシンボル及び当該関数を構成するコードブロックを表すサブシンボルから構成される関数シンボルを生成することができる。 That is, in the present embodiment, the code block (the position where the function ID is described) constituting the function identified by the function ID (caller function ID and callee function ID) included in the diagram information is included in the function ID. By specifying based on the code block information, it is possible to generate a function symbol composed of a main symbol representing the entire function and sub-symbols representing code blocks constituting the function.

上記したように生成された関数シンボルを含む対象ダイアグラムは、ステップS6においてダイアグラム表示領域202に表示される。 The object diagram including the function symbols generated as described above is displayed in the diagram display area 202 in step S6.

上記したステップS3~S6の処理が実行された場合、ステップS7及びS8の処理が実行される。この場合におけるステップS7においては、対象ソースコードを識別するためのソースコードID、付加内容「強調」及び位置情報「5(行)~13(行)」を含むコード付加情報が生成される。また、ステップS8においては、ステップS7において生成されたコード付加情報がコード表示領域201に表示されている対象ソースコードに反映される。 When the processes of steps S3 to S6 are executed, the processes of steps S7 and S8 are executed. In step S7 in this case, code additional information including a source code ID for identifying the target source code, additional content "emphasis", and position information "5 (line) to 13 (line)" is generated. Further, in step S8, the code additional information generated in step S7 is reflected in the target source code displayed in the code display area 201. FIG.

ここで、図12は、上記したステップS3~S8の処理が実行された後の表示画面200の一例を示す。 Here, FIG. 12 shows an example of the display screen 200 after the processes of steps S3 to S8 have been executed.

詳細については省略するが、図12に示すmain関数を表す関数シンボル400は、main関数全体を表現するメインシンボル400a及び当該main関数を構成するコードブロック(if文に相当するコードブロック)を表すサブシンボル400bから構成されている。また、ダイアグラム表示領域202に表示されている関数シンボル400(メインシンボル400a及びサブシンボル400b)は、上記したダイアグラム付加情報に基づいて強調表示されている(例えば、色彩が付されて表示されている)。 Although the details are omitted, the function symbol 400 representing the main function shown in FIG. It is composed of a symbol 400b. Also, the function symbols 400 (main symbol 400a and sub-symbol 400b) displayed in the diagram display area 202 are highlighted (for example, displayed in color) based on the above diagram additional information. ).

また、コード表示領域201においては、main関数の定義が記述された部分が強調表示されている。具体的には、例えば図12に示すコード表示領域201に表示されているmain関数の定義が記述された部分には、強調表示されていることを示すために色彩(例えば、青色等)が付された強調表示線500が付与されている。 Also, in the code display area 201, the part where the definition of the main function is described is highlighted. Specifically, for example, the part where the definition of the main function is described displayed in the code display area 201 shown in FIG. A highlighted highlighting line 500 is provided.

このように本実施形態においては、コード表示領域201において対象ソースコードに含まれる関数を指定することによって、当該関数を表す関数シンボルを含む対象ダイアグラムをダイアグラム表示領域202に表示することができるとともに、コード表示領域201に表示されている当該関数が記述されている部分を強調表示することができる。 As described above, in this embodiment, by specifying a function included in the target source code in the code display area 201, the target diagram including the function symbol representing the function can be displayed in the diagram display area 202. The portion where the function is described displayed in the code display area 201 can be highlighted.

次に、ユーザは、コード表示領域201に表示されているmain関数内に記述されている他の関数を指定する(つまり、当該他の関数に対して関数追加操作を行う)ことができる。図12に示すコード表示領域201においては、例えばmain関数に含まれるtoymodel_exec関数が指定される。 Next, the user can specify another function described in the main function displayed in the code display area 201 (that is, perform a function addition operation on the other function). In the code display area 201 shown in FIG. 12, for example, the toymodel_exec function included in the main function is specified.

図12に示すコード表示領域201においてtoymodel_exec関数が指定された場合、図13に示すように、表示画面200に含まれるコード表示領域201には、当該toymodel_exec関数の定義が記述されている部分が表示される(つまり、コード表示領域201の表示がmain関数からtoymodel_exec関数に遷移する)。なお、図13においては、toymodel_exec関数の一部のみが表示されている。 When the toymodel_exec function is specified in the code display area 201 shown in FIG. 12, the part where the definition of the toymodel_exec function is described is displayed in the code display area 201 included in the display screen 200 as shown in FIG. (that is, the display in the code display area 201 transitions from the main function to the toymodel_exec function). Note that FIG. 13 shows only part of the toymodel_exec function.

ここで、図8に示すステップS3~S6の処理が実行される。この場合におけるステップS3においては、toymodel_exec関数が追加される対象ダイアグラムを識別するためのダイアグラムID、main関数を識別するための関数ID(呼び出し元関数ID)及び当該toymodel exec関数を識別するための関数ID(呼び出し先関数ID)を含むダイアグラム情報が生成される。 Here, the processing of steps S3 to S6 shown in FIG. 8 is executed. In step S3 in this case, the diagram ID for identifying the target diagram to which the toymodel_exec function is added, the function ID (caller function ID) for identifying the main function, and the function for identifying the toymodel exec function Diagram information including an ID (called function ID) is generated.

また、ステップS4においては、ステップS3において生成されたダイアグラム情報に含まれるダイアグラムID、付加内容「強調」及びtoymodel_exec関数を識別するための関数ID(位置情報)を含むダイアグラム付加情報が生成される。 Also, in step S4, additional diagram information is generated that includes the diagram ID, the additional content "emphasis", and the function ID (positional information) for identifying the toymodel_exec function included in the diagram information generated in step S3.

ステップS5においては、ステップS3において生成されたダイアグラム情報及びステップS4において生成されたダイアグラム付加情報に基づいて対象ダイアグラムが生成される。 In step S5, a target diagram is generated based on the diagram information generated in step S3 and the diagram additional information generated in step S4.

なお、この場合におけるステップS5においては、ダイアグラム情報に含まれる呼び出し元関数IDによって識別されるmain関数を表す関数シンボル(以下、main関数シンボルと表記)が生成される。また、ステップS5においては、ダイアグラム情報に含まれる呼び出し先関数IDによって識別されるtoymodel_exec関数を表す関数シンボル(以下、toymodel exec関数シンボルと表記)が生成される。なお、各関数シンボルについては上記した通りであるため、ここではその詳しい説明を省略する。 In this case, in step S5, a function symbol (hereinafter referred to as main function symbol) representing the main function identified by the caller function ID included in the diagram information is generated. Also, in step S5, a function symbol representing the toymodel_exec function identified by the called function ID included in the diagram information (hereinafter referred to as toymodel exec function symbol) is generated. Since each function symbol is as described above, detailed description thereof is omitted here.

更に、ステップS5においては、main関数(呼び出し元関数)とtoymodel_exec関数(呼び出し先関数)との呼び出し関係を表す対象ダイアグラムが生成される。 Furthermore, in step S5, a target diagram is generated that represents the calling relationship between the main function (caller function) and the toymodel_exec function (callee function).

これにより、main関数シンボル及びtoymodel_exec関数シンボルを含み、かつ、main関数とtoymodel_exec関数との呼び出し関係を表す対象ダイアグラムが生成される。 As a result, a target diagram is generated that includes the main function symbol and the toymodel_exec function symbol and expresses the calling relationship between the main function and the toymodel_exec function.

ステップS5において生成された対象ダイアグラムは、ステップS6においてダイアグラム表示領域202に表示される。 The target diagram generated in step S5 is displayed in the diagram display area 202 in step S6.

上記したように図8に示すステップS3~S6の処理が実行された場合、ステップS7及びS8の処理が実行される。この場合におけるステップS7においては、対象ソースコードを識別するためのソースコードID、付加内容「強調」及び位置情報「22(行)~42(行)」を含むコード付加情報が生成される。なお、図13には示されていないが、位置情報「22~42」は、toymodel_exec関数の定義がソースコード中の22行目~42行目に記述されていることを示している。また、ステップS8においては、ステップS7において生成されたコード付加情報がコード表示領域に201に表示されている対象ソースコードに反映される。 As described above, when the processes of steps S3 to S6 shown in FIG. 8 are executed, the processes of steps S7 and S8 are executed. In this case, in step S7, code additional information including a source code ID for identifying the target source code, additional content "emphasis", and position information "22 (line) to 42 (line)" is generated. Although not shown in FIG. 13, the position information "22 to 42" indicates that the definition of the toymodel_exec function is described on the 22nd to 42nd lines in the source code. Also, in step S8, the code additional information generated in step S7 is reflected in the target source code displayed at 201 in the code display area.

ここで、図14は、上記したようにtoymodel_exec関数がユーザによって指定されることによってステップS3~S8の処理が実行された後の表示画面200の一例を示す。 Here, FIG. 14 shows an example of the display screen 200 after the processing of steps S3 to S8 is executed by the user specifying the toymodel_exec function as described above.

図14に示すように、表示画面200に含まれるダイアグラム表示領域202には、main関数シンボル400及びtoymodel_exec関数シンボル600を含む対象ダイアグラムが表示されている。なお、main関数シンボル400は、上記した図12に示すダイアグラム表示領域202に表示されているmain関数シンボル400と同一の関数シンボルである。 As shown in FIG. 14, in the diagram display area 202 included in the display screen 200, a target diagram including the main function symbol 400 and the toymodel_exec function symbol 600 is displayed. The main function symbol 400 is the same function symbol as the main function symbol 400 displayed in the diagram display area 202 shown in FIG. 12 described above.

一方、toymodel_exec関数シンボル600は、toymodel_exec関数全体を表現するメインシンボル600a及び当該toymodel_exec関数を構成するコードブロックの各々を表すサブシンボル600b~600fから構成されている。 On the other hand, the toymodel_exec function symbol 600 is composed of a main symbol 600a representing the entire toymodel_exec function and sub-symbols 600b to 600f representing code blocks constituting the toymodel_exec function.

なお、図14に示すダイアグラム表示領域202に表示されている対象ダイアグラムにおいて、main関数シンボル400(メインシンボル400a及びサブシンボル400b)及びtoymodel_exec関数シンボル600(メインシンボル600a及びサブシンボル600b~600f)は、上記したダイアグラム付加情報に基づいて強調表示されている。 In the target diagram displayed in the diagram display area 202 shown in FIG. 14, the main function symbol 400 (main symbol 400a and sub-symbol 400b) and toymodel_exec function symbol 600 (main symbol 600a and sub-symbols 600b to 600f) are Highlighted based on diagram additional information above.

更に、ダイアグラム表示領域202に表示されている対象ダイアグラムには、main関数シンボルとtoymodel_exec関数シンボルとを接続する呼び出し線(main関数シンボルからtoymodel_exec関数への矢印)700が含まれている。これにより、対象ダイアグラムにおいては、main関数が呼び出し元関数であり、toymodel_exec関数が呼び出し先関数であるという呼び出し関係を表すことができる。 Furthermore, the target diagram displayed in the diagram display area 202 includes a call line (an arrow from the main function symbol to the toymodel_exec function) 700 connecting the main function symbol and the toymodel_exec function symbol. As a result, in the target diagram, it is possible to express a calling relationship in which the main function is the caller function and the toymodel_exec function is the callee function.

ここで、上記した図10及び図12に示すコード表示領域201に表示されているmain関数において、toymodel_exec関数は、当該main関数を構成するif文に相当するコードブロック以外の部分に含まれている。この場合、main関数とtoymodel_exec関数との接続関係を表す呼び出し線700は、図14に示すようにmain関数シンボル400のメインシンボル400a(サブシンボル400bの下)に接続されている。 Here, in the main function displayed in the code display area 201 shown in FIGS. 10 and 12, the toymodel_exec function is included in a portion other than the code block corresponding to the if statement that constitutes the main function. . In this case, a call line 700 representing the connection relationship between the main function and the toymodel_exec function is connected to the main symbol 400a (below the sub-symbol 400b) of the main function symbol 400 as shown in FIG.

すなわち、本実施形態において、呼び出し元関数と呼び出し先関数との呼び出し関係を表す呼び出し線(矢印)は、当該呼び出し元関数内の呼び出し先関数が記述されている位置に対応する位置(メインシンボルまたはサブシンボル)に接続される。例えば呼び出し先関数が呼び出し元関数を構成するコードブロック内に記述されている場合には、当該呼び出し元関数と呼び出し先関数との呼び出し関係を表す呼び出し線は、当該コードブロックを表すサブシンボルに接続される。 That is, in this embodiment, the calling line (arrow) representing the calling relationship between the calling function and the called function is the position (main symbol or sub-symbol). For example, if the callee function is described in a code block that constitutes the caller function, the call line representing the calling relationship between the caller function and the callee function is connected to the sub symbol representing the code block. be done.

ここでは、呼び出し線の呼び出し元関数側の接続について説明したが、呼び出し先関数側において、当該呼び出し線は、例えば図14に示すように呼び出し先関数名等と接続されればよい。 Here, the connection of the calling line on the side of the calling function has been described, but on the side of the called function, the calling line may be connected to the name of the called function, etc., as shown in FIG. 14, for example.

また、ダイアグラム表示領域202に表示される対象ダイアグラムには、インジケータ800が更に含まれていてもよい。このインジケータ800は、コード表示領域201に表示されている対象ソースコードの部分を対象ダイアグラムにおいて表している。換言すれば、コード表示領域201に対象ソースコードの一部分として関数が表示されている場合、インジケータ800は、当該関数を表す関数シンボルを指し示している。 Also, the target diagram displayed in the diagram display area 202 may further include an indicator 800 . This indicator 800 represents the portion of the subject source code displayed in the code display area 201 in the subject diagram. In other words, when a function is displayed as part of the target source code in the code display area 201, the indicator 800 points to the function symbol representing that function.

具体的には、例えば図14に示すように関数シンボル600にインジケータ800が付与されている場合、当該インジケータ800は、当該関数シンボル600によって表される関数の定義が記述されている部分がコード表示領域201に表示されていることを表している。 Specifically, for example, when a function symbol 600 is provided with an indicator 800 as shown in FIG. It represents that it is displayed in the area 201 .

なお、図14においてはインジケータ800が三角形状のマークである例を示しているが、当該インジケータ800は他の形状を有していてもよい。また、インジケータ800は、コード表示領域201に表示されている対象ソースコードの部分を把握することが可能であれば、図形、記号、文字または色彩等で表現されるものであってもよい。 Although FIG. 14 shows an example in which the indicator 800 is a triangular mark, the indicator 800 may have another shape. Also, the indicator 800 may be represented by graphics, symbols, characters, colors, or the like, as long as the portion of the target source code displayed in the code display area 201 can be grasped.

また、コード表示領域201において、toymodel_exec関数の定義が記述された部分は強調表示されている。具体的には、例えば図14に示すコード表示領域201に表示されているtoymodel_exec関数の定義が記述された部分には、強調されていることを示すために色彩が付された強調表示線900が付与されている。 Also, in the code display area 201, the portion where the definition of the toymodel_exec function is described is highlighted. Specifically, for example, in the code display area 201 shown in FIG. 14, the part where the definition of the toymodel_exec function is described has a colored highlighting line 900 to indicate that it is highlighted. Granted.

ここでは、main関数及びtoymodel_exec関数が順次指定された(つまり、main関数及びtoymodel_exec関数がダイアグラムに追加された)場合について説明したが、当該toymodel_exec関数の後に更に他の関数(当該toymodel_exec関数内に記述されている関数)が指定された場合には、上記したステップS3~S8の処理と同様の処理が実行される。このような処理が繰り返されることによって、ユーザによって指定された複数の関数の各々を表す関数シンボル(メインシンボル及びサブシンボル)を含み、かつ、当該複数の関数の間の呼び出し関係を表すダイアグラムをダイアグラム表示領域202に表示することができる。 Here, the case where the main function and the toymodel_exec function are specified in order (that is, the main function and the toymodel_exec function are added to the diagram) has been explained, but another function (described within the toymodel_exec function) is described after the toymodel_exec function. function) is specified, the same processing as the processing of steps S3 to S8 described above is executed. By repeating such processing, a diagram containing function symbols (main symbols and sub-symbols) representing each of a plurality of functions designated by the user and representing calling relationships between the functions is generated. It can be displayed in the display area 202 .

なお、図8に示す処理においては関数が指定される度にステップS3~S8の処理が実行されるものとして説明したが、例えば複数の関数が指定された後にステップS3~S8の処理が実行される構成としてもよい。なお、ステップS3~S8の処理が実行されるタイミングについてはユーザによって指示されればよい。 In the processing shown in FIG. 8, the processing of steps S3 to S8 is executed each time a function is designated, but for example, the processing of steps S3 to S8 is executed after a plurality of functions are designated. It may be configured to be It should be noted that the timing at which the processes of steps S3 to S8 are executed may be instructed by the user.

具体的には、図15に示すように、上記したmain関数が追加されたダイアグラムがダイアグラム表示領域202に表示された後、コード表示領域201においてmain関数内に記述されているtoymodel_exec関数、toymodel_exec関数内に記述されているtoy_call関数、toy_call関数内に記述されているget_flag関数が順次指定されたものとする。なお、ユーザによって指定された関数の各々と当該関数の各々が指定された順番(つまり、途中経路の関数)はコードリーディング支援装置10内で保持(記憶)される。get_flag関数が指定された後に、例えばダイアグラムを表示(生成)する旨がユーザによって指示された場合、図8に示すステップS3~S8の処理が実行される。この場合、ダイアグラム表示領域202においては、toymodel_exec関数、toy_call関数及びget_flag関数の各々を表す関数シンボル(toymodel_exec関数シンボル、toy_call関数シンボル及びget_flag関数シンボル)を含むダイアグラムがダイアグラム表示領域202に表示される。また、このダイアグラムにおいては、toymodel_exec関数を呼び出し元関数、toy_call関数を呼び出し先関数とする呼び出し関係を表す呼び出し線(矢印)が表示される。同様に、このダイアグラムにおいては、toy_call関数を呼び出し元関数、get_flag関数を呼び出し先関数とする呼び出し関係を表す呼び出し線(矢印)が表示される。 Specifically, as shown in FIG. 15, after the diagram to which the main function is added is displayed in the diagram display area 202, the toymodel_exec function and the toymodel_exec function described in the main function are displayed in the code display area 201. It is assumed that the toy_call function described in the above and the get_flag function described in the toy_call function are sequentially specified. Note that each of the functions specified by the user and the order in which each of the functions was specified (that is, the functions of the intermediate path) are held (stored) in the code reading support device 10 . After specifying the get_flag function, for example, when the user instructs to display (generate) a diagram, the processing of steps S3 to S8 shown in FIG. 8 is executed. In this case, the diagram display area 202 displays a diagram including function symbols (toymodel_exec function symbol, toy_call function symbol, and get_flag function symbol) representing each of the toymodel_exec function, toy_call function, and get_flag function. Also, in this diagram, call lines (arrows) are displayed to represent the calling relationship with the toymodel_exec function as the caller function and the toy_call function as the callee function. Similarly, in this diagram, call lines (arrows) are displayed to represent the calling relationship with the toy_call function as the caller function and the get_flag function as the callee function.

本実施形態において、ユーザは、当該ユーザが順次指定した関数を指定することによってダイアグラム表示領域202に表示されるダイアグラムを参照することによって、例えば対象ソースコード(プログラム)に基づくコンピュータの特定の動作(振る舞い)を読解することが可能となる。 In this embodiment, the user refers to the diagram displayed in the diagram display area 202 by designating the functions sequentially designated by the user, for example, a specific operation of the computer based on the target source code (program) ( behavior) can be read.

なお、本実施形態においてはダイアグラム表示領域202にダイアグラムが表示されるものとして説明したが、表示画面200には、当該ダイアグラムを表示する他の領域が配置されていてもよい。具体的には、例えば図16に示すように、ダイアグラムを全体的に表示するための領域(第3表示領域)204が表示画面200に更に配置されていてもよい。この場合、ダイアグラム表示領域202においては、ダイアグラム全体を表示する領域204において指定されたダイアグラムの一部分が拡大して表示されるようにしてもよい。なお、ダイアグラム表示領域202においてダイアグラム全体が表示され、領域204においてダイアグラムの一部分が表示されるようにしてもよい。更に、領域204の表示及び非表示がユーザによって選択可能なように構成されていてもよい。 Although the diagram is displayed in the diagram display area 202 in this embodiment, the display screen 200 may have another area for displaying the diagram. Specifically, for example, as shown in FIG. 16, an area (third display area) 204 for displaying the diagram as a whole may be further arranged on the display screen 200 . In this case, in the diagram display area 202, a portion of the diagram specified in the area 204 for displaying the entire diagram may be enlarged and displayed. Note that the diagram display area 202 may display the entire diagram and the area 204 may display a portion of the diagram. Furthermore, the display or non-display of the area 204 may be configured to be selectable by the user.

また、上記したダイアグラム表示処理において生成されたダイアグラム情報及びダイアグラム付加情報はダイアグラム格納部12に格納される。このため、ダイアグラム格納部12に格納されたダイアグラム情報及びダイアグラム付加情報を上記したファイル選択領域203において指定することによって、コードリーディング装置10を使用してユーザが作成(表示)したダイアグラムを他のユーザが参照(閲覧)するようなことも可能となる。 Also, the diagram information and diagram additional information generated in the above diagram display process are stored in the diagram storage unit 12 . Therefore, by designating the diagram information and diagram additional information stored in the diagram storage unit 12 in the file selection area 203, the diagram created (displayed) by the user using the code reading device 10 can be shared with other users. It is also possible for the user to refer (browse) the

更に、本実施形態においては、ユーザによって指定された関数がダイアグラムに追加されるものとして説明したが、例えば図15に示すようにmain関数がユーザによって指定された場合に、当該main関数内に記述されているtoymodel_exec関数、toymodel_exec関数内に記述されているtoy_call関数、toy_call関数内に記述されているget_flag関数が自動的にダイアグラムに追加される構成とすることも可能である。このような構成の場合、自動的にダイアグラムに追加された関数(つまり、候補)の中からダイアグラムへの追加を承認する関数をユーザが選択するようにしてもよい。 Furthermore, in the present embodiment, the function specified by the user is added to the diagram, but if the main function is specified by the user as shown in FIG. The toymodel_exec function, the toy_call function described in the toymodel_exec function, and the get_flag function described in the toy_call function are automatically added to the diagram. In such a configuration, the user may select a function to be approved for addition to the diagram from among the functions (that is, candidates) automatically added to the diagram.

また、1つの関数内に複数の関数が記述されている場合には、複数の呼び出し線を介して、当該1つの関数(呼び出し元関数)が複数の呼び出し先関数と接続されていてもよい。 Also, when a plurality of functions are described in one function, the one function (caller function) may be connected to a plurality of callee functions via a plurality of call lines.

また、上記したダイアグラム表示処理においては関数指定操作が行われる度に当該関数指定操作において指定された関数を表す関数シンボルを生成するものとして説明したが、対象ソースコードに含まれる関数の各々を表す関数シンボルは、予め生成され、コードリーディング支援装置10内で管理されても構わない。 In addition, in the diagram display process described above, each time a function specification operation is performed, a function symbol representing the function specified in the function specification operation is generated. Function symbols may be generated in advance and managed within the code reading support device 10 .

次に、図17のフローチャートを参照して、コメント付加処理の処理手順の一例について説明する。なお、本実施形態におけるコメント付加処理は、付加内容としてコメントを含む付加情報(コード付加情報及びダイアグラム付加情報)を編集(生成及び削除等)する処理をいう。 Next, an example of the processing procedure of comment addition processing will be described with reference to the flowchart of FIG. 17 . Note that the comment addition processing in the present embodiment refers to processing for editing (creating, deleting, etc.) additional information (code additional information and diagram additional information) including comments as additional content.

ここでは、上記したダイアグラム表示処理が実行されることによって、コード表示領域201には対象ソースコードが表示され、ダイアグラム表示領域202にはユーザによって指定された関数(関数シンボル)が追加された対象ダイアグラムが表示されているものとする。 Here, by executing the diagram display process described above, the target source code is displayed in the code display area 201, and the target diagram to which the function (function symbol) specified by the user is added in the diagram display area 202. shall be displayed.

ここで、本実施形態において、ユーザは、例えばコード表示領域201に表示されている対象ソースコードに対してコメントを付加することができる。なお、対象ソースコードに対するコメントは、コードが記述されている行単位で付加可能である。 Here, in this embodiment, the user can add a comment to the target source code displayed in the code display area 201, for example. A comment for the target source code can be added for each line in which the code is written.

上記したように対象ソースコードに対してコメントを付加する場合、ユーザは、対象ソースコードのコメントを付加すべき部分をコード表示領域201に表示し、コメントを付加する操作(以下、コメント付加操作と表記)を行う。ユーザは、このコメント付加操作を行うことによって、対象ソースコードに対するコメントを付加(追加)することができる。なお、コメント付加操作には、コメントを付加すべき行番号を指定する操作及び当該コメントを作成する操作等が含まれる。 When adding a comment to the target source code as described above, the user displays the portion of the target source code to which the comment should be added in the code display area 201, and performs an operation to add the comment (hereinafter referred to as a comment addition operation). notation). By performing this comment adding operation, the user can add (add) a comment to the target source code. Note that the comment addition operation includes an operation of designating a line number to which a comment should be added, an operation of creating the comment, and the like.

操作受付部15は、上記したコメント付加操作が受け付けられた(ユーザによって行われた)か否かを判定する(ステップS11)。 The operation reception unit 15 determines whether or not the comment addition operation described above has been received (performed by the user) (step S11).

コメント付加操作が受け付けられたと判定された場合(ステップS11のYES)、編集処理部16は、対象ソースコードに付加されるコード付加情報を生成する(ステップS12)。この場合、編集処理部16は、対象ソースコードを識別するためのソースコードID、上記したコメント付加操作においてユーザによって作成されたコメント(付加内容)及び当該コメント付加操作においてユーザによって指定された行番号(位置情報)を含むコード付加情報を生成する。ステップS12において生成されたコード付加情報は、コード格納部11に格納される。 If it is determined that the comment addition operation has been accepted (YES in step S11), the edit processing unit 16 generates code addition information to be added to the target source code (step S12). In this case, the edit processing unit 16 uses the source code ID for identifying the target source code, the comment (additional content) created by the user in the above-described comment addition operation, and the line number specified by the user in the comment addition operation. Generate code additional information including (location information). The code additional information generated in step S<b>12 is stored in the code storage section 11 .

ステップS12の処理が実行されると、コード表示処理部13は、コード格納部11に格納されたコード付加情報を、コード表示領域201に表示されている対象ソースコードに反映する(ステップS13)。上記したコード付加情報によれば、ステップS13の処理が実行されることによって、コード表示領域201に表示されている対象ソースコードのユーザによって指定された部分(行)にコメントが表示(付加)される。 When the process of step S12 is executed, the code display processing unit 13 reflects the code additional information stored in the code storage unit 11 on the target source code displayed in the code display area 201 (step S13). According to the code addition information described above, a comment is displayed (added) to the portion (line) specified by the user of the target source code displayed in the code display area 201 by executing the process of step S13. be.

また、編集処理部16は、ダイアグラム表示領域202に表示されている対象ダイアグラムに付加されるダイアグラム付加情報を生成する(ステップS14)。この場合、編集処理部16は、対象ダイアグラムを識別するためのダイアグラムID、コメント付加操作においてユーザによって作成されたコメント(付加内容)及び当該コメント付加操作においてユーザによって指定された行番号に該当するコードブロック(当該行番号に記述されたコードを含むコードブロック)を識別するためのコードブロックID(位置情報)を含むダイアグラム付加情報を生成する。なお、ユーザによって指定された行番号に該当するコードブロックが存在しない場合には、当該行番号に該当する関数を識別するための関数IDがダイアグラム付加情報に含まれていてもよい。ステップS14において生成されたダイアグラム付加情報は、ダイアグラム格納部12に格納される。 Also, the edit processing unit 16 generates diagram additional information to be added to the target diagram displayed in the diagram display area 202 (step S14). In this case, the edit processing unit 16 uses the diagram ID for identifying the target diagram, the comment (additional content) created by the user in the comment addition operation, and the code corresponding to the line number specified by the user in the comment addition operation. Diagram additional information including a code block ID (positional information) for identifying a block (a code block containing the code written at the line number) is generated. If there is no code block corresponding to the line number specified by the user, the diagram additional information may include a function ID for identifying the function corresponding to the line number. The diagram additional information generated in step S14 is stored in the diagram storage unit 12. FIG.

ステップS14の処理が実行されると、ダイアグラム表示処理部14は、ダイアグラム格納部12に格納されたダイアグラム付加情報を、ダイアグラム表示領域202に表示されている対象ダイアグラムに反映する(ステップS15)。上記したダイアグラム付加情報によれば、ステップS15の処理が実行されることによって、ユーザによって指定された行番号に該当するサブシンボルにコメントが表示(付加)される。なお、上記したように位置情報として関数IDがダイアグラム付加情報に含まれている場合には、当該関数IDによって識別される関数を表す関数シンボル(を構成するメインシンボル)にコメントが付加されてもよい。 When the process of step S14 is executed, the diagram display processing unit 14 reflects the diagram additional information stored in the diagram storage unit 12 on the target diagram displayed in the diagram display area 202 (step S15). According to the diagram additional information described above, a comment is displayed (added) to the sub-symbol corresponding to the line number specified by the user by executing the process of step S15. As described above, when a function ID is included in the diagram additional information as position information, even if a comment is added to the function symbol (the main symbol that constitutes it) representing the function identified by the function ID, good.

上記したコメント付加処理によれば、例えば対象ソースコードに対してコメントが付加(追加)された場合に、対象ダイアグラムの該当箇所に同じコメントを表示することができる。 According to the above-described comment adding process, for example, when a comment is added (added) to the target source code, the same comment can be displayed at the corresponding portion of the target diagram.

なお、ステップS11においてコメント付加操作が受け付けられていないと判定された場合(ステップS11のNO)、コメント付加処理は終了される。 Note that if it is determined in step S11 that the comment addition operation has not been accepted (NO in step S11), the comment addition process ends.

以下、上記したコメント付加処理について具体的に説明する。ここでは、図12に示すようにコード表示領域201に対象ソースコード(main関数が記述されている部分)が表示されており、ダイアグラム表示領域202に対象ダイアグラム(main関数を表す関数シンボル400)が表示されているものとする。 The comment adding process described above will be specifically described below. Here, as shown in FIG. 12, the target source code (the part where the main function is described) is displayed in the code display area 201, and the target diagram (the function symbol 400 representing the main function) is displayed in the diagram display area 202. shall be displayed.

この場合において、例えば対象ソースコードの8行目にコメントを付加する場合を想定する。この場合、ユーザは、入力デバイス106(例えば、マウスまたはキーボード)を用いて、例えば対象ソースコードの8行目にカーソルを合わせ、右クリック操作を行う。なお、この操作が上記したコメントを付加すべき行番号を指定する操作に相当する。 In this case, it is assumed that a comment is added to line 8 of the target source code, for example. In this case, the user uses the input device 106 (eg, mouse or keyboard) to place the cursor on line 8 of the target source code, for example, and right-click. Note that this operation corresponds to the operation of specifying the line number to which the comment should be added.

ここで、上記したように対象ソースコードの8行目にカーソルを合わせて右クリック操作が行われた場合には、図18に示す画面(以下、コメント作成画面と表記)が例えばポップアップ形式等で表示される。 Here, as described above, when the cursor is placed on the eighth line of the target source code and a right-click operation is performed, the screen shown in FIG. Is displayed.

図18に示すように、コメント作成画面1000には、コメント作成領域1000aが設けられている。ユーザは、入力デバイス106を用いて、コメント作成領域1000aにおいてコメントを作成することができる。 As shown in FIG. 18, the comment creating screen 1000 is provided with a comment creating area 1000a. A user can use the input device 106 to create a comment in the comment creation area 1000a.

また、コメント作成画面1000には、「OK」ボタン1000b及び「キャンセル」ボタン1000cが更に設けられている。 The comment creation screen 1000 is further provided with an "OK" button 1000b and a "Cancel" button 1000c.

コメント作成領域1000aにおいてコメントが作成され、ユーザによって「OK」ボタン1000bが押下された場合、コメントの作成が完了する。 When a comment is created in the comment creation area 1000a and the user presses the "OK" button 1000b, the creation of the comment is completed.

一方、ユーザによって「キャンセル」ボタン1000cが押下された場合、コメントの作成がキャンセルされる。 On the other hand, when the user presses the "cancel" button 1000c, the creation of the comment is cancelled.

上記したようにコメント作成画面1000におけるコメントの作成が完了した場合、図17に示すステップS12~S15の処理が実行される。この場合におけるステップS12においては、対象ソースコードを識別するためのソースコードID、コメント作成画面1000においてユーザによって作成されたコメント(付加内容)及び上記したコード表示領域201においてユーザによって指定された「8(行目)」(位置情報)を含むコード付加情報が生成される。 When comment creation on the comment creation screen 1000 is completed as described above, the processes of steps S12 to S15 shown in FIG. 17 are executed. In step S12 in this case, the source code ID for identifying the target source code, the comment (additional content) created by the user on the comment creating screen 1000, and the "8 Code additional information including "(row)" (position information) is generated.

ステップS13においては、ステップS12において生成されたコメント付加情報がコード表示領域201に表示されている対象ソースコードに反映される。 In step S<b>13 , the comment additional information generated in step S<b>12 is reflected in the target source code displayed in the code display area 201 .

一方、ステップS14においては、対象ダイアグラムを識別するためのダイアグラムID、コメント作成画面1000においてユーザによって作成されたコメント(付加内容)及びコード表示領域201においてユーザによって指定された行番号に該当するコードブロックを識別するためのコードブロックID(位置情報)を含むダイアグラム情報が生成される。 On the other hand, in step S14, the diagram ID for identifying the target diagram, the comment (additional content) created by the user on the comment creation screen 1000, and the code block corresponding to the line number specified by the user in the code display area 201 Diagram information including a code block ID (positional information) for identifying is generated.

ステップS15においては、ステップS14において生成されたダイアグラム情報がダイアグラム表示領域202に表示されている対象ダイアグラムに反映される。 In step S15, the diagram information generated in step S14 is reflected in the target diagram displayed in the diagram display area 202. FIG.

ここで、図19は、上記したステップS12~S15の処理が実行された後の表示画面200の一例を示す。 Here, FIG. 19 shows an example of the display screen 200 after the processes of steps S12 to S15 described above are executed.

図19に示すように、コード表示領域201に表示されている対象ソースコードの5行目には、ユーザによって作成されたコメントが付加されている。 As shown in FIG. 19, a comment created by the user is added to the fifth line of the target source code displayed in the code display area 201 .

また、ダイアグラム表示領域202に表示されている対象ダイアグラムに含まれるmain関数シンボル400に含まれるサブシンボル400bには、ユーザによって作成されたコメントが付加されている。 A comment created by the user is added to the sub-symbol 400b included in the main function symbol 400 included in the target diagram displayed in the diagram display area 202. FIG.

このようにコード表示領域201において対象ソースコードのユーザによって指定された位置(行)にコメントが付加された場合には、対象ダイアグラムの該当箇所にも同様のコメントが付加される。 When a comment is added to the position (line) specified by the user in the target source code in the code display area 201 in this way, the same comment is added to the corresponding part of the target diagram.

本実施形態においては、対象ソースコードに対してコメントが付加された場合に対象ダイアグラムに当該コメントが反映されるものとして説明したが、例えば対象ダイアグラムに対してユーザがコメントを付加することも可能である。この場合には、対象ダイアグラムに対して付加されたコメントが対象ソースコードに反映されるものとする。 In the present embodiment, when a comment is added to the target source code, the comment is reflected in the target diagram. However, for example, the user can add a comment to the target diagram. be. In this case, comments added to the target diagram are reflected in the target source code.

なお、対象ダイアグラムに対するコメントは例えば当該対象ダイアグラムを構成するメインシンボルまたはサブシンボルに対して付加することが可能である。これによれば、例えば対象ダイアグラムを構成するメインシンボルに対してコメントが付加された場合には、対象ソースコード中の当該メインシンボル(関数シンボル)によって表される関数が記述されている任意の行等に当該コメントが表示(付加)されればよい。一方、例えば対象ダイアグラムを構成するサブシンボルに対してコメントが付加された場合には、対象ソースコード中の当該サブシンボルによって表されるコードブロックが記述されている任意の行等に当該コメントが表示(付加)されればよい。 A comment for a target diagram can be added to, for example, a main symbol or a sub-symbol that constitutes the target diagram. According to this, for example, when a comment is added to the main symbol that constitutes the target diagram, any line in which the function represented by the main symbol (function symbol) in the target source code is described It is sufficient if the comment is displayed (added) to, for example. On the other hand, for example, when a comment is added to a sub-symbol that constitutes the target diagram, the comment is displayed in any line where the code block represented by the sub-symbol in the target source code is described. (addition) is sufficient.

また、本実施形態においてはコメントが付加される場合について説明したが、当該コメントを削除することも可能である。コメントが削除される場合には、当該コメントを付加内容として含む付加情報(コード付加情報及びダイアグラム付加情報)が削除され、当該付加情報の削除が対象ソースコード及び対象ダイアグラムに反映されればよい。 Moreover, although the case where a comment is added has been described in the present embodiment, it is also possible to delete the comment. When a comment is deleted, the additional information (code additional information and diagram additional information) including the comment as additional content is deleted, and the deletion of the additional information is reflected in the target source code and target diagram.

次に、図20のフローチャートを参照して、強調表示変更処理の処理手順の一例について説明する。なお、本実施形態における強調表示変更処理は、付加内容として強調を含む付加情報(コード付加情報及びダイアグラム付加情報)を編集(生成及び削除等)する処理をいう。 Next, an example of the processing procedure of the highlighting change processing will be described with reference to the flowchart of FIG. 20 . Note that the highlighting change process in this embodiment is a process of editing (creating, deleting, etc.) additional information (code additional information and diagram additional information) including emphasis as additional content.

ここでは、上記したダイアグラム表示処理が実行されることによって、コード表示領域201には対象ソースコードが表示され、ダイアグラム表示領域202にはユーザによって指定された関数(関数シンボル)が追加された対象ダイアグラムが表示されているものとする。 Here, by executing the diagram display process described above, the target source code is displayed in the code display area 201, and the target diagram to which the function (function symbol) specified by the user is added in the diagram display area 202. shall be displayed.

ここで、ユーザは、例えばコード表示領域201に表示されている対象ソースコードに対して強調表示の有無を変更することができる。強調表示の有無は、例えば関数を構成するコードブロック単位で変更することが可能である。 Here, the user can change whether or not to highlight the target source code displayed in the code display area 201, for example. The presence or absence of highlighting can be changed for each code block constituting a function, for example.

なお、上記した図8に示すダイアグラム表示処理等において説明したように、ユーザによって指定された関数が対象ダイアグラムに追加された場合、対象ソースコードの当該関数が記述されている部分及び対象ダイアグラムに含まれる当該関数を表す関数シンボルはそれぞれ強調表示される。このため、ここでは対象ソースコード(の強調表示されている部分)の強調表示を解除する場合について主に説明する。 As described in the diagram display processing and the like shown in FIG. Each function symbol representing that function is highlighted. Therefore, the case of canceling the highlighting of (the highlighted portion of) the target source code will be mainly described here.

上記したように対象ソースコードの強調表示を解除する場合、ユーザは、対象ソースコードの強調表示されている部分をコード表示領域201に表示し、当該強調表示を解除する操作(以下、強調解除操作と表記)を行う。ユーザは、この強調解除操作を行うことによって、対象ソースコードに対する強調表示を解除することができる。なお、強調解除操作には、強調表示を解除するコードブロック(が記述されている行番号)を指定する操作等が含まれる。 When canceling the highlighting of the target source code as described above, the user displays the highlighted portion of the target source code in the code display area 201, and performs an operation to cancel the highlighting (hereinafter referred to as the canceling operation). notation). The user can cancel the highlighting of the target source code by performing this highlighting cancellation operation. Note that the operation for canceling highlighting includes an operation for designating (the line number in which is described) the code block whose highlighting is to be canceled.

操作受付部15は、上記した強調解除操作が受け付けられた(つまり、ユーザによって行われた)か否かを判定する(ステップS21)。 The operation receiving unit 15 determines whether or not the above-described de-emphasizing operation has been received (ie, performed by the user) (step S21).

強調解除操作が受け付けられたと判定された場合(ステップS21のYES)、編集処理部16は、対象ソースコードに付加されるコード付加情報を削除する(ステップS22)。この場合、編集処理部16は、対象ソースコードを識別するためのソースコードID、付加内容「強調」及び強調解除操作においてユーザによって指定されたコードブロックが記述されている行番号(位置情報)を含むコード付加情報をコード格納部11から削除する。 When it is determined that the emphasis canceling operation has been accepted (YES in step S21), the editing processing unit 16 deletes the code addition information added to the target source code (step S22). In this case, the edit processing unit 16 stores the source code ID for identifying the target source code, the additional content "emphasis", and the line number (position information) where the code block specified by the user in the deemphasis operation is described. The included code additional information is deleted from the code storage unit 11 .

ステップS22の処理が実行されると、コード表示処理部13は、当該ステップS22におけるコード付加情報の削除をコード表示領域201に表示されている対象ソースコードに反映する(ステップS23)。上記したコード付加情報の削除によれば、ステップS23の処理が実行されることによって、コード表示領域201に表示されている対象ソースコードのユーザによって指定されたコードブロックの部分の強調表示が解除される。 When the process of step S22 is executed, the code display processing unit 13 reflects the deletion of the code additional information in step S22 on the target source code displayed in the code display area 201 (step S23). According to the deletion of the code additional information described above, by executing the process of step S23, the highlighted display of the portion of the code block specified by the user in the target source code displayed in the code display area 201 is canceled. be.

また、編集処理部16は、ダイアグラム表示領域202に表示されている対象ダイアグラムに付加されるダイアグラム付加情報を削除する(ステップS24)。この場合、編集処理部16は、対象ダイアグラムを識別するためのダイアグラムID、付加内容「強調」及び強調解除操作においてユーザによって指定されたコードブロックを識別するためのコードブロックID(位置情報)を含むダイアグラム付加情報をダイアグラム格納部12から削除する。なお、ユーザによって指定されたコードブロックを識別するためのコードブロックIDは、当該ユーザによって指定されたコードブロックが記述されている行番号及び上記したコード格納部11に格納されているコード解析情報(コードブロック情報)に基づいて特定することができる。 Also, the edit processing unit 16 deletes the diagram additional information added to the target diagram displayed in the diagram display area 202 (step S24). In this case, the edit processing unit 16 includes a diagram ID for identifying the target diagram, a code block ID (position information) for identifying the code block specified by the user in the additional content "emphasis" and the deemphasis operation. The diagram additional information is deleted from the diagram storage unit 12. The code block ID for identifying the code block specified by the user includes the line number where the code block specified by the user is described and the code analysis information ( code block information).

ステップS24の処理が実行されると、ダイアグラム表示処理部14は、当該ステップS24におけるダイアグラム付加情報の削除をダイアグラム表示領域202に表示されている対象ダイアグラムに反映する(ステップS25)。上記したダイアグラム付加情報の削除によれば、ステップS25の処理が実行されることによって、ダイアグラム表示領域202に表示されている対象ダイアグラムのユーザによって指定されたコードブロックを表すサブシンボルの強調表示が解除される。 When the process of step S24 is executed, the diagram display processing unit 14 reflects the deletion of the diagram additional information in step S24 on the target diagram displayed in the diagram display area 202 (step S25). According to the above-described deletion of additional diagram information, the highlighting of the sub-symbol representing the code block specified by the user of the target diagram displayed in the diagram display area 202 is canceled by executing the process of step S25. be done.

上記した強調表示変更処理によれば、例えば対象ソースコード(コードブロック)の強調表示が解除(強調表示の有無が変更)された場合に、対象ダイアグラムの該当箇所(当該コードブロックを表すサブシンボル)の強調表示も同様に解除する(強調表示の有無を変更する)ことができる。 According to the above-described highlighting change processing, for example, when the highlighting of the target source code (code block) is canceled (whether or not highlighting is changed), the corresponding portion of the target diagram (the sub-symbol representing the code block) Similarly, the highlighting of can be canceled (whether or not highlighting can be changed).

なお、ステップS21において強調解除操作が受け付けられていないと判定された場合(ステップS21のNO)、強調表示変更処理は終了される。 Note that if it is determined in step S21 that the highlighting cancellation operation has not been accepted (NO in step S21), the highlighting change process is terminated.

以下、上記した強調表示変更処理について具体的に説明する。ここでは、図12に示すようにコード表示領域201に対象ソースコード(main関数が記述されている部分)が表示されており、ダイアグラム表示領域202に対象ダイアグラム(main関数を表す関数シンボル400)が表示されているものとする。 The highlighting change processing described above will be specifically described below. Here, as shown in FIG. 12, the target source code (the part where the main function is described) is displayed in the code display area 201, and the target diagram (the function symbol 400 representing the main function) is displayed in the diagram display area 202. shall be displayed.

この場合において、例えば対象ソースコードの8行目~10行目に記述されているコードブロックの強調表示を解除する場合を想定する。この場合、ユーザは、入力デバイス106(例えば、マウスまたはキーボード)を用いて、対象ソースコードの8行目~10行目を指定する操作を行う。 In this case, it is assumed that the highlighting of the code block described in the 8th to 10th lines of the target source code is canceled. In this case, the user uses the input device 106 (eg, mouse or keyboard) to perform an operation to specify the eighth to tenth lines of the target source code.

この場合、上記した図20に示すステップS22~S23の処理が実行される。この場合におけるステップS22においては、対象ソースコードを識別するためのソースコードID、付加内容「強調」及びユーザによって選択(指定)された「8(行目)~10(行目)」(位置情報)を含むコード付加情報がコード格納部11から削除される。 In this case, the processes of steps S22 and S23 shown in FIG. 20 are executed. In step S22 in this case, the source code ID for identifying the target source code, the additional content "emphasis", and "8 (line) to 10 (line)" selected (designated) by the user (position information ) is deleted from the code storage unit 11 .

具体的には、ステップS22の処理が実行される前には、対象ソースコードを識別するためのソースコードID、付加内容「強調」及び位置情報「5(行目)~13(行目)」を含むコード付加情報がコード格納部11に格納されている。このため、上記したコード付加情報がコード格納部11から削除された場合には、コード格納部11には、対象ソースコードを識別するためのソースコードID、付加内容「強調」及び位置情報「5(行目)~7(行目)」を含むコード付加情報と、対象ソースコードを識別するためのソースコードID、付加内容「強調」及び位置情報「11(行目)~13(行目)」を含むコード付加情報とが格納された状態となる。 Specifically, before the process of step S22 is executed, the source code ID for identifying the target source code, the additional content "emphasis", and the position information "5 (line) to 13 (line)" is stored in the code storage unit 11. Therefore, when the code additional information described above is deleted from the code storage unit 11, the code storage unit 11 stores the source code ID for identifying the target source code, the additional content "emphasis", and the position information "5". Code additional information including (line) to 7 (line)", source code ID for identifying the target source code, additional content "emphasis" and position information "11 (line) to 13 (line) ” is stored.

ステップS23においては、ステップS22におけるコメント付加情報の削除がコード表示領域201に表示されている対象ソースコードに反映される。 In step S23, the deletion of the comment additional information in step S22 is reflected in the target source code displayed in the code display area 201. FIG.

一方、ステップS24においては、対象ダイアグラムを識別するためのダイアグラムID、付加内容「強調」及びユーザによって選択された8行目~10行目に記述されているコードブロックを識別するためのコードブロックID(位置情報)を含むダイアグラム情報がダイアグラム格納部12から削除される。 On the other hand, in step S24, the diagram ID for identifying the target diagram, the additional content "emphasis", and the code block ID for identifying the code block described on the 8th to 10th lines selected by the user. The diagram information including (position information) is deleted from the diagram storage unit 12 .

ステップS25においては、ステップS24におけるダイアグラム付加情報の削除がダイアグラム表示領域202に表示されている対象ダイアグラムに反映される。 In step S25, the deletion of the diagram additional information in step S24 is reflected in the target diagram displayed in the diagram display area 202. FIG.

ここで、図21は、上記したステップS22~S25の処理が実行された後の表示画面200の一例を示す。 Here, FIG. 21 shows an example of the display screen 200 after the processes of steps S22 to S25 described above are executed.

図21に示すように、コード表示領域201に表示されている対象ソースコードの8行目~10行目においては、強調表示されていることを示す強調表示線500が削除されている(つまり、強調表示が解除されている)。 As shown in FIG. 21, in the 8th to 10th lines of the target source code displayed in the code display area 201, the highlighting line 500 indicating that it is highlighted is deleted (that is, unhighlighted).

また、ダイアグラム表示領域202に表示されている対象ダイアグラムに含まれるmain関数シンボル400に含まれるサブシンボル400bには、強調表示されていることを示す色彩が付されていない(つまり、強調表示が解除されている)。 Also, the sub-symbol 400b included in the main function symbol 400 included in the target diagram displayed in the diagram display area 202 is not colored to indicate that it is highlighted (that is, the highlighting is canceled). is being used).

このように本実施形態においては、対象ソースコードのユーザによって指定(選択)された位置の強調表示が解除された場合には、対象ダイアグラムの該当箇所の強調表示も同様に解除される。 As described above, in this embodiment, when the highlighting of the position specified (selected) by the user in the target source code is released, the highlighting of the corresponding portion of the target diagram is also released.

なお、ここでは便宜的に対象ソースコードの8行目~10行目の強調表示が解除される場合について説明したが、一般的には所定の振る舞いにおいて動作しない箇所の強調表示等がユーザの操作に応じて解除される。 Here, for the sake of convenience, the case where the highlighting of the 8th to 10th lines of the target source code is canceled has been described, but in general, the highlighting of the part that does not work in the predetermined behavior is not performed by the user's operation. be released accordingly.

本実施形態においては強調表示が解除される場合について主に説明したが、例えば対象ソースコードに対して強調表示が設定された場合に、当該強調表示の設定が対象ダイアグラムに反映される構成であってもよい。この場合には、付加内容として強調表示を含む付加情報(コード付加情報及びダイアグラム付加情報)が生成され、当該付加情報が対象ソースコード及び対象ダイアグラムに反映されればよい。 In the present embodiment, the case where the highlighting is canceled has been mainly described. may In this case, additional information (code additional information and diagram additional information) including highlighting as additional content may be generated, and the additional information should be reflected in the target source code and target diagram.

また、本実施形態においては対象ソースコードに対する強調表示の有無が変更された場合に当該強調表示の有無の変更が対象ダイアグラムに反映されるものとして説明したが、例えば対象ダイアグラムに対する強調表示の有無が変更された場合に当該強調表示の有無の変更が対象ソースコードに反映される構成としてもよい。 Further, in the present embodiment, when the presence/absence of highlighting for the target source code is changed, the change in the presence/absence of highlighting is reflected in the target diagram. A configuration may be adopted in which, when a change is made, the change in the presence or absence of the highlighting is reflected in the target source code.

上記したように本実施形態においては、ソースコードを表示するコード表示領域201(第1表示領域)及びソースコードの少なくとも一部を表すダイアグラムを表示するダイアグラム表示領域202(第2表示領域)が配置された画面を表示し、当該ダイアグラム表示領域202に表示されているダイアグラムを編集(作成)する。なお、本実施形態においては、コード表示領域201に表示されたソースコードに含まれる複数の関数のうちユーザによって指定された関数(を表す関数シンボル)をダイアグラムに追加することができる。 As described above, in this embodiment, a code display area 201 (first display area) for displaying source code and a diagram display area 202 (second display area) for displaying a diagram representing at least part of the source code are arranged. The displayed screen is displayed, and the diagram displayed in the diagram display area 202 is edited (created). Note that, in the present embodiment, a function (a function symbol representing it) designated by the user among a plurality of functions included in the source code displayed in the code display area 201 can be added to the diagram.

一般的なコードリーディングを支援するツールにおいては例えばユーザ(開発者)が図示したくない要素が表示されてしまう等、当該ユーザの意図を反映することが困難であるのに対して、本実施形態においては、上記した構成により、ユーザの意図するダイアグラムを作成及び表示することができるため、コードリーディングを適切に支援することが可能となる。 In general tools for supporting code reading, it is difficult to reflect the user's intentions, for example, elements that the user (developer) does not want to be shown are displayed. With the configuration described above, it is possible to create and display a diagram intended by the user, so that it is possible to appropriately assist code reading.

また、本実施形態において、コード表示領域201に表示されたソースコードのユーザによって指定された関数が記述されている部分は強調表示される。このような構成によれば、ユーザは、ソースコードに含まれる複数の関数のうち、ダイアグラムに追加された関数を容易に判別することができる。 In addition, in the present embodiment, the portion of the source code displayed in the code display area 201 where the function specified by the user is described is highlighted. According to such a configuration, the user can easily identify the function added to the diagram among the multiple functions included in the source code.

更に、本実施形態において、上記した関数シンボルはユーザによって指定された関数を構成するコードブロックを表すサブシンボルを含む。また、関数シンボルに含まれるサブシンボルの位置は、関数シンボルによって表される関数内に記述されている当該サブシンボルによって表されるコードブロックの位置に基づいている。このような構成によれば、ユーザは、当該ユーザによって指定された関数を構成するコードブロックの位置関係等をダイアグラムにおいて容易に把握することが可能となる。 Further, in this embodiment, the function symbols described above include sub-symbols representing code blocks that make up the function specified by the user. Also, the position of a sub-symbol included in a function symbol is based on the position of the code block represented by the sub-symbol described within the function represented by the function symbol. According to such a configuration, the user can easily grasp the positional relationship and the like of the code blocks forming the function specified by the user in the diagram.

更に、本実施形態においては、例えば第1関数が指定された場合に当該第1関数を表す第1関数シンボルがダイアグラムに追加され、当該第1関数に含まれる第2関数が指定された場合に当該第2関数を表す第2関数シンボルがダイアグラムに追加される。また、第2関数が指定された場合には、ソースコードの当該第2関数が記述されている部分がコード表示領域201に表示される。本実施形態においては、このような構成により、各関数内に記述されている関数(つまり、呼び出し先関数)をコード表示領域201において順次指定することができる。 Furthermore, in this embodiment, for example, when a first function is specified, a first function symbol representing the first function is added to the diagram, and when a second function included in the first function is specified, A second function symbol representing the second function is added to the diagram. Also, when the second function is specified, the portion of the source code where the second function is described is displayed in the code display area 201 . In this embodiment, with such a configuration, functions described in each function (that is, callee functions) can be sequentially specified in the code display area 201 .

また、本実施形態において、ダイアグラムは、上記した第1関数と第2関数との間の呼び出し関係を表す。具体的には、第1関数と第2関数との間の呼び出し関係は、第1関数シンボルと第2関数シンボルとを接続する呼び出し線(矢印)によって表すことができる。本実施形態においては、このような構成により、ユーザは、ダイアグラムにおいて複数の関数の間の呼び出し関係を容易に把握することが可能となる。 Also, in this embodiment, the diagram represents the calling relationship between the first function and the second function described above. Specifically, the calling relationship between the first function and the second function can be represented by a call line (arrow) connecting the first function symbol and the second function symbol. In this embodiment, such a configuration allows the user to easily grasp the calling relationship between a plurality of functions in the diagram.

更に、本実施形態において、第1関数と第2関数との間の呼び出し関係を表す呼び出し線は、第1関数を構成するコードブロックのうち第2関数が記述されているコードブロックを表すサブシンボルと第2関数シンボルとを接続する。このような構成によれば、ダイアグラムにおいて、第1関数において第2関数が記述されている位置(コードブロック)を容易に把握することが可能となる。 Furthermore, in the present embodiment, the calling line representing the calling relationship between the first function and the second function is a sub-symbol representing the code block in which the second function is described among the code blocks constituting the first function. and the second function symbol. With such a configuration, it is possible to easily grasp the position (code block) where the second function is described in the first function in the diagram.

なお、本実施形態においてコード表示領域201にはソースコードの一部分のみが表示されるが、ダイアグラムは、ソースコードに含まれる関数がコード表示領域201に表示されている場合に当該ダイアグラムに追加されている当該関数を表す関数シンボルを指し示すインジケータを含む。このようなインジケータによれば、コード表示領域201に表示されている内容に対応するダイアグラムの該当箇所(関数シンボル等)を容易に把握することが可能となる。 In this embodiment, only part of the source code is displayed in the code display area 201, but a diagram is added to the diagram when functions included in the source code are displayed in the code display area 201. contains an indicator pointing to the function symbol representing the function in question. With such an indicator, it is possible to easily grasp the relevant portion (function symbol, etc.) of the diagram corresponding to the content displayed in the code display area 201 .

また、本実施形態においては、表示画面200にはダイアグラムを全体的に表示する領域204が更に配置されていてもよい。この場合、ダイアグラム表示領域202には、例えばユーザによって指定されたダイアグラムの一部が拡大して表示される。このような構成によれば、ダイアグラムの細部を容易に確認することができる。 Further, in this embodiment, the display screen 200 may further include an area 204 for displaying the diagram as a whole. In this case, the diagram display area 202 displays, for example, an enlarged portion of the diagram specified by the user. With such a configuration, it is possible to easily confirm the details of the diagram.

更に、本実施形態においては、コード表示領域201に表示されたソースコードに対するコメントが作成された場合に、当該コメントをダイアグラム表示領域202に表示されているダイアグラムにも反映する。同様に、ダイアグラム表示領域202に表示されたダイアグラムに対するコメントが作成された場合に、当該コメントをコード表示領域201に表示されているソースコードにも反映する。本実施形態においては、このような構成により、例えばソースコード及びダイアグラムの一方に対して付加されたコメントであっても、当該コメントをソースコード及びダイアグラムの両方で確認することが可能となる。 Furthermore, in this embodiment, when a comment is created for the source code displayed in the code display area 201 , the comment is also reflected in the diagram displayed in the diagram display area 202 . Similarly, when a comment is created for the diagram displayed in the diagram display area 202 , the comment is also reflected in the source code displayed in the code display area 201 . In this embodiment, with such a configuration, for example, even if a comment is added to either the source code or the diagram, it is possible to check the comment in both the source code and the diagram.

また、本実施形態においては、コード表示領域201に表示されたソースコードに対する強調表示の有無が変更された場合に、当該強調表示の有無の変更をダイアグラム表示領域202に表示されているダイアグラムにも反映する。同様に、ダイアグラム表示領域202に表示されたダイアグラムに対する強調表示の有無が変更された場合に、当該強調表示の有無の変更をコード表示領域201に表示されているソースコードにも反映する。本実施形態においては、このような構成により、例えばソースコード及びダイアグラムの一方において強調表示の有無が変更された場合であっても、当該変更内容をソースコード及びダイアグラムの両方で確認することが可能となる。 In addition, in this embodiment, when the presence or absence of highlighting for the source code displayed in the code display area 201 is changed, the change in the presence or absence of highlighting is also applied to the diagram displayed in the diagram display area 202. reflect. Similarly, when the presence/absence of highlighting for the diagram displayed in the diagram display area 202 is changed, the change in the presence/absence of highlighting is also reflected in the source code displayed in the code display area 201.例文帳に追加In this embodiment, with such a configuration, for example, even if the presence or absence of highlighting is changed in either the source code or the diagram, it is possible to confirm the change in both the source code and the diagram. becomes.

すなわち、本実施形態においては、ソースコードのビューア(エディタ)としての機能とダイアグラムのエディタとしての機能とが連携して動作することによって、ユーザの利便性を向上させることができる。 That is, in the present embodiment, the function as a source code viewer (editor) and the function as a diagram editor operate in cooperation with each other, thereby improving convenience for the user.

なお、上記した本実施形態に係るコードリーディング装置10は、例えばレガシーコードと称される仕様が不明なソフトウェアを運用及び保守する際に利用することができる。具体的には、このようなソフトウェア(ソースコード)の内容を理解すること(コードリーディング)は困難である場合が多いが、本実施形態に係るコードリーディング装置10を利用し、ユーザの意図が反映されたダイアグラムを参照して特定の動作(振る舞い)を確認することによって、当該コードリーディングの困難性を緩和することが可能となる。 Note that the code reading device 10 according to the present embodiment described above can be used, for example, when operating and maintaining software whose specifications are unknown, which is called legacy code. Specifically, it is often difficult to understand (code reading) the contents of such software (source code), but the code reading device 10 according to the present embodiment can be used to reflect the user's intentions. By checking the specific operation (behavior) with reference to the diagram, it is possible to ease the difficulty of reading the code.

なお、本実施形態においては、コードリーディング支援装置10がコード格納部11及びダイアグラム格納部12を含むものとして説明したが、当該コード格納部11(に格納されているコード解析情報及びコード付加情報)及びダイアグラム格納部12(に格納されているダイアグラム情報及びダイアグラム付加情報)の少なくとも一部がコードリーディング支援装置10とは異なる外部装置で管理されていてもよい。このような構成の場合には、コード格納部11またはダイアグラム格納部12に格納されている情報が必要に応じて外部装置から受信されればよい。 In the present embodiment, the chord reading support device 10 has been described as including the chord storage unit 11 and the diagram storage unit 12, but the code storage unit 11 (the chord analysis information and the chord additional information stored therein) And at least a part of (the diagram information and diagram additional information stored in) the diagram storage unit 12 may be managed by an external device different from the chord reading support device 10 . In such a configuration, the information stored in the code storage section 11 or the diagram storage section 12 may be received from an external device as needed.

本発明のいくつかの実施形態を説明したが、これらの実施形態は、例として提示したものであり、発明の範囲を限定することは意図していない。これら実施形態は、その他の様々な形態で実施されることが可能であり、発明の要旨を逸脱しない範囲で、種々の省略、置き換え、変更を行うことができる。これら実施形態やその変形は、発明の範囲や要旨に含まれると同様に、特許請求の範囲に記載された発明とその均等の範囲に含まれるものである。 While several embodiments of the invention have been described, these embodiments have been presented by way of example and are not intended to limit the scope of the invention. These embodiments can be implemented in various other forms, and various omissions, replacements, and modifications can be made without departing from the scope of the invention. These embodiments and their modifications are included in the scope and spirit of the invention, as well as the scope of the invention described in the claims and equivalents thereof.

10…コードリーディング支援装置(電子計算機)、11…コード格納部、12…ダイアグラム格納部、13…コード表示処理部、14…ダイアグラム表示処理部、15…操作受付部、16…編集処理部、101…CPU、102…不揮発性メモリ、103…主メモリ、104…BIOS-ROM、105…システムコントローラ、106…入力デバイス、107…表示デバイス、108…EC。 DESCRIPTION OF SYMBOLS 10... Chord reading assistance apparatus (electronic computer), 11... Code storage part, 12... Diagram storage part, 13... Chord display processing part, 14... Diagram display processing part, 15... Operation reception part, 16... Editing process part, 101 CPU 102 Non-volatile memory 103 Main memory 104 BIOS-ROM 105 System controller 106 Input device 107 Display device 108 EC.

Claims (10)

ソースコードを表示する第1領域及び前記ソースコードの少なくとも一部を表すダイアグラムを表示する第2領域が配置された画面を表示する表示処理手段と、
前記第2領域に表示されているダイアグラムを編集する編集処理手段と
を具備し、
前記ソースコードには、複数の関数が記述されており、
前記編集処理手段は、前記第1領域に表示されているソースコードに記述されている少なくとも1つの関数が電子計算機を使用するユーザによって指定された場合に、当該関数を表す関数シンボルを前記第2領域に表示されているダイアグラムに追加し、
前記表示処理手段は、
前記第1領域に表示されているソースコード中の前記ユーザによって指定された位置に第1コメントが作成された場合、前記第2領域に表示されている関数シンボルのうちの当該ソースコード中の当該ユーザによって指定された位置に記述されている関数を表す関数シンボルに前記第1コメントを付加して表示し、
前記第2領域に表示された関数シンボルのうちの前記ユーザによって指定された関数シンボルに第2コメントが作成された場合、前記第1領域に表示されているソースコード中の当該関数シンボルによって表される関数が記述されている位置に前記第2コメントを付加して表示する
電子計算機。
display processing means for displaying a screen on which a first area displaying a source code and a second area displaying a diagram representing at least part of the source code are arranged;
and editing processing means for editing the diagram displayed in the second area,
A plurality of functions are described in the source code,
When at least one function described in the source code displayed in the first area is designated by a user using a computer, the editing processing means converts the function symbol representing the function into the second area. Add to the diagram displayed in the area,
The display processing means is
When the first comment is created at the position specified by the user in the source code displayed in the first area, the corresponding function symbol in the source code displayed in the second area. adding and displaying the first comment to a function symbol representing a function written at a position specified by a user;
When a second comment is created for a function symbol specified by the user among the function symbols displayed in the second area, the function symbol in the source code displayed in the first area indicates the second comment. A computer that adds and displays the second comment at the position where the function is described.
前記第1領域に表示されたソースコードの前記ユーザによって指定された関数が記述されている部分は、強調表示される請求項1記載の電子計算機。 2. The computer according to claim 1, wherein a portion of the source code displayed in the first area where the function specified by the user is described is highlighted. 前記複数の関数の各々は、少なくとも1つのコードブロックから構成され、
前記関数シンボルは、前記ユーザによって指定された関数を構成するコードブロックを表すサブシンボルを含む
請求項1記載の電子計算機。
each of the plurality of functions is composed of at least one code block;
2. The electronic computer according to claim 1, wherein said function symbols include sub-symbols representing code blocks forming a function specified by said user.
前記関数シンボルに含まれるサブシンボルの位置は、当該関数シンボルによって表される関数内に記述されている当該サブシンボルによって表されるコードブロックの位置に基づいている請求項3記載の電子計算機。 4. The computer according to claim 3, wherein the position of a sub-symbol included in said function symbol is based on the position of a code block represented by said sub-symbol described in the function represented by said function symbol. 前記第1領域には、前記ソースコードの一部分が表示され、
前記ダイアグラムは、前記ソースコードに記述されている関数が前記第1領域に表示されている場合に当該ダイアグラムに追加されている当該関数を表す関数シンボルを指し示すインジケータを含む
請求項1記載の電子計算機。
a portion of the source code is displayed in the first area;
2. The computer according to claim 1, wherein said diagram includes an indicator pointing to a function symbol representing a function added to said diagram when said function described in said source code is displayed in said first area. .
前記画面には、前記ダイアグラムを全体的に表示する第3領域が更に配置され、
前記第2領域には、前記ダイアグラムの一部が拡大して表示される
請求項1記載の電子計算機。
The screen further includes a third area for displaying the diagram as a whole,
2. The computer according to claim 1, wherein a part of said diagram is enlarged and displayed in said second area.
前記編集処理手段は、前記第1領域に表示されたソースコードに対する強調表示の有無が変更された場合に、当該強調表示の有無の変更を前記第2領域に表示されているダイアグラムに反映する請求項1記載の電子計算機。 wherein, when the presence/absence of highlighting for the source code displayed in the first area is changed, the editing processing means reflects the change in the presence/absence of highlighting in the diagram displayed in the second area. Item 1. The electronic computer according to item 1. 前記編集処理手段は、前記第2領域に表示されたダイアグラムに対する強調表示の有無が変更された場合に、当該強調表示の有無の変更を前記第1領域に表示されているソースコードに反映する請求項1記載の電子計算機。 wherein, when the presence or absence of highlighting for the diagram displayed in the second area is changed, the editing processing means reflects the change in the presence or absence of highlighting in the source code displayed in the first area. Item 1. The electronic computer according to item 1. 電子計算機が実行する方法であって、
ソースコードを表示する第1領域及び前記ソースコードの少なくとも一部を表すダイアグラムを表示する第2領域が配置された画面を表示するステップと、
前記第2領域に表示されているダイアグラムを編集するステップと
を具備し、
前記ソースコードには、複数の関数が記述されており、
前記編集するステップは、前記第1領域に表示されているソースコードに記述されている少なくとも1つの関数が電子計算機を使用するユーザによって指定された場合に、当該関数を表す関数シンボルを前記第2領域に表示されているダイアグラムに追加するステップを含み、
前記表示するステップは、
前記第1領域に表示されているソースコード中の前記ユーザによって指定された位置に第1コメントが作成された場合、前記第2領域に表示されている関数シンボルのうちの当該ソースコード中の当該ユーザによって指定された位置に記述されている関数を表す関数シンボルに前記第1コメントを付加して表示するステップと、
前記第2領域に表示された関数シンボルのうちの前記ユーザによって指定された関数シンボルに第2コメントが作成された場合、前記第1領域に表示されているソースコード中の当該関数シンボルによって表される関数が記述されている位置に前記第2コメントを付加して表示するステップと
を含む
方法。
A computer-implemented method comprising:
displaying a screen on which a first area displaying source code and a second area displaying a diagram representing at least part of the source code are arranged;
and editing the diagram displayed in the second area;
A plurality of functions are described in the source code,
In the editing step, when at least one function described in the source code displayed in the first area is designated by a user using a computer, the function symbol representing the function is changed to the second function. including steps to add to the diagram displayed in the area,
The displaying step includes:
When the first comment is created at the position specified by the user in the source code displayed in the first area, the corresponding function symbol in the source code displayed in the second area. adding and displaying the first comment to a function symbol representing a function written at a position specified by a user;
When a second comment is created for a function symbol specified by the user among the function symbols displayed in the second area, the function symbol in the source code displayed in the first area indicates the second comment. a step of adding and displaying the second comment at a position where the function is described.
電子計算機のコンピュータによって実行されるプログラムであって、
前記コンピュータに、
ソースコードを表示する第1領域及び前記ソースコードの少なくとも一部を表すダイアグラムを表示する第2領域が配置された画面を表示するステップと、
前記第2領域に表示されているダイアグラムを編集するステップと
を実行させ、
前記ソースコードには、複数の関数が記述されており、
前記編集するステップは、前記第1領域に表示されているソースコードに記述されている少なくとも1つの関数が電子計算機を使用するユーザによって指定された場合に、当該関数を表す関数シンボルを前記第2領域に表示されているダイアグラムに追加するステップを含み、
前記表示するステップは、
前記第1領域に表示されているソースコード中の前記ユーザによって指定された位置に第1コメントが作成された場合、前記第2領域に表示されている関数シンボルのうちの当該ソースコード中の当該ユーザによって指定された位置に記述されている関数を表す関数シンボルに前記第1コメントを付加して表示するステップと、
前記第2領域に表示された関数シンボルのうちの前記ユーザによって指定された関数シンボルに第2コメントが作成された場合、前記第1領域に表示されているソースコード中の当該関数シンボルによって表される関数が記述されている位置に前記第2コメントを付加して表示するステップと
を含む
プログラム。
A program executed by a computer of an electronic calculator,
to the computer;
displaying a screen on which a first area displaying source code and a second area displaying a diagram representing at least part of the source code are arranged;
performing a step of editing the diagram displayed in the second area;
A plurality of functions are described in the source code,
In the editing step, when at least one function described in the source code displayed in the first area is designated by a user using a computer, the function symbol representing the function is changed to the second function. including steps to add to the diagram displayed in the area,
The displaying step includes:
When the first comment is created at the position specified by the user in the source code displayed in the first area, the corresponding function symbol in the source code displayed in the second area. adding and displaying the first comment to a function symbol representing a function written at a position specified by a user;
When a second comment is created for a function symbol specified by the user among the function symbols displayed in the second area, the function symbol in the source code displayed in the first area indicates the second comment. a step of adding the second comment to the position where the function is described and displaying it.
JP2022109585A 2018-12-07 2022-07-07 Electronic computer, method and program Active JP7322255B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2022109585A JP7322255B2 (en) 2018-12-07 2022-07-07 Electronic computer, method and program

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2018229591A JP7105683B2 (en) 2018-12-07 2018-12-07 Electronic computer, method and program
JP2022109585A JP7322255B2 (en) 2018-12-07 2022-07-07 Electronic computer, method and program

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2018229591A Division JP7105683B2 (en) 2018-12-07 2018-12-07 Electronic computer, method and program

Publications (2)

Publication Number Publication Date
JP2022125274A JP2022125274A (en) 2022-08-26
JP7322255B2 true JP7322255B2 (en) 2023-08-07

Family

ID=87519616

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2022109585A Active JP7322255B2 (en) 2018-12-07 2022-07-07 Electronic computer, method and program

Country Status (1)

Country Link
JP (1) JP7322255B2 (en)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006277206A (en) 2005-03-29 2006-10-12 Nec Corp Source analysis support method and device, and source analysis support program
US20160054981A1 (en) 2013-05-14 2016-02-25 Microsoft Corporation Programming interface

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3299259B2 (en) * 1990-05-15 2002-07-08 富士通株式会社 Program structure diagram editing processing method
JPH08339208A (en) * 1995-06-09 1996-12-24 Mitsubishi Electric Corp Program preparation device for programmable controller

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006277206A (en) 2005-03-29 2006-10-12 Nec Corp Source analysis support method and device, and source analysis support program
US20160054981A1 (en) 2013-05-14 2016-02-25 Microsoft Corporation Programming interface

Also Published As

Publication number Publication date
JP2022125274A (en) 2022-08-26

Similar Documents

Publication Publication Date Title
US9524279B2 (en) Help document animated visualization
US20100251155A1 (en) Placeholder activities and in-lining of code editors in workflow designer
CN108027721B (en) Techniques for configuring a general program using controls
KR20110127686A (en) Rich web site authoring and design
US20080015911A1 (en) Methods and apparatuses for developing business solutions
US10635855B1 (en) Code comment markup
US9684738B2 (en) Text-based command generation
WO2011099073A1 (en) Computer system and user operation support method using computer
WO2018193503A1 (en) Program creation device
JP7105683B2 (en) Electronic computer, method and program
JP7322255B2 (en) Electronic computer, method and program
JP2010108055A (en) Program for program generation and program generation device
JP2012118933A (en) Screen design evaluation device, screen design evaluation method and program
JP6576608B1 (en) Drawing support device, display device, drawing support method, and computer program
CN118647968A (en) User behavior-based help recommendation for controlling execution of industrial software programs
JP7247593B2 (en) Generation device, software robot system, generation method and generation program
JP2009169628A (en) Construction device, construction method and program for monitoring control system
JP5954309B2 (en) Program generation support apparatus, program generation support method, and program
KR102588597B1 (en) Method for designing a program using operation logic designer as an alternative editor for uml sequence diagram and apparatus using the same
JP7421137B2 (en) Information processing device, information processing method and program
JPH0954688A (en) Gui design supporting method
JP4127318B2 (en) Program generation method and apparatus
KR102076552B1 (en) Apparatus for registering and performing macro, macro registration method
JP2010250826A (en) Device and method for setting workflow
JP2008257318A (en) Character input device, method and program

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20220707

TRDD Decision of grant or rejection written
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20230621

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20230627

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20230726

R151 Written notification of patent or utility model registration

Ref document number: 7322255

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R151