This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2012-289101, filed on Dec. 28, 2012, the entire contents of which are incorporated herein by reference.
The embodiments discussed herein are directed to a file management program, a file management apparatus, and a file management method.
In product design and development, various documents, such as specification documents, design documents, or test specification documents, generated through design and development processes are managed. Examples of the product include a control system and an embedded system in the automobile industry, the electronics/precision industry, or the like. Therefore, in the product design and development, in some cases, a file management apparatus manages a large number of documents.
The file management apparatus can store information on association between files through a file association process performed by an operator. In this configuration, when one of the files is modified, the file management apparatus can search for a file influenced by the modification.
However, the file management apparatus associates the files on a file-by-file basis. Therefore, it is difficult to specify what portion of a file is to be influenced by a modification.
Therefore, the operator determines a portion to be influenced in the entire file by referring to descriptions in the file. Consequently, if the amount of the descriptions is large, it takes more effort and time to specify an area to be influenced.
According to an aspect of the present invention, non-transitory computer-readable recording medium having stored therein a file management program for causing a computer to execute a process, the process includes extracting, upon receiving a search request for an area to be influenced by a first portion of a file in a first table format, information for specifying a second portion of a file in a second table format associated with information for specifying the first portion, by referring to a storage unit containing an association relationship between the information for specifying the first portion and the information for specifying the second portion; and outputting the information for specifying the second portion and information for specifying the file in the second table format containing the second portion, as a reply to the search request.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
Preferred embodiments of the present invention will be explained with reference to accompanying drawings. The present invention is not limited to the embodiments below. The embodiments may be combined appropriately as long as the processes do not conflict with one another.
A system according to a first embodiment will be explained.
The terminal devices 12 are computers used by developers who perform development. The terminal devices 12 are, for example, information processing apparatuses such as desktop personal computers (PC), tablet PCs, or notebook PCs. A developer generates various documents by the terminal devices 12 during the development. For example, the developer generates various documents, such as a functional requirement document for describing requirements for functions needed for the development, a functional design document for designing each of the functions, and a test specification document for testing whether each of the functions is realized, according to each stage of the development. In the documents generated through the development as described above, contents to be described, written portions, styles, and the like are determined for each of specific categories, such as a document type, a development timing, and a development agent, to unify a description format. By unifying the description format for each type of a document, all of the documents of the same type can contain the same items; therefore, it becomes possible to prevent omission of an item that needs to be described. Furthermore, by unifying the description format for each type of a document, it becomes possible to promptly refer to a target written portion when checking the contents of the documents of the same type; therefore, it becomes possible to easily check the contents. The developer generates the documents according to document formats by using software that enables to generate a document in a table format. Examples of the software that enables to generate a document in a table format include spreadsheet software such as Microsoft Excel (registered trademark). Incidentally, the development includes not only software development but also hardware development. For example, in the development of an automobile, hardware development and software development are performed in order to realize needed functions. Furthermore, each of the documents may be generated by using a document of related development. For example, in the development of an automobile, if a new car model is developed by using or modifying a certain component of an already-developed car model, a document of the new car model is generated by using a document of the component of the already-developed car model.
The file management apparatus 11 manages a file of a document. The file management apparatus 11 is, for example, a computer such as a server computer. The file management apparatus 11 may be implemented by a single computer or a cloud computing including multiple computers. In the first embodiment, an example is explained in which the file management apparatus 11 is implemented by a single computer. The file management apparatus 11 can manage documents by classifying the documents into groups. For example, the file management apparatus 11 manages documents by classifying the documents for each development process. The file management apparatus 11 provides separate folders to receive registration of documents for the respective groups, and receives registration of documents from the terminal device 12. When a developer generates or modifies a document by the terminal device 12, he/she registers a file of the document in a table format in a folder corresponding to the type of the document. When a file of a new document is registered in the folder, the file management apparatus 11 stores the registered file of the document. Furthermore, when an already-registered document is newly registered in the folder, the file management apparatus 11 compares the already-registered document and the newly-registered document to specify a modified portion and modified contents. Then, the file management apparatus 11 stores, as a modification history, the modified portion and the modified contents specified as above, together with the newly-registered document.
The file management apparatus 11 determines a relevance between the files of the registered documents. As a result of the determination, the file management apparatus 11 manages the files containing related portions, in an associated manner.
The file management apparatus 11 according to the first embodiment will be explained below.
The communication I/F unit 20 is an interface for controlling communication with other devices, such as the terminal devices 12. The communication I/F unit 20 transmits and receives various types of information to and from the other devices via the network 13. For example, the communication I/F unit 20 receives a file of a document in a table format from the terminal device 12 via the network 13. As an example of the communication I/F unit 20, a network interface card, such as a LAN card, may be employed.
The display unit 21 is a display device that displays various types of information. Examples of the display device serving as the display unit 21 include a liquid crystal display (LCD) and a cathode ray tube (CRT). The display unit 21 displays various types of information.
The input unit 22 is an input device that inputs various types of information. Examples of the input device serving as the input unit 22 include a mouse and a keyboard. The input unit 22 receives input of operation from a user, and inputs operation information indicating the contents of the received operation to the control unit 24.
The storage unit 23 is a storage device, such as a hard disk, a solid state drive (SSD), or an optical disk. The storage unit 23 may be a data-rewritable semiconductor memory, such as a random access memory (RAM), a flash memory, or a non-volatile static random access memory (NVSRAM).
The storage unit 23 stores therein an operating system (OS) and various programs used for file management, which are executed by the control unit 24. Furthermore, the storage unit 23 stores therein various types of data used in the programs executed by the control unit 24. For example, the storage unit 23 stores therein document data 30, format information 31, element information 32, file information 33, and relation information 34.
The document data 30 is data of a file of a registered document. For example, the document data 30 is stored when the terminal device 12 registers a file of a document in a document registration folder. Furthermore, the document data 30 is referred to by an extracting unit 40 (to be described later) when an element in the document is to be extracted.
The format information 31 is data, in which information on an element to be associated in a file in a table format is stored for each of description formats of documents. Incidentally, in a design process of the development, a requirement needed for the development is determined and a function for concretely realizing the requirement is designed. Then, in a test process, a test is performed to check whether the designed function is implemented and whether the requirement needed for the function is satisfied. As described above, in some cases, the requirement, the function, and the test item are related with one another. When there is the relevance, if any one of the related portions is modified, the other related portions may also be modified. For example, if the requirement is modified, a function related to the modified requirement and a test item related to the modified requirement are also modified. Therefore, the file management apparatus 11 according to the first embodiment stores, in the format information 31, information on a cell containing information on an element to be associated, for each of description formats of documents. For example, the format information 31 is registered by a developer who generates a document or an administrator who manages the file management apparatus 11 via the input unit 22 or the terminal device 12. Furthermore, the format information 31 is referred to by the extracting unit 40 (to be described later) in order to extract an element to be associated.
In the example in
The element information 32 is data containing information on an element extracted from a document. For example, the element information 32 is stored by the extracting unit 40 (to be described later). Furthermore, the element information 32 is referred to by the extracting unit 40 (to be described later) in order to determine a related element.
In the example in
The file information 33 is data containing information on a file from which an element is extracted. For example, the file information 33 is stored by the extracting unit 40 (to be described later). Furthermore, the file information 33 is referred to by a searching unit 43 (to be described later) in order to specify a file to be influenced.
In the example in
The relation information 34 is data containing information on an associated element. For example, the relation information 34 is stored by an associating unit 42 (to be described later). Furthermore, the relation information 34 is referred to by the searching unit 43 (to be described later) in order to specify an area to be influenced.
In the example in
Referring back to
The extracting unit 40 extracts various types of information. For example, when a file of a document in a table format is registered in a folder for receiving registration of the document, the extracting unit 40 extracts an element from the table-format file according to a format of the document by referring to the format information 31. If the file contains information indicating a type of the document, the format of the document may be determined based on the information contained in the file. For example, if information indicating a description format of the document is contained in a file name of the file or in a specific cell, the extracting unit 40 specifies the description format based on the registered file. For example, if a name indicating the type of the document is contained in the file name of the file or in a specific cell, the extracting unit 40 specifies the description format based on the file name or the specific cell. Incidentally, the description format of the document may be designated by a developer. For example, if a file is registered in a folder for receiving registration of the document, the extracting unit 40 displays types of description formats of documents stored in the format information 31 onto the terminal device 12, and receives designation of a description format.
The extracting unit 40 obtains, from the format information 31, a portion where an element to be associated is extracted, based on the description format of the document. For example, the extracting unit 40 obtains an item name of attribute information to be extracted and an item name of a cell containing information on an element, by referring to the items of Key and Contents in the format information 31. Then, the extracting unit 40 searches for cells with the obtained item name in the registered file, and sequentially extracts pieces of data of the cells with the item names along a column. The data extraction is continued until a predetermined termination condition is satisfied. For example, the termination condition may be set such that the data extraction is terminated when a predetermined number of empty cells are continued. Furthermore, the termination condition may be set such that the data extraction is terminated when data extraction for a predetermined number of cells is completed. It may be possible to provide a single termination condition for all of the documents, or provide different termination conditions for different types of the documents.
The extracting unit 40 assigns a unique ID number to the extracted attribute information and the extracted information on the element corresponding to the attribute information, and stores the ID number in association with the attribute information and the information on the element corresponding to the attribute information in the element information 32. Furthermore, the extracting unit 40 stores the attribute information and a document name of a file from which the element is extracted, in the file information 33 in an associated manner.
Subsequently, the extracting unit 40 extracts pieces of data of the items with the item names specified as the extraction objects from the registered files. In the example in
The extracting unit 40 assigns a unique ID number to the extracted attribute information and the extracted information on the element corresponding to the attribute information, and stores the ID number in association with the attribute information and the information on the element corresponding to the attribute information in the element information 32. Furthermore, the extracting unit 40 stores the attribute information and the document name of the file from which the element has been extracted, in the file information 33 in an associated manner. Therefore, in the example in
Referring back to
The associating unit 42 makes various types of association. For example, the associating unit 42 associates elements that are determined as related elements by the determining unit 41. For example, the associating unit 42 reads, from the element information 32, pieces of information in the item of Key of the elements determined as related elements, and registers the read pieces of the information on the related elements in the relation information 34 in an associated manner.
An example of association between various documents generated during development will be described below.
The documents generated through the development contain a large number of various types of information, and multiple description formats are employed. Therefore, it takes effort and time for a developer to search for an item to be managed. Furthermore, a large number of documents are generated through the development. Therefore, it is difficult for the developer to manage association between items of the documents.
Therefore, the file management apparatus 11 stores, in the format information 31, pieces of information on elements to be associated in table-format files, for each of the description formats of documents. If a document is registered, the file management apparatus 11 extracts elements from the document based on the format of the registered document. Therefore, the file management apparatus 11 can extract pieces of information on the elements to be associated from among a large number of pieces of information contained in the documents. Furthermore, the file management apparatus 11 compares the pieces of the information on the extracted elements to determine a relevance. Therefore, the file management apparatus 11 can specify related elements from among a large number of the extracted elements, and therefore can assist the association operation.
Referring back to
The searching unit 43 searches for various types of information and extracts the information obtained by the search. For example, if a search is requested, the searching unit 43 searches for elements associated with the designated element in the relation information 34 according to the search condition designated via the condition screen 80. For example, in the relation information 34, information for specifying a first portion of a file in a first table format and information for specifying a second portion of a file in a second table format are associated with each other. In this case, when receiving a search request for an area to be influenced by the first portion, the searching unit 43 extracts the information for specifying the second portion associated with the information for specifying the first portion. Furthermore, if the search condition contains information for designating a dependency relationship, the searching unit 43 extracts information related to the first portion according to the information for designating the dependency relationship. For example, if the dependency relationship between search target elements is designated in the search condition, the searching unit 43 searches for elements that are associated based on the designated dependency relationship. Moreover, if the search condition contains information for designating a search scope of information on an associated portion, the searching unit 43 extracts associated information within the designated scope. For example, if the number of hierarchies is designated as a search scope of information on an associated portion, the searching unit 43 repeats extraction of the second portion associated with the first portion by assuming that the extracted second portion serves as the first portion, for the same number of times as the designated number of hierarchies.
Incidentally, in the development of an automobile, the International Organization for Standardization (ISO) 26262 is defined as an automotive functional safety standard. The file management apparatus 11 extracts elements to be associated from registered documents, and manages the elements in an associated manner. Therefore, even if any of the elements need to be modified, it is possible to specify an area to be influenced by the modified element. Consequently, the file management apparatus 11 can support development compliant with ISO 26262.
The flow of an extraction process for extracting an element from a document by the file management apparatus 11 according to the first embodiment will be explained below.
As illustrated in
Next, the flow of an association process for associating elements by the file management apparatus 11 according to the first embodiment will be explained below.
As illustrated in
In contrast, if the comparison has not been completed (NO at S23), the determining unit 41 compares the process-target information and the selected information to determine whether the pieces of the information entirely or partially match each other (S24). If the pieces of the information do not entirely or partially match each other (NO at S24), the process proceeds to S26 to be described later.
In contrast, if the pieces of the information entirely or partially match each other (YES at S24), the associating unit 42 reads pieces of information stored in the item of Key of the elements for which the pieces of the information entirely or partially match each other, and registers the read pieces of the information on the elements in the relation information 34 in an associated manner (S25).
The determining unit 41 determines whether the process-target information has been compared with all of the read pieces of the information other than the process-target information (S26). If the comparison has not been completed (NO at S26), the process proceeds to S22 as described above, and a next piece of information is selected.
In contrast, if the comparison has been completed (YES at S26), the determining unit 41 determines whether all of the read pieces of the information have already been selected as the process-target information (S27). If there is a piece of information that has not been selected as the process-target information from among the read pieces of the information (NO at S27), the process proceeds to S21 as described above.
In contrast, if all of the read pieces of the information have been selected as the process-target information (YES at S27), the process is terminated.
Next, the flow of a search process performed by the file management apparatus 11 according to the first embodiment to search for an area to be influenced will be explained below.
As illustrated in
The searching unit 43 extracts a second portion of a file in a second table format associated with the first portion of the file in the first table format based on the dependency relationship designated in the search condition (S32). For example, if a search based on the superordinate-to-subordinate dependency relationship is designated, the searching unit 43 extracts, from the relation information 34, a subordinate element of an element of the first portion of the file in the first table format serving as a superordinate element. For example, the searching unit 43 searches for attribute information in the item of Relation Child ID of a record, for which the attribute information on the element of the first portion of the file in the first table format is stored in the item of Relation Parent ID in the relation information 34. Furthermore, if a search based on the subordinate-to-superordinate dependency relationship is designated, the searching unit 43 extracts, from the relation information 34, a superordinate element that is associated with the element of the first portion of the file in the first table format serving as a subordinate element. For example, the searching unit 43 searches for attribute information in the item of Relation Parent ID of a record, for which the attribute information on the element of the first portion of the file in the first table format is stored in the item of Relation Child ID in the relation information 34. Then, the searching unit 43 handles the extracted element as the second portion of the file in the second table format.
The searching unit 43 determines whether the second portion of the file in the second table format is extracted (S33). If the second portion is not extracted (NO at S33), the process proceeds to S37 to be described later.
In contrast, if the second portion is extracted (YES at S33), an element of the second portion of the file in the second table format is stored as an element to be influenced (S34).
The searching unit 43 determines whether the number of hierarchies is designated in the search condition (S35). If the number of hierarchies is designated (YES at S35), the searching unit 43 determines whether the variable N indicating the hierarchy subjected to the search corresponds to the number of hierarchies designated in the search condition (S36). If the variable N corresponds to the number of hierarchies designated in the search condition (YES at S36), the searching unit 43 outputs the above-stored element to be influenced and a file containing the element to be influenced, as an area to be influenced (S37), and the process is terminated.
In contrast, if the number of hierarchies is not designated (NO at S35) or if the variable N does not correspond to the number of hierarchies designated by the search condition (NO at S36), the process proceeds to S38 to be described below. The searching unit 43 adds one to the value of the variable N (S38). Then, the searching unit 43 sets the second portion obtained by the search as a new first portion, and sets a file in the second table format containing the second portion as a new file in the first table format (S39), and then the process proceeds to S32 as described above.
As described above, the file management apparatus 11 stores an association relationship between the information for specifying the first portion of the file in the first table format and the information for specifying the second portion of the file in the second table format in the relation information 34 in the storage unit 23. When receiving a search request for an area to be influenced by the first portion of the file in the first table format, the file management apparatus 11 extracts information for specifying the second portion associated with the information for specifying the first portion, by referring to the relation information 34 in the storage unit 23. Then, the file management apparatus 11 outputs, as a reply to the search request, information for specifying the second portion and information for specifying the file in the second table format containing the second portion. Therefore, the file management apparatus 11 can specify even a portion of a file as an area to be influenced by a modification.
Furthermore, the file management apparatus 11 stores, in the relation information 34 in the storage unit 23, the dependency relationship of the second portion with respect to the first portion. Then, if the search request for the area to be influenced contains information for designating the dependency relationship, the file management apparatus 11 extracts information related to the first portion according to the information for designating the dependency relationship. Therefore, the file management apparatus 11 can extract only a portion that is associated based on a specific dependency relationship. For example, if the dependency relationship is the order of development processes, the file management apparatus 11 can extract portions to be influenced in subsequent processes.
Moreover, if the search request for the area to be influenced contains information for designating a search scope, the file management apparatus 11 extracts information for specifying the second portion associated with the first portion within the scope contained in the search request. Therefore, the file management apparatus 11 can extract an area to be influenced by a modification within the designated scope.
A second embodiment will be explained below. A configuration of the file management apparatus 11 according to the second embodiment is approximately the same as the file management apparatus 11 according to the first embodiment illustrated in
The file management apparatus 11 according to the second embodiment is able to set a type of an association relationship between elements. Furthermore, the file management apparatus 11 is able to set multiple types of association relationships between the same elements. The file management apparatus 11 stores a type of an association relationship in the relation information 34 for each of association relationships.
Incidentally, elements extracted from documents are associated with one another for various purposes. For example, elements to be influenced by a modification are associated with each other to simplify a search for the area to be influenced by the modification. Furthermore, elements concerning a part developed for a specific target are associated with each other. For example, in the development of an automobile, different functions may be developed for different countries in order to comply with respective legal systems, environments, or needs in the countries. Moreover, elements of a referenced part are associated with each other in order to simplify a search for the referenced part in the documents.
The file management apparatus 11 according to the second embodiment can register different types of association relationships for respective purposes, and provides items of “Traceability”, “Japan Model”, “United States Model”, and “Reference” as types of association relationships. The item of Traceability is used to associate elements to be influenced by a modification. The item of Japan Model is used to associate elements of specific functions developed for Japan. The item of United States Model is used to associate elements of specific functions developed for the United States. The item of Reference is used to associate elements of referenced documents.
In the item of Relation Kind in the relation information 34 according to the second embodiment, a name indicating a type is stored as information on the type of the association relationship. In the example in
The file management apparatus 11 displays, as candidate elements, elements determined as related elements by the determining unit 41 on the designation screen 60 illustrated in
The associating unit 42 registers the elements, which are designated to be associated via the designation screen, in the relation information 34 for each of the types designated in the designation screen 65.
Furthermore, the file management apparatus 11 according to the second embodiment allows the developer to designate elements to be associated and associate the elements via an operation screen. When receiving a request for the operation screen from the terminal device 12, the associating unit 42 displays the operation screen to associate elements on the terminal device 12, and associates the elements designated via the operation screen.
When the elements to be associated are designated via the operation screen 90, the associating unit 42 displays the designation screen 65 as illustrated in
Furthermore, the file management apparatus 11 according to the second embodiment receives a search request for an area to be influenced, together with designation of an association type to be searched for. For example, the searching unit 43 displays, as a search condition, a condition screen containing a field that enables to designate an association type to be searched for on the terminal device 12, and receives the search request for the area to be influenced via the condition screen.
When a search is requested, the searching unit 43 searches for, as the area to be influenced, elements associated with the designated element in the relation information 34 according to the search condition designated via the condition screen 80. For example, in the relation information 34, the information for specifying the first portion of the file in the first table format and the information for specifying the second portion of the file in the second table format are associated with each other. In this case, if the search condition contains information for designating a type of an association relationship, the searching unit 43 extracts information for specifying a second portion that is associated based on the designated type, from among second portions associated with the information for specifying the first portion.
The flow of a search process performed by the file management apparatus 11 according to the second embodiment to search for an area to be influenced will be explained below.
The searching unit 43 determines whether a type of an association relationship is designated in the search condition (S40). If the type is not designated (NO at S40), the process proceeds to S34 as described above. In contrast, if the type is designated (YES at S40), the searching unit 43 extracts an element of the second portion that is associated based on the designated type, from among elements of the second portion of the file in the second table format extracted by the process at S32 (S41), and the process proceeds to S34.
As described above, the file management apparatus 11 further stores a type of an association relationship in the relation information 34 in the storage unit 23, for each of association relationships. If a search request for an area to be influenced contains information for designating a type of an association relationship, the file management apparatus 11 extracts information for specifying the second portion that is associated based on the type contained in the search request, from among the second portions associated with the information for specifying the first portion. Therefore, the file management apparatus 11 can extract only a portion that is associated based on a specific type. For example, the file management apparatus 11 can specify even a portion of a file as the area to be influenced by a modification. Furthermore, the file management apparatus 11 can specify even a portion of a file as an area corresponding to the development for a specify country, such as Japan or the United States. Moreover, the file management apparatus 11 can specify even a portion of a file of a referenced document.
While the embodiments of the present invention have been described above, the present invention may be embodied in various forms other than the above-described embodiments. The other embodiments will be described below.
For example, while, in the embodiments, an example has been explained in which item names of elements to be associated are stored and pieces of data of the items of the item names are extracted as information on the elements, the present invention is not limited to this example. For example, it may be possible to store area information indicating an area in which information on elements to be associated is stored, and may extract data in the area indicated by the area information in a file.
Furthermore, the components illustrated in the drawings are functionally conceptual and do not necessarily have to be physically configured in the manner illustrated in the drawings. In other words, specific forms of distribution and integration of the apparatuses are not limited to those illustrated in the drawings, and all or part of the apparatuses may be functionally or physically distributed or integrated in arbitrary units depending on various loads or use conditions. For example, the processing units of the extracting unit 40, the determining unit 41, the associating unit 42, and the searching unit 43 illustrated in
File Management Program
Various processes explained in the above embodiments may be implemented by causing a computer system, such as a personal computer or a workstation, to execute a program that is prepared in advance. Therefore, an example of the computer system that executes a program having the same functions as those of the embodiments will be explained below.
As illustrated in
The ROM 320 stores therein, in advance, a file management program 320a that implements the same functions as those of the processing units of the above embodiments. For example, the file management program 320a implements the same functions as those of the extracting unit 40, the determining unit 41, the associating unit 42, and the searching unit 43 of the above embodiments. Meanwhile, the file management program 320a may be separated appropriately.
The HDD 330 stores therein various types of data. For example, the HDD 330 stores therein an OS or various types of data used to manage files.
The CPU 310 reads the file management program 320a from the ROM 320 and executes the program, to thereby implement the same operations as those of the processing units of the embodiments. Specifically, the file management program 320a implements the same operations as those of the extracting unit 40, the determining unit 41, the associating unit 42, and the searching unit 43 of the embodiments.
Incidentally, the file management program 320a described above need not always be stored in the ROM 320 from the beginning. The file management program 320a may be stored in the HDD 330.
For example, the program may be stored in a “portable physical medium”, such as a flexible disk (FD), a compact disk-ROM (CD-ROM), a digital versatile disk (DVD), a magnetooptical disk, or an integrated circuit (IC) card, that is insertable into the computer 300. Then, the computer 300 reads the program from the medium and executes the program.
Alternatively, the program may be stored in “other computers (or servers)” connected to the computer 300 via a public line, the Internet, a local area network (LAN), or a wide area network (WAN). Then, the computer 300 reads the program from the other computers or servers and executes the program.
It is possible to specify even a portion of a file as an area to be influenced by a modification.
All examples and conditional language recited herein are intended for pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed as limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiments of the present invention have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2012-289101 | Dec 2012 | JP | national |