RFR: JDK-8324950: IGV: save the state to a file [v5]
Andrey Turbanov
aturbanov at openjdk.org
Mon Feb 26 09:24:54 UTC 2024
On Tue, 20 Feb 2024 19:00:07 GMT, Tobias Holenstein <tholenstein at openjdk.org> wrote:
>> The current workflow in IGV is the following:
>> 1) import an XML file with graphs or send via network
>> 2) open or more graphs in a tab
>> 3) extract a set of nodes to be displayed in the tab
>> 4) close IGV and start from 1) again
>>
>> The idea of this RFE is to save the important **states** of IGV to a workspace directory:
>> - imported graphs (_graphs.xml_)
>> - opened graph tabs + extracted nodes (_state.igv_)
>>
>>
>> ### Saving the state of IGV
>> - For IGV to save the state it needs a workspace, which can be passed in 3 different ways:
>> 1) Using a global variable : `IGV_WORKSPACE=path/to/igv_workspace ./igv.sh`
>> 2) Passed as an argument : `./igv.sh path/to/igv_workspace `
>> 3) With default location `IdealGraphVisualizer/workspace` : `./igv.sh`
>>
>> Open IGV with the following example workspace (unzipped) [igv_workspace.zip](https://github.com/openjdk/jdk/files/14311092/igv_workspace.zip) should look something like this:
>> 
>>
>>
>> ### Workspace
>> A workspace is a directory where IGV saves imported graphs as _graphs.xml_ and opened graph tabs to _state.igv_. A workspace is loaded when IGV is opened. The current workspace is saved when IGV is closed or when the workspace is changed to a different directory. When changing a directory the state of the new workspace is loaded.
>> - Click here to select a different workspace directory
>> 
>>
>> - Imports an XML file (group and graphs) into the current workspace
>> 
>>
>> - saves the state of the current workspace
>> 
>> - imported graphs (_graphs.xml_)
>> - opened graph tabs + extracted nodes (_state.igv_)
>>
>>
>> - Export the selected groups to a separate XML file
>> 
>>
>> - Delete the selected groups and graphs
>> 
>>
>> - Clear the workspace and delete all groups and graphs
>> 
>>
>>
>>
>> ---------
>> ### Progress
>> - ...
>
> Tobias Holenstein has updated the pull request with a new target base due to a merge or a rebase. The pull request now contains 21 commits:
>
> - userdir
> - move loadWorkspace to init
> - Update src/utils/IdealGraphVisualizer/igv.sh
>
> Co-authored-by: Roberto Castañeda Lozano <robcasloz at users.noreply.github.com>
> - USERDIR to WORKSPACE
> - invokeLater and correct getWorkspaceGraphsPath
> - clear() in loadWorkspace()
> - setWorkspacePath
> - import description
> - saveall.gif
> - temp
> - ... and 11 more: https://git.openjdk.org/jdk/compare/b419e951...dfc05f72
src/utils/IdealGraphVisualizer/Coordinator/src/main/java/com/sun/hotspot/igv/coordinator/OutlineTopComponent.java line 351:
> 349:
> 350: static public String WORKSPACE_XML_FILE = "graphs.xml";
> 351: static public String WORKSPACE_STATE_FILE = "state.igv";
Let's use blessed modifiers order
Suggestion:
public static String WORKSPACE_XML_FILE = "graphs.xml";
public static String WORKSPACE_STATE_FILE = "state.igv";
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/17630#discussion_r1502276861
More information about the hotspot-compiler-dev
mailing list