Compare Example - Structural Compare for Key/Value Pairs
Introduction
This example demonstrates how to support structural compare for files consisting of key/value pairs. It shows how to implement and register a custom structure creator that parses key/value pairs into a tree structure that is used as the input to the structural compare framework provided by the Compare plugin. In addition, it registers a standard text viewer for the individual key/value pairs.This example is only for demonstration purposes. Structural compare support for Java property files (another key/value format) is provided by the Eclipse Java Tooling.
Running the example
- Create a project (not necessarily a Java project)
- Create a key/value pair file f1.kv
- Open Window > Preferences > Workbench > File Association and associate the default text editor with the file extension "kv"
- Open f1.kv with the editor and enter this contents
lastname=Doe firstname=John city=Chicago state=IL- Make a copy of this file and rename it f2.kv
- Open f2.kv and change the firstname "John" to "Mary"
- Add another key/value pair "country=US" to f2.kv
- Select both files f1.kv and f2.kv
- From the context menu select Compare With > Each Other
- A new compare editor opens that shows the structural differences of both files in its top pane. Selecting one of the properties "firstname" or "country" feeds the text of the corresponding key/value pair into the standard text compare viewer in the bottom pane.
Code organization of the example
The example code is organized in a single package org.eclipse.compare.examples.structurecreator:
- KeyValuePairStructureCreator
is the structure creator that parses the contents of a stream into a tree of IStructureComparators.- TextMergeViewerCreator
is a factory for TextMergeViewers. It is registered for the type "kvtxt" which is the type of an individual key/value pair.- Util
provides utility methods for NLS support and for reading an InputStream as a String.