The present disclosure relates to methods and systems for providing information related to software components for easy understanding for scenarios like search listing and can be used in conjunction with a search engine or other shortlisting products for software components.
With open-source technologies, cloud based public code repositories and cloud based applications increasing exponentially, there is a need for software developers to have a way to find such software components for use in their software development. Today there are more than 30 million public code repositories and 100,000 public application programmable interfaces (APIs). There are few 100 million articles that provide knowledge, review of the software components.
Considering some patents that are in this same field of technology, U.S. Pat. No. 8,296,311 discloses a search middleware which is used to receive search requests regarding a software incident associated with a software application. The search requests may be populated with attribute values determined based on context data associated with the software application and collected in association with the software incident. The search requests may be dispatched to a subset of a plurality of solution repositories, even if the solution repositories have different interfaces and/or search technologies. The resulting solution documents retrieved from the solution repositories may be compiled for presentation on a solution search interface. However, this disclosure is silent regarding providing language and license retrieval, and provision of quality scores for the software components.
U.S. Pat. No. 8,498,974 discloses a computer-implemented method for processing query information includes receiving data representative of a search query from a user search session. The method also includes identifying a plurality of search results based upon the search query. Each search result is associated with a plurality of user characteristics and data that represents requestor behavior relative to previously submitted queries associated with the respective search result. The method also includes ordering the plurality of user characteristics based upon the data that represents requestor behavior relative to previously submitted queries and the respective search result. The method also includes adjusting the ordered plurality of user characteristics based upon at least one predefined compatibility associated with the user characteristics. The method also includes ranking the search results based upon the adjusted plurality of user characteristics. However, this disclosure is silent regarding providing language and license retrieval, and provision of security related scores for the software components.
United States Patent Application Publication No. 2004/0243568A1 discloses a search engine architecture that is designed to handle a full range of user queries, from complex sentence-based queries to simple keyword searches. The search engine architecture includes a natural language parser that parses a user query and extracts syntactic and semantic information. The parser is robust in the sense that it not only returns fully parsed results (e.g., a parse tree), but is also capable of returning partially parsed fragments in those cases where more accurate or descriptive information in the user query is unavailable. A question matcher is employed to match the fully parsed output and the partially parsed fragments to a set of frequently asked questions (FAQs) stored in a database. The question matcher then correlates the questions with a group of possible answers arranged in standard templates that represent possible solutions to the user query. The search engine architecture also has a keyword searcher to locate other possible answers by searching on any keywords returned from the parser. The answers returned from the question matcher and the keyword searcher are presented to the user for confirmation as to which answer best represents the user's intentions when entering the initial search query. The search engine architecture logs the queries, the answers returned to the user, and the user's confirmation feedback in a log database. The search engine has a log analyzer to evaluate the log database to glean information that improves performance of the search engine over time by training the parser and the question matcher. However, this disclosure is silent on features that are directed towards display of scores for the searched items and associated information for easy selection of search results.
U.S. Pat. No. 8,627,270 discloses a computer system is provided, comprising: a transceiver; and a processor configured to facilitate collecting and storing information related to a software project having one or more software artifacts, the information including: a project identifier, artifact identifiers for the artifacts used by the project, information about the temporal version for the artifacts, and contact information for a project user. Artifact metadata associated with the software artifacts is collected from a repository, which includes information identifying the artifact, information about security risks associated with the artifact, information about a license associated with the artifact, or information indicative of a level of use or user rating of the artifact. Periodical monitoring of the metadata is performed to determine whether there has been any actionable change in the artifact metadata; and the project user is notified using the contact information if it is determined that there has been an actionable change in the artifact metadata. However, this disclosure is silent on features that are directed towards display of scores for the searched items and associated information for easy selection of search results.
United States Patent Application Publication No. 2011/0231817A1 discloses a system that includes one or more computer processors that are configured to receive parameters relating to non-functional attributes of a proposed software component, parameters relating to non-functional attributes of one or more available software components, and a weight for each of the non-functional attributes. The system calculates a quality and a risk for each available software component as a function of the parameters of the proposed software component, the parameters for the one or more available software components, and the weight for each of the non-functional attributes. The system outputs to a display device one or more of the qualities and the risk for the one or more available software components. However, this disclosure does not take into consideration ecosystem score, languages, license. Furthermore, user preferences are not considered, and machine learning techniques are not used.
U.S. Pat. No. 8,935,192 discloses methods, systems, and apparatus, including computer programs, for a social search engine. In one aspect, a method includes receiving an answer to a question from an answerer; identifying an entity in the answer, in which the entity refers to a product, a service, a company, or a merchant. Permission is obtained from the answerer to provide an interactive link for the entity in the answer to a resource from which the entity can be obtained and a user submitted query is received to determine whether the query is related to the entity. The answer is provided in response to the determining step, including the link to the resource, as part of search results that are responsive to the query. However, this disclosure is silent on features that are directed towards display of scores for the searched items and associated information for easy selection of search results.
United States Patent Application Publication No. 2006/0265232A1 discloses an adaptive customer assistance system that serves as an integrated online and offline help platform for a suite of software products. The assistance system includes a customer-interaction interface and a data management component and a download management component for distributed customer interaction. The data management component includes an authoring component, a download component, a runtime component and an analysis component. The runtime component, which includes a customer assistance model, is configured to receive a user-formulated question from the customer-interaction interface. The runtime component provides an answer to the user-formulated question based on information included in the customer assistance model. The analysis component automatically analyzes, in substantially real-time, the user-formulated question and the corresponding answer, and provides an analysis output for use in improving a quality of customer assistance. However, this disclosure is silent on features that are directed towards ecosystem score, languages, license and user preferences and machine learning techniques.
U.S. Pat. No. 8,112,744 discloses a system for self-assembling software components. In one embodiment, a system includes a first and second set of language components, where each language component defines at least one part of language runnable on a computer by associating a piece of grammar of the language with at least one software component that implements the piece of grammar. The system further includes a request broker that upon being provided with a section of code written in the language matches syntactic appearances of the first set of language components in the section of code and granting logic to grant access to the language components of the first set whose syntactic appearances the request broker matched, to enable self-assemblage of the language components of the first set with language components of the second set. However, this disclosure is silent on features that are directed towards display of scores for the searched items and associated information for easy selection of search results.
U.S. Pat. No. 9,672,554 discloses methods and systems for analyzing, ordering and presenting item listings. In one example embodiment, a search query is processed to identify item listings satisfying the search query. Then, for each item listing that satisfies the search query, a ranking score is derived and assigned to the item listing. The ranking score is based in part on a relevance score, a listing quality score and a business rules score (or, adjustment factor). Finally, the item listings are ordered, based on their corresponding ranking score, and presented in order in a search results page. However, this disclosure is limited to describing regarding the order of the items to be presented and is silent on display of attributes of the library.
U.S. Pat. No. 8,452,742B2 discloses a software configuration management system which includes a software component database and a software product management unit and accepts data transmission/reception from a software component database management client and a software product operation client. The software configuration management system further includes: a component-product correspondence table, component-file correspondence information, a synchronization unit for mutually committing a modification of the software component database and a modification of a software product; update information; and a correspondence table update unit. However, this disclosure is silent on features that are directed towards display of scores for the searched items and associated information for easy selection of search results.
United States Patent Application Publication No. 2007/0234291A1 discloses methods, systems, and software for utilizing development components or other enterprise content whether developed internally or by third parties. One method for utilizing reusable development components includes presenting an interface to a remote user operable to display information for at least a first and a second development component. In some cases, the first development component is a first type of enterprise application content and the second development component of a second type of enterprise application content. The user is then allowed to update some portion of metadata associated with the first development component. However, this disclosure is silent on features that are directed towards display of scores for the searched items and associated information for easy selection of search results.
United States Patent Application No. 2002/0194578A1 discloses a software component library management system, which can effectively support both a component utilization user and a component management user in carrying out their business tasks. The component management tool includes a component retrieve/pickup function unit and a component administration/registration function unit. The component administration/registration function unit is adapted to make registrations of attribute information on software components stored in the component database, such as relation information items representing relations between the software component and other software components. The component retrieve/pickup function unit can retrieve and pickup a batch of software components related to a specific software component, based on the relation information items. The relation information item includes a slave link used to identify a slave component which a certain software component uses (slave information item), and a master link used to identify a master component by which a certain software component is used (master information item). However, this disclosure is silent on features that are directed towards display of scores for the searched items and associated information for easy selection of search results.
In view of the state of prior art as described above, even with a dedicated search engine that provides specialized search and retrieval of software components, it is difficult for a developer to decide which component choice should be selected from the displayed list. Because of this the developer will have to spend a lot of time to review each component and since the process is manual, it is prone to errors.
The present disclosure provides techniques that puts together all relevant information of the software component and displays it concisely and in an easy to interpret format. This will enable the developer to get all critical details of the software component in the same search listing window, in an easy-to-understand format, significantly saving time and eliminating manual review errors.
A system for display of search item scores and related information for easier search result selection. A results information builder to capture a search request and decide on required information components and coordinates with different services to generate information. A language retrieval service to provide a programming language information of a software component. An ecosystem retrieval service to provide an ecosystem information of the software component. A license retrieval service to provide a licensing information of the software component. A quality retrieval service to provide a quality score of the software component and a security retrieval service to provide a security score of the software component. A source details retrieval service to provide details of sources and associated details of the software component and a results information widget generator that dynamically assembles and generates listing information associated with the software component. A software information crawler crawls internet sources to assimilate associated information of the software components.
In an embodiment, Results Information Builder is configured to decide on list of the information required and template based on the search request, type of listing required, and user preferences, wherein the user preferences are one of explicit choices and machine learnt based on user behavior of that user or a set of users using information in equivalent listings. In the same embodiment, Results Information Builder is configured to decide parameters that need to be used for this list of the information that comprise programming language, ecosystem information such as popularity, support, licensing information, quality, security, and diverse sources of that software component. In the same embodiment, the Results Information Builder is configured to coordinate with whole or selected services across the Language Retrieval Service, the Ecosystem Retrieval Service, the License Retrieval Service, the Quality Retrieval Service, the Security Retrieval Service, the Source Details Retrieval Service to collate the information details.
In an embodiment, the Language Retrieval Service is configured to leverage machine learning technologies to provide most relevant one or more programming languages that the software component is available based on context of the user. In the same embodiment, the Language Retrieval Service is configured to cover complete set of software programming languages, technologies, frameworks; and down-select based on the user preference shared or based on this user or other user behavior, according to the technologies that most frequently used and context of the search. In an embodiment, the Ecosystem Retrieval Service is configured to leverage machine learning technologies to compute an ecosystem score for the software component, wherein the ecosystem score is built based on software popularity, number of downloads, number of answered questions and the rate of closure of issues.
In an embodiment, the License Retrieval Service is configured to leverage machine learning technologies to provide the most relevant licenses that the software component is available based on the context of the user, and prioritize and interpret licenses based on the commercial construct that the user is leveraging, and their implementation context. In the same embodiment, the License Retrieval Service is configured to down-select based on the user preference shared or based on this user or other user behavior, according to the licenses that are most frequently used and the context of the implementation; and display an alert icon to help the user decide, if based on the license applicability to the context of the search, the license type is non-conformant.
In an embodiment, the Quality Retrieval Service is configured to leverage the machine learning technologies to compute the quality score for the software component, wherein the quality score is built based on total number of bugs, open bugs, software code scan performance and rate of closure of issues. In an embodiment, the Security Retrieval Service is configured to leverage machine learning technologies to compute the security score for the software component, wherein the security score is built based on total number of bugs, open bugs, software code scan performance and rate of closure of issues.
In an embodiment, the Source Details Retrieval Service is configured to leverage the machine learning technologies to retrieve and provide most relevant sources where the software component is available based on the context of the user and compare the same software component available with a plurality of hosting providers and in multiple formats that comprise source code, API, and library. In the same embodiment, the Source Details Retrieval Service is configured to down-select based on one of the user preferences shared and based on this user or other user behavior, according to the sources that are most frequently used and the context of this search; and retrieve relevant software component summary, author's name and last updated date and the last updated date translated to an easy to compare format that is similar to number of days ago.
In an embodiment, the Results Information Widget Generator is configured to consolidate information parameters from the different information component services that have been processed and converts it to the format required, wherein the formats include messages comprising json, xml or fully usable UI components across the computer, tablet, mobile screens in a responsive technology. In an embodiment, the Software Information Crawler is configured to crawl the internet sources that comprise public repositories, cloud providers, Question and Answers (Q&A), review sites, vulnerability databases; and parse and store information on programming language, licenses, sources, support, popularity, quality, and security information into a file storage.
One aspect includes a system for displaying search item scores and related information for easier search result selection, the system comprising: one or more processors and memory storing instructions that, when executed by the one or more processors, cause the one or more processors to perform operations comprising: receiving a search request for a software component; retrieving a programming language information of the software component; retrieving an ecosystem information of the software component; retrieving a licensing information of the software component; retrieving a quality score of the software component; retrieving a security score of the software component; retrieving details of sources and associated details of the software component; dynamically generating a results information widget including information associated with the software component; and searching, based on the retrieved information, internet sources to assimilate associated information of the software components.
In some embodiments, the operations further comprise: determining a list of the information required and template based on the search request, type of listing required, and user preferences, wherein the user preferences are one of explicit choices and machine learnt based on user behavior of that user or a set of users using information in equivalent listings; and determining parameters that need to be used for this list of the information that comprise programming language, ecosystem information, licensing information, quality, security, and diverse sources of that software component.
In some embodiments, the operations further comprise: provide, based on results of a machine learning model, most relevant one or more programming languages that the software component is available based on context of the user including software programming languages, technologies, and frameworks; and down-selecting based on the user preference shared or based on this user or other user behavior, according to the technologies that most frequently used and context of the search.
In some embodiments, the operations further comprise generating an ecosystem score, based on results of a machine learning model, for the software component, wherein the ecosystem score is built based on one or more of software popularity, number of downloads, number of answered questions, or rate of closure of issues.
In some embodiments, the operations further comprise: providing, based on results of a machine learning model, the most relevant licenses that the software component is available based on the context of the user; interpreting licenses, based on the commercial construct that the user is leveraging, and their implementation context; down-selecting based on the user preference shared or based on this user or other user behavior, according to the licenses that are most frequently used and the context of the implementation; and displaying an alert icon to help the user decide, if based on the license applicability to the context of the search, the license type is non-conformant.
In some embodiments, the operations further comprise computing a quality score, based on results of a machine learning model, for the software component, wherein the quality score is built based on one or more of total number of bugs, open bugs, software code scan performance, or rate of closure of issues.
In some embodiments, the operations further comprise computing, based on results of a machine learning model, a security score for the software component, wherein the security score is built based on one or more of total number of bugs, open bugs, software code scan performance, or rate of closure of issues.
In some embodiments, the operations further comprise: providing, based on results of a machine learning model, most relevant sources where the software component is available based on the context of the user; comparing the same software component available with a plurality of hosting providers and in multiple formats that comprise source code, API, and library; down-selecting based on one of the user preferences shared and based on this user or other user behavior, according to the sources that are most frequently used and the context of this search; and retrieving relevant software component summary, author's name and last updated date.
In some embodiments, the operations further comprise: consolidating the retrieved information; and converting the consolidated information to a format including one or more messages comprising JSON, XML, or fully usable UI components across the computer, tablet, mobile screens in a responsive technology.
In some embodiments, the operations further comprise: crawling internet sources that comprise public repositories, cloud providers, Question and Answers (Q&A), review sites, and vulnerability databases; parsing and storing information on programming language, licenses, sources, support, popularity, quality, and security information into a file storage.
Another aspect is a method of displaying search item scores and related information for easier search result selection, the method comprising: receiving a search request for a software component; retrieving a programming language information of the software component; retrieving an ecosystem information of the software component; retrieving a licensing information of the software component; retrieving a quality score of the software component; retrieving a security score of the software component; retrieving details of sources and associated details of the software component; dynamically generating a results information widget including information associated with the software component; and searching, based on the retrieved information, internet sources to assimilate associated information of the software components.
In some embodiments, the method further comprises determining a list of the information required and template based on the search request, type of listing required, and user preferences.
In some embodiments, the method further comprises processing user preferences that comprise one of explicit choices, machine learnt based on user behavior of that user, and a set of users using information in equivalent listings.
In some embodiments, the method further comprises determining parameters that need to be used for the equivalent listings that comprises programming language, ecosystem information, licensing information, quality, security, and diverse sources of that software component.
In some embodiments, the method further comprises providing, based on results of a machine learning model, the most relevant one or more programming languages, wherein the software component is available based on a context of the user covering all software programming languages, technologies and frameworks; and down-selecting based on one of the user preference shared and this user or other user behavior, according to the technologies that are most frequently used and the context of this search.
In some embodiments, the method further comprises computing, based on results of a machine learning model, the ecosystem score for the software component based on one or more of the software popularity, number of downloads, number of answered questions, or rate of closure of issues.
In some embodiments, the method further comprises providing, based on results of a machine learning model, most relevant licenses, wherein the software component is available based on the context of the user, which is prioritized and interpreted based on the commercial construct that the user is leveraging and their implementation context, and further down-selected based on one of the user preference shared and this user or other user behavior, according to the licenses that are most frequently used and the implementation context, and providing an alert based on non-conformant licenses.
In some embodiments, the method further comprises computing, based on results of a machine learning model, a quality score for the software component based on one or more of total number of bugs, open bugs, software code scan performance, or rate of closure of issues.
In some embodiments, the method further comprises computing, based on results of a machine learning model, a security score for the software component based on total number of bugs, open bugs, software code scan performance and rate of closure of issues.
In some embodiments, the method further comprises: providing, based on results of a machine learning model, most relevant sources where the software component is available based on the context of the user across multiple hosting providers and in multiple formats comprising source code, API, library; down-selecting based on one of the user preference shared and on this user or other user behavior, according to the sources that are most frequently used and the context of this search; and retrieving relevant software component summary, author name and last updated date and the last updated date translated to an easy to compare format that is similar to number of days ago.
In some embodiments, the method further comprises: consolidating information parameters from different information component services that have been processed; and converting the consolidated information parameters to a format required comprising one of JSON, XML, and fully usable UI components across the computer, tablet, mobile screens in a responsive technology.
In some embodiments, the method further comprises: crawling internet sources that comprise public repositories, cloud providers, Q&A, review sites, vulnerability databases; and parsing and storing information on the programming language, licenses, sources, support, popularity, quality, and security information into a file storage.
Another aspect is a computer program product for displaying search item scores and related information for easier search result selection comprising a processor and memory storing instructions thereon, wherein the instructions when executed by the processor cause the processor to perform operations comprising: receiving a search request for a software component; retrieving a programming language information of the software component; retrieving an ecosystem information of the software component; retrieving a licensing information of the software component; retrieving a quality score of the software component; retrieving a security score of the software component; retrieving details of sources and associated details of the software component; dynamically generating a results information widget including information associated with the software component; and searching, based on the retrieved information, internet sources to assimilate associated information of the software components.
The disclosure can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the present disclosure. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views.
Like reference numbers and designations in the various drawings indicate like elements.
To eliminate the manual review errors and to significantly reduce the time taken for the developer to review the choices from a list of software components listed, we propose a solution that retrieves all relevant information to the software component and displays it concisely and in an easy to interpret format. So now the developer can get all critical details in the same listing window, in an easy-to-understand format, significantly saving time and eliminating manual review errors.
In the embodiment shown in
The request from Search System 101 goes to the API Hub 102 which acts as a gateway for accepting and transmitting all web service requests. The API Hub 102 hosts the web services for taking the requests and creating request messages to be put into the Messaging Bus 103. The Messaging Bus 103 provides for event driven architecture thereby enabling long running processes to be decoupled from requesting system's calls. This decoupling will help the system to service the request and notify calling system once the entire process of generating the filter is completed. There are job listeners configured to listen to the messages in the Messaging Bus 103.
The Results Information Builder 104 decides on the list of information required and template based on the search request, type of listing required and user preferences. User preferences can be explicit choices or can be machine learnt based on user behavior of that user or a set of users using information in equivalent listings. The Results Information Builder 104 will decide the parameters that need to be used for this listing such as but not limited to programming language, ecosystem information such as popularity, support, licensing information, quality, security, and diverse sources of that software component.
The Results Information Builder 104 coordinates with different services such as Language Retrieval Service 105, Ecosystem Retrieval Service 106, License Retrieval Service 107, Quality Retrieval Service 108, Security Retrieval Service 109, and Source Details Retrieval Service 110 to collate the information details to be created in the widget. The Results Information Builder 104 calls the different services based on the type of information that needs to be used for the current user search.
The Language Retrieval Service 105 leverages machine learning technologies to provide the most relevant programming language or programming languages that the input software component is available based on the context of the user. The same software can be available in multiple programming languages or implementation frameworks. The Language Retrieval Service 105 is selected based on the user preference shared or based on this user or other user behavior, according to the technologies that they most frequently use and the context of this search.
The Ecosystem Retrieval Service 106 leverages machine learning technologies to compute the ecosystem score for the software component. The ecosystem score is built based on the software popularity, the number of downloads, number of answered questions and the rate of closure of issues.
The License Retrieval Service 107 leverages machine learning technologies to provide the most relevant licenses that the input software component is available based on the context of the user. The same software can be available under multiple licenses based on the commercial construct that the user is leveraging, and their implementation context. It is selected based on the user preference shared or based on this user or other user behavior, according to the licenses that they most frequently use and the context of this implementation. Based on the license applicability to this context, non-conformant license types are paired with an alert icon to help the user decide accordingly. In other words, the License Retrieval Service 107 prioritizes and interprets licenses based on the commercial construct that the user is leveraging, and their implementation context
The Quality Retrieval Service 108 leverages machine learning technologies to compute the quality score for the software component. The quality score is built based on the total number of bugs, open bugs, software code scan performance and the rate of closure of issues.
The Security Retrieval Service 109 leverages machine learning technologies to compute the quality score for the software component. The security score is built based on the total number of bugs, open bugs, software code scan performance and the rate of closure of issues.
The Source Details Retrieval Service 110 leverages machine learning technologies to retrieve and provide the most relevant sources where the input software component is available based on the context of the user. The same software component can be available with multiple hosting providers and in multiple formats such as source code, API, library etc. It is selected based on the user preference shared or based on this user or other user behavior, according to the sources that they most frequently use and the context of this search. From these sources the relevant software component summary, the author's name and last updated date are retrieved, and the last updated date is translated to an easy to compare format such as number of days ago.
Results Information Widget Generator 111 takes the consolidated information parameters from the different information component services that have been processed by Results Information Builder 104 and converts it to the format required by the Search System 101. These formats are, but not limited to messages such as JSON, XML or fully usable UI components across the computer, tablet, mobile screens in a responsive technology such as React.
The File Storage 114 is used to store document type of data, source code files, documents, readme files, installation guides, user guides, neural network models etc.
The Database 115 is a relational database system (RDBS) like MySQL to store all meta-data pertaining to the requests received from the search system 101, messaging bus, request processor and from other system components described above. The meta-data includes details of every request to identify who submitted it, requested details to track the progress as the System processes the request through its different tasks. The status of each execution step in entire process is stored in this database to track and notify the system on completion.
The Software Information Crawler 112 crawls (or searches or scans) the internet sources such as, but not limited to public repositories, cloud providers, Q&A, review sites, vulnerability databases to parse and store information on programming language, licenses, sources, support, popularity, quality, and security information into the File Storage 114.
Although a few implementations have been described in detail above, other modifications are possible. For example, while a client application is described as accessing the delegate(s), in other implementations the delegate(s) may be employed by other applications implemented by one or more processors, such as an application executing on one or more servers. In addition, the logic flows depicted in the figures do not require the order shown, or sequential order, to achieve desirable results. In addition, other actions may be provided, or actions may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Accordingly, other implementations are within the scope of the following claims.
As multiple embodiments of the present disclosure have been elaborated above, it should be construed that they have been described by way of example alone, and not by way of limitation. Hence, the scope of the present disclosure should not be limited by any of the exemplary embodiments. Additionally, the disclosure is defined above in terms of multiple exemplary embodiments and applications. It should be understood that the several features and the functionality explained in one or more of the distinct embodiments are not limited in their applicability to the specific embodiment with which they are explained, but instead can be functional, by itself or in a defined combination, to one or more of the other embodiments of the disclosure, whether or not such embodiments are explained and whether or not such aspects are presented as being a part of a described embodiment.
This application claims the benefit of and priority to U.S. Provisional Patent Application No. 63/153,192 filed Feb. 24, 2021, the entire disclosure of which is incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5953526 | Day et al. | Sep 1999 | A |
7322024 | Carlson et al. | Jan 2008 | B2 |
7703070 | Bisceglia | Apr 2010 | B2 |
7774288 | Acharya et al. | Aug 2010 | B2 |
7958493 | Lindsey et al. | Jun 2011 | B2 |
8010539 | Blair-Goldensohn et al. | Aug 2011 | B2 |
8051332 | Zakonov et al. | Nov 2011 | B2 |
8112738 | Pohl et al. | Feb 2012 | B2 |
8112744 | Geisinger | Feb 2012 | B2 |
8219557 | Grefenstette et al. | Jul 2012 | B2 |
8296311 | Rapp et al. | Oct 2012 | B2 |
8412813 | Carlson et al. | Apr 2013 | B2 |
8417713 | Blair-Goldensohn et al. | Apr 2013 | B1 |
8452742 | Hashimoto et al. | May 2013 | B2 |
8463595 | Rehling et al. | Jun 2013 | B1 |
8498974 | Kim et al. | Jul 2013 | B1 |
8627270 | Fox et al. | Jan 2014 | B2 |
8677320 | Wilson et al. | Mar 2014 | B2 |
8688676 | Rush et al. | Apr 2014 | B2 |
8838606 | Cormack et al. | Sep 2014 | B1 |
8838633 | Dhillon et al. | Sep 2014 | B2 |
8935192 | Ventilla et al. | Jan 2015 | B1 |
8943039 | Grieselhuber et al. | Jan 2015 | B1 |
9015730 | Allen et al. | Apr 2015 | B1 |
9043753 | Fox et al. | May 2015 | B2 |
9047283 | Zhang et al. | Jun 2015 | B1 |
9135665 | England et al. | Sep 2015 | B2 |
9176729 | Mockus et al. | Nov 2015 | B2 |
9201931 | Lightner et al. | Dec 2015 | B2 |
9268805 | Crossley et al. | Feb 2016 | B2 |
9330174 | Zhang | May 2016 | B1 |
9361294 | Smith | Jun 2016 | B2 |
9390268 | Martini et al. | Jul 2016 | B1 |
9471559 | Castelli et al. | Oct 2016 | B2 |
9558098 | Alshayeb et al. | Jan 2017 | B1 |
9589250 | Palanisamy et al. | Mar 2017 | B2 |
9626164 | Fuchs | Apr 2017 | B1 |
9672554 | Dumon et al. | Jun 2017 | B2 |
9977656 | Mannopantar et al. | May 2018 | B1 |
10305758 | Bhide et al. | May 2019 | B1 |
10474509 | Dube et al. | Nov 2019 | B1 |
10484429 | Fawcett et al. | Nov 2019 | B1 |
10761839 | Migoya et al. | Sep 2020 | B1 |
10922740 | Gupta et al. | Feb 2021 | B2 |
11288167 | Vaughan | Mar 2022 | B2 |
11294984 | Kittur | Apr 2022 | B2 |
11295375 | Chitrapura et al. | Apr 2022 | B1 |
11301631 | Atallah et al. | Apr 2022 | B1 |
11334351 | Pandurangarao et al. | May 2022 | B1 |
11461093 | Edminster et al. | Oct 2022 | B1 |
11474817 | Sousa et al. | Oct 2022 | B2 |
11893117 | Segal et al. | Feb 2024 | B2 |
20010054054 | Olson | Dec 2001 | A1 |
20020059204 | Harris | May 2002 | A1 |
20020150966 | Muraca | Oct 2002 | A1 |
20020194578 | Irie et al. | Dec 2002 | A1 |
20040243568 | Wang et al. | Dec 2004 | A1 |
20060090077 | Little et al. | Apr 2006 | A1 |
20060104515 | King et al. | May 2006 | A1 |
20060200741 | Demesa et al. | Sep 2006 | A1 |
20060265232 | Katariya et al. | Nov 2006 | A1 |
20070050343 | Siddaramappa et al. | Mar 2007 | A1 |
20070185860 | Lissack | Aug 2007 | A1 |
20070234291 | Ronen et al. | Oct 2007 | A1 |
20070299825 | Rush et al. | Dec 2007 | A1 |
20090043612 | Szela, Jr. | Feb 2009 | A1 |
20090319342 | Shilman et al. | Dec 2009 | A1 |
20100106705 | Rush et al. | Apr 2010 | A1 |
20100121857 | Elmore et al. | May 2010 | A1 |
20100174670 | Malik et al. | Jul 2010 | A1 |
20100205198 | Mishne et al. | Aug 2010 | A1 |
20100205663 | Ward et al. | Aug 2010 | A1 |
20100262454 | Sommer et al. | Oct 2010 | A1 |
20110231817 | Hadar et al. | Sep 2011 | A1 |
20120143879 | Stoitsev | Jun 2012 | A1 |
20120259882 | Thakur et al. | Oct 2012 | A1 |
20120278064 | Leary et al. | Nov 2012 | A1 |
20130103662 | Epstein | Apr 2013 | A1 |
20130117254 | Manuel-Devadoss et al. | May 2013 | A1 |
20130326469 | Fox et al. | Dec 2013 | A1 |
20140040238 | Scott et al. | Feb 2014 | A1 |
20140075414 | Fox et al. | Mar 2014 | A1 |
20140122182 | Cherusseri et al. | May 2014 | A1 |
20140149894 | Watanabe et al. | May 2014 | A1 |
20140163959 | Hebert et al. | Jun 2014 | A1 |
20140188746 | Li | Jul 2014 | A1 |
20140297476 | Wang et al. | Oct 2014 | A1 |
20140331200 | Wadhwani et al. | Nov 2014 | A1 |
20140337355 | Heinze | Nov 2014 | A1 |
20150127567 | Menon et al. | May 2015 | A1 |
20150220608 | Crestani Campos et al. | Aug 2015 | A1 |
20150331866 | Shen et al. | Nov 2015 | A1 |
20160253688 | Nielsen et al. | Sep 2016 | A1 |
20160350105 | Kumar et al. | Dec 2016 | A1 |
20160378618 | Cmielowski et al. | Dec 2016 | A1 |
20170034023 | Nickolov | Feb 2017 | A1 |
20170063776 | Nigul | Mar 2017 | A1 |
20170154543 | King et al. | Jun 2017 | A1 |
20170220633 | Porath et al. | Aug 2017 | A1 |
20170286541 | Mosley et al. | Oct 2017 | A1 |
20170286548 | De | Oct 2017 | A1 |
20180046609 | Agarwal et al. | Feb 2018 | A1 |
20180067836 | Apkon et al. | Mar 2018 | A1 |
20180114000 | Taylor | Apr 2018 | A1 |
20180329883 | Leidner et al. | Nov 2018 | A1 |
20180349388 | Skiles et al. | Dec 2018 | A1 |
20190229998 | Cattoni | Jul 2019 | A1 |
20190278933 | Bendory et al. | Sep 2019 | A1 |
20190286683 | Kittur | Sep 2019 | A1 |
20190311044 | Xu et al. | Oct 2019 | A1 |
20190324981 | Counts et al. | Oct 2019 | A1 |
20200110839 | Wang et al. | Apr 2020 | A1 |
20200125482 | Smith et al. | Apr 2020 | A1 |
20200133830 | Sharma et al. | Apr 2020 | A1 |
20200293354 | Song et al. | Sep 2020 | A1 |
20200301672 | Li et al. | Sep 2020 | A1 |
20200301908 | Frost et al. | Sep 2020 | A1 |
20200348929 | Sousa et al. | Nov 2020 | A1 |
20200356363 | Dewitt et al. | Nov 2020 | A1 |
20210049091 | Hikawa et al. | Feb 2021 | A1 |
20210073293 | Fenton et al. | Mar 2021 | A1 |
20210081189 | Nucci et al. | Mar 2021 | A1 |
20210141863 | Wu et al. | May 2021 | A1 |
20210149658 | Cannon et al. | May 2021 | A1 |
20210149668 | Gupta et al. | May 2021 | A1 |
20210349801 | Rafey | Nov 2021 | A1 |
20210357210 | Clement et al. | Nov 2021 | A1 |
20210382712 | Richman et al. | Dec 2021 | A1 |
20210397418 | Nikumb et al. | Dec 2021 | A1 |
20220012297 | Basu et al. | Jan 2022 | A1 |
20220083577 | Yoshida et al. | Mar 2022 | A1 |
20220215068 | Kittur | Jul 2022 | A1 |
20220269687 | Balasubramanian | Aug 2022 | A1 |
20220269743 | Balasubramanian | Aug 2022 | A1 |
20220269744 | Balasubramanian | Aug 2022 | A1 |
20230308700 | Perez | Sep 2023 | A1 |
Number | Date | Country |
---|---|---|
108052442 | May 2018 | CN |
10-2020-0062917 | Jun 2020 | KR |
WO-2007013418 | Feb 2007 | WO |
WO-2020086773 | Apr 2020 | WO |
Entry |
---|
Iderli Souza, An Analysis of Automated Code Inspection Tools for PHP Available on Github Marketplace, Sep. 2021, pp. 10-17 (Year: 2021). |
Khatri et al, “Validation of Patient Headache Care Education System (PHCES) Using a Software Reuse Reference Model”, Journal of System Architecture, pp. 157-162 (Year: 2001). |
Lotter et al, “Code Reuse in Stack Overflow and Popular Open Source Java Projects”, IEEE, pp. 141-150 (Year: 2018). |
Rothenberger et al, “Strategies for Software Reuse: A Principal Component Analysis of Reuse Practices”, IEEE, pp. 825-837 (Year:2003). |
Tung et al, “A Framework of Code Reuse in Open Source Software”, ACM, pp. 1-6 (Year: 2014). |
Lampropoulos et al, “REACT—A Process for Improving Open-Source Software Reuse”, IEEE, pp. 251-254 (Year: 2018). |
Leclair et al., “A Neural Model for Generating Natural Language Summaries of Program Subroutines,” Collin McMillan, Dept. of Computer Science and Engineering, University of Notre Dame Notre Dame, IN, USA, Feb. 5, 2019. |
Schweik et al, Proceedings of the OSS 2011 Doctoral Consortium, Oct. 5, 2011, Salvador, Brazil, pp. 1-100, Http:/Avorks.bepress.com/charles_schweik/20 (Year: 2011). |
Stanciulescu et al, “Forked and Integrated Variants in an Open-Source Firmware Project”, IEEE, pp. 151-160 (Year: 2015). |
Zaimi et al, “:An Empirical Study on the Reuse of Third-Party Libraries in Open-Source Software Development”, ACM, pp. 1-8 (Year: 2015). |
M. Squire, “Should We Move to Stack Overflow?” Measuring the Utility of Social Media for Developer Support, 2015 IEEE/ACM 37th IEEE International Conference on Software Engineering, Florence, Italy, 2015, pp. 219-228, doi: 10.1109/ICSE.2015.150. (Year: 2015). |
S. Bayati, D. Parson, T. Sujsnjak and M. Heidary, “Big data analytics on large-scale socio-technical software engineering archives,” 2015 3rd International Conference on Information and Communication Technology (IColCT), Nusa Dua, Bali, Indonesia, 2015, pp. 65-69, doi: 10.1109/IColCT.2015.7231398. (Year: 2015). |
Andreas DAutovic, “Automatic Assessment of Software Documentation Quality”, published by IEEE, ASE 2011, Lawrence, KS, USA, pp. 665-669, (Year: 2011). |
Number | Date | Country | |
---|---|---|---|
20220269687 A1 | Aug 2022 | US |
Number | Date | Country | |
---|---|---|---|
63153192 | Feb 2021 | US |