use of org.eclipse.core.resources.mapping.ResourceMapping in project egit by eclipse.
the class ModelTestCase method prepareContext.
protected IMergeContext prepareContext(Repository repository, IFile workspaceFile, String srcRev, String dstRev) throws Exception {
GitSynchronizeData gsd = new GitSynchronizeData(repository, srcRev, dstRev, true, Collections.<IResource>singleton(workspaceFile));
GitSynchronizeDataSet gsds = new GitSynchronizeDataSet(gsd);
GitResourceVariantTreeSubscriber subscriber = new GitResourceVariantTreeSubscriber(gsds);
subscriber.init(new NullProgressMonitor());
ResourceMapping mapping = AdapterUtils.adapt(workspaceFile, ResourceMapping.class);
SubscriberScopeManager manager = new SubscriberScopeManager(subscriber.getName(), new ResourceMapping[] { mapping }, subscriber, true);
manager.initialize(new NullProgressMonitor());
GitSubscriberMergeContext mergeContext = new GitSubscriberMergeContext(subscriber, manager, gsds);
// Wait for asynchronous update of the diff tree to end
Job.getJobManager().join(mergeContext, new NullProgressMonitor());
return mergeContext;
}
use of org.eclipse.core.resources.mapping.ResourceMapping in project egit by eclipse.
the class ModelTestCase method prepareModelContext.
protected IMergeContext prepareModelContext(Repository repository, IFile workspaceFile, String srcRev, String dstRev) throws Exception {
Set<IResource> includedResources = new HashSet<IResource>(Arrays.asList(workspaceFile));
Set<IResource> newResources = new HashSet<IResource>(includedResources);
Set<ResourceMapping> allMappings = new HashSet<ResourceMapping>();
ResourceMappingContext mappingContext = ResourceMappingContext.LOCAL_CONTEXT;
ModelProvider provider = ModelProvider.getModelProviderDescriptor(SampleModelProvider.SAMPLE_PROVIDER_ID).getModelProvider();
do {
Set<IResource> copy = newResources;
newResources = new HashSet<IResource>();
for (IResource resource : copy) {
ResourceMapping[] mappings = provider.getMappings(resource, mappingContext, new NullProgressMonitor());
allMappings.addAll(Arrays.asList(mappings));
newResources.addAll(collectResources(mappings, mappingContext));
}
} while (includedResources.addAll(newResources));
ResourceMapping[] mappings = allMappings.toArray(new ResourceMapping[allMappings.size()]);
GitSynchronizeData gsd = new GitSynchronizeData(repository, srcRev, dstRev, true, includedResources);
GitSynchronizeDataSet gsds = new GitSynchronizeDataSet(gsd);
GitResourceVariantTreeSubscriber subscriber = new GitResourceVariantTreeSubscriber(gsds);
subscriber.init(new NullProgressMonitor());
GitSubscriberResourceMappingContext resourceMappingContext = new GitSubscriberResourceMappingContext(subscriber, gsds);
SubscriberScopeManager manager = new SubscriberScopeManager(subscriber.getName(), mappings, subscriber, resourceMappingContext, true);
manager.initialize(new NullProgressMonitor());
GitSubscriberMergeContext mergeContext = new GitSubscriberMergeContext(subscriber, manager, gsds);
// Wait for asynchronous update of the diff tree to end
Job.getJobManager().join(mergeContext, new NullProgressMonitor());
return mergeContext;
}
use of org.eclipse.core.resources.mapping.ResourceMapping in project egit by eclipse.
the class ModelAwareGitSynchronizer method synchronize.
@Override
protected void synchronize(IResource[] resources, Repository repository, String leftRev, String rightRev, boolean includeLocal) throws IOException {
if (rightRev.equals(GitFileRevision.INDEX)) {
openGitTreeCompare(resources, leftRev, CompareTreeView.INDEX_VERSION, includeLocal);
} else {
final Set<IResource> includedResources = new HashSet<>(Arrays.asList(resources));
final Set<ResourceMapping> allMappings = new HashSet<>();
Set<IResource> newResources = new HashSet<>(includedResources);
do {
final Set<IResource> copy = newResources;
newResources = new HashSet<>();
for (IResource resource : copy) {
Assert.isNotNull(resource);
ResourceMapping[] mappings = ResourceUtil.getResourceMappings(resource, context);
allMappings.addAll(Arrays.asList(mappings));
newResources.addAll(collectResources(mappings));
}
} while (includedResources.addAll(newResources));
if (GitFileRevision.INDEX.equals(leftRev)) {
// Even git tree compare cannot handle index as
// source...
// Synchronize using the local data for now.
final ResourceMapping[] mappings = allMappings.toArray(new ResourceMapping[allMappings.size()]);
final GitSynchronizeData data = new GitSynchronizeData(repository, leftRev, rightRev, true, includedResources);
GitModelSynchronize.launch(new GitSynchronizeDataSet(data), mappings);
} else {
final ResourceMapping[] mappings = allMappings.toArray(new ResourceMapping[allMappings.size()]);
final GitSynchronizeData data = new GitSynchronizeData(repository, leftRev, rightRev, includeLocal, includedResources);
GitModelSynchronize.launch(new GitSynchronizeDataSet(data), mappings);
}
}
}
use of org.eclipse.core.resources.mapping.ResourceMapping in project egit by eclipse.
the class GitChangeSetContentProvider method getTraversals.
@Override
protected ResourceTraversal[] getTraversals(ISynchronizationContext context, Object object) {
if (object instanceof IAdaptable) {
if (traversalCache.containsKey(object)) {
return traversalCache.get(object);
}
ResourceMapping rm = getResourceMapping(object);
if (rm == null) {
return null;
}
GitSubscriberMergeContext ctx = (GitSubscriberMergeContext) getContext();
ResourceMappingContext rmCtx = new GitSubscriberResourceMappingContext((GitResourceVariantTreeSubscriber) ctx.getSubscriber(), ctx.getSyncData());
try {
ResourceTraversal[] traversals = rm.getTraversals(rmCtx, new NullProgressMonitor());
traversalCache.put(object, traversals);
return traversals;
} catch (CoreException e) {
Activator.logError(e.getMessage(), e);
}
}
return null;
}
use of org.eclipse.core.resources.mapping.ResourceMapping in project egit by eclipse.
the class GitScopeUtil method createScopeManager.
/**
* Creates a new {@link SubscriberScopeManager} for the given set of
* {@link IResource}s
*
* @param resources
* @param monitor
* @return {@link SubscriberScopeManager}
*/
private static SubscriberScopeManager createScopeManager(final IResource[] resources, IProgressMonitor monitor) {
ResourceMapping[] mappings = GitScopeUtil.getResourceMappings(resources);
GitSynchronizeDataSet set = new GitSynchronizeDataSet();
final GitResourceVariantTreeSubscriber subscriber = new GitResourceVariantTreeSubscriber(set);
monitor.setTaskName(UIText.GitModelSynchronize_fetchGitDataJobName);
subscriber.init(monitor);
SubscriberScopeManager manager = new SubscriberScopeManager(UIText.GitScopeOperation_GitScopeManager, mappings, subscriber, true);
return manager;
}
Aggregations