Uploaded image for project: 'IvyDE (Retired)'
  1. IvyDE (Retired)
  2. IVYDE-235

Add configuration option to use an extended revision id when resolving eclipse projects

    XMLWordPrintableJSON

Details

    • New Feature
    • Status: Resolved
    • Minor
    • Resolution: Fixed
    • 2.0.0.final
    • 2.2.0.beta1
    • classpath container
    • None

    Description

      The current resolve code in IvyDE leverages the default revision id of the form [org]-[module] in the resolution cache. A custom revision id cannot be currently specified in the Ivy ResolveOptions as it can effectively be done via the API and in the ant tasks. This leads to resolution cache collisions when more than project exist on the same module in the eclipse workspace.

      A standard technique to improve workspace dependency resolution is to leverage the revision attribute in the module descriptor (and the branch attribute as proposed in IVYDE-234). However this technique has limitations due to the aforementioned resolution cache collision which force the developer to manually re-resolve affected projects to ensure that the workspace dependencies (as well as the classpath container) are properly computed. By allowing the developer to optionally cache and load resolve reports using an extended resolve id that uses more information found in the attributes of the module descriptor, resolution cache collisions can be avoided.

      A configuration option on the global configuration page under the classpath configuration submenu is proposed: specifically a boolean checkbox underneath the 'Resolve dependencies in the workspace' checkbox. This new boolean would default to false (unchecked) and would be titled 'Use extended resolve id in the resolution cache'.

      To ensure the lowest probability of resolution cache collision, the proposed forms of the extended revision id against the contents of the unpublished module descriptor info tag are as follows:

      <info organisation="myorg" module="mymod" branch="mybranch" revision="2.1" status="milestone"/>
      resolveId = myorg-mymod-milestone-mybranch-2.1

      <info organisation="myorg" module="mymod" revision="3"/>
      resolveId = myorg-mymod-integration--3

      <info organisation="myorg" module="mymod"/>
      resolveId = myorg-mymod-integration--working@myworkstation.mydomain.com

      Attachments

        1. ivyde-235.patch
          16 kB
          Jeffrey M. Metcalf

        Activity

          People

            hibou Nicolas Lalevée
            jmetcalf Jeffrey M. Metcalf
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved:

              Time Tracking

                Estimated:
                Original Estimate - 48h
                48h
                Remaining:
                Remaining Estimate - 48h
                48h
                Logged:
                Time Spent - Not Specified
                Not Specified