data:image/s3,"s3://crabby-images/a6b56/a6b56306813dff604db9a9ee84eac01a9938e64a" alt="Logo"
Eclipse plugin bundling metric-based static code analyses that reveal fragments containing hidden type correlations
« Approach |
Tool Demo (Coming Soon) »
Minimal Requirements
- Java Version: 17
- Eclipse IDE for RCP and RAP Developers 2023-06 R
- it is strongly recommended to use the specified versions
- the plugin does not currently work when installed on Eclipse IDE for Java Developers
- using a Java >= 17 with any Eclipse IDE for RCP and RAP Developers <= 2023-03 R is impossible due to a bug in Eclipse, ultimately addressed here
- In Eclipse IDE for RCP and RAP Developers, go to
Help
>Install New Software...
>Add...
>Local...
- Open the
jfamilycounselor.repository
folder - Install the deployable feature
jFamilyCounselor
that should appear under theLOOSE Research Group
category (check/uncheck theGroup items by category
) - Accept the license terms
- Trust the unsigned content of the unknown origin
- Restart Eclipse
- Upon start, a log indicating that the plugin was loaded should be present in the
Error Log
view - Create workspace and import the Java projects from
jfamilycounselor.example
- Using the
Package Explorer
view, right-click on theWineBar
project and selectBrowse in Insider
(Note: Make sure the projects have the Java nature) - Alternatively, using the
Package Explorer
view, right-click on theWaiterTray
class (NOT on the compilation unitWaiterTray.java
) and selectBrowse in Insider
(Note: A class is represented as a 'C' green encircled icon. Browsing in Insider a compilation unit will result in no entries in theInsider
view) - In either scenarios, you should see an entry in the
Insider
view
If the starting log, or the Browse in Insider
option is missing, or nothing can be seen upon browsing, the installation was not successful. Retry with a clean installation in a different, newly installed Eclipse.
jFamilyCounselor is developed using the XCore framework. In order to install XCore, copy the binaries in the dropins
folder of Eclipse. The binaries are also present in the ro.lrg.insider/lib
folder.
Before working with jFamilyCounselor, it is recommended to experiment with XCore. Skimming through the paper and following the XCore's tutorial (present on its repository Wiki) would be recommended. Also refer to the XCore Training section.
In order to setup the jFamilyCounselor's workspace, configure it as specified in the tutorial and import the following projects:
jfamilycounselor
jfamilycounselor.test
jfamilycounselor.feature
ro.lrg.insider
(also found here)
- Use the launch configuration from the
jfamilycounselor
project to start anEclipse Application
- Follow the Check Installation steps
For further explanations on how to use jFamilyCounselor, please refer to the tool demo paper (coming soon).
Before working with jFamilyCounselor, it is recommended to experiment with XCore. Skimming through the paper and following the XCore's tutorial (present on its Wiki pages) would be recommended. Also, refer to the dev notes below whenever stumbling upon a bug/problem.
XCore is a tool that dynamically generates the meta-model of static analyses. It works based on the following abstractions: properties
, groups
and actions
.
- a
property
represents a computation applied on an analysed element. For a class, the number of its fields, the number of its descendants, a boolean indicating whether the class contains static methods or not, all represent properties of that class - a
group
models a one-to-many relationship between elements. Some possible groups of a class are: the group of fields or methods the class declares, the group of interfaces it implements, etc. - an
action
triggers some behavior that is related to that element. For instance, we can trigger a job that exports the results of a Java project analysis as a CSV file
- Make sure to have Eclipse RCP Plug-in Developer Resources installed
- Stop project automatic builds
- Create a new plugin project; add as Imported Packages:
ro.lrg.xcore.metametamodel
(Note: The names of the projects that use XCore should not contain dots, otherwise there might be bugs) - Enable the XCore annotation processor (which should be visible only if XCore's jar was placed in
dropins
) - Import the
ro.lrg.insider
plugin project and make the former project depend on it - Implement metrics (Note: In order to properly see the XCore property page, make sure to be in the
Java
perspective, not inPlugin Development
and go to the Java's projects properties through thePackage Explorer
view)
jFamilyCounselor is an Eclipse plugin that runs a metric-based static code analysis, capable of identifying fragments containing hidden familial type correlations in Java source code.
Note: Make sure the plugin is properly installed in order to continue.
- In the
Package Explorer
view, right-click on the "WineBar" Java project >Browse in Insider
- In the
Insider
view, right-click onWineBar
>Actions
>jfamilycounselor
>AssignmentsBasedReport
. - In the project's root folder there should be a directory containing the results:
jFamilyCounselor/reports
(Note: same goes for exporing visualisations - HFTC View)
- In the
Package Explorer
view, expand the project until reaching to theWaiterTray.java
compilation unit. - In the
Package Explorer
view, expand the compilation unit so as to see theWaiterTray
class (green 'C' icon) > right-click >Browse in Insider
. - In the
Insider
view, right-click onro.lrg.winebar.WaiterTray
>Properties
>jfamilycounselor
>AssignmentsBasedApertureCoverage
. - Right-click on
ro.lrg.winebar.WaiterTray
>Groups
>jfamilycounselor
>RelevantReferencesPairs
. - Right-click on any entry >
Properties
>jfamilycounselor
>AssignmentsBasedApertureCoverage
. - Right-click on the entry for which the
aperture coverage
is minimum (0.5) >Groups
>jfamilycounselor
>AssignmentsBasedUsedTypes
.
- The cast-based approach records a slower progress at the beginning, and becomes better afterwards owing to caching
- The implemented analyses perform heavy computations and use a lot of memory and CPU. It is recommended to allocate at least 6GB RAM for the Eclipse application that runs jFamilyCounselor in order to obtain results in a feasible amount of time
- The visualisation might not be displayed immediately after export due to some permission issues. It is best to configure Eclipse to use an external browser to fix this problem.
- The visualisation might not perform well for large projects when zooming
- In a visualisation, is a correlation has multiple clients and the tooltip overflows, press
F2
in order to lock the tooltip be so to scroll through the list; another press unlocks the tooltip - XCore currently does not run any computation on separate threads and long operations can block the UI. It is best to analyse projects following these steps:
- Export a report using one of the XCore actions. The export is located in the project's root folder
- Use the results to determine the types that might be interesting to be analysed manually
- Browse those types in Insider individually and navigate through its defined groups to see, for instance, its relevant references pairs, or possible/used types of a particular pair
- For better performance, it might be needed to reconfigure the
CacheSupervisor
depending on the available amount of RAM - The
ro.lrg.jfamilycounselor.plugin
package contains all classes which are responsible for the metamodel's generation through XCore - In terms of vocabulary, a
capability
is nothing but a glorified singleton that wraps some logic which can be tested in isolation and composed with other capabilities - Always use the Java perspective, not the default Plugin Development; some XCore features function only when using the former
The deployment of the plugin is done using the jfamilycounselor.feature
. The deployable features are exported in the jfamilycounselor.repository
folder.
The project that was intensively analysed is kettle-engine
. In order to reproduce jFamilyCounselor's results presented in Rosu et al., Towards the Detection of Hidden Familial Type Correlations in Java Code, SCAM 2022, follow these steps:
- Allocate more RAM
- Download the source code of Pentaho Kettle-Engine (1984dc13e773e7f12eb82e771a5ac8cdf86905e6)
- Import as
Existing Maven projects
- Browse
kettle-engine
in Insider - Export reports with the desired approaches
- The reports can be found in the project's root folder
The plugin currently requires a lot of memory in order to perform the Assignments Based
analysis on the target project. Therefore:
- Go to the Eclipse's installation path
- Search for the
eclipse.ini
file - Update the
-Xms
and-Xmx
flags:
-Xms6g
-Xmx8g
Other projects that were identified to contain hidden type correlations and which can help improving jFamilyCounselor are present in corpus used in the study: Luis Mastrangelo, Matthias Hauswirth, and Nathaniel Nystrom. 2019. Casting about in the dark: an empirical study of cast operations in Java programs. Proc. ACM Program. Lang. 3, OOPSLA, Article 158 (October 2019), 31 pages, DOI.
All code is available to you under the MIT license, available at http://opensource.org/licenses/mit-license.php and also in the LICENSE.md file