mirror of
https://github.com/eclipse-cdt/cdt
synced 2025-04-29 19:45:01 +02:00
patch from vhirsl@ca.ibm.com
- PR 62334: `Message: Unable to find full path for "cygpath" echoed repeatedly to xterminal` - PR 64226: `[Scanner Config] Path discovery supporting UNC filepaths` - PR 65121: `[Scanner Config] Importing 1.2.1 project does not update properties` - PR 62742: `CDT-specific file changes to .project are not saved` - Scanner config portion, since Platform PR 64128 `Changing arguments on an ICommand no longer makes it to the .project` was fixed in Eclipse 3.0 RC1
This commit is contained in:
parent
2dfa4fa8a1
commit
df04b9e18c
4 changed files with 19 additions and 35 deletions
|
@ -291,10 +291,8 @@ public class ScannerConfigInfoFactory {
|
|||
IProjectDescription description = project.getDescription();
|
||||
ICommand builder = ScannerConfigNature.getBuildSpec(description, builderID);
|
||||
args.put(name, value);
|
||||
ICommand newBuilder = description.newCommand();
|
||||
newBuilder.setBuilderName(builder.getBuilderName());
|
||||
newBuilder.setArguments(args);
|
||||
description = MakeProjectNature.setBuildSpec(description, newBuilder);
|
||||
builder.setArguments(args);
|
||||
MakeProjectNature.setBuildSpec(description, builder);
|
||||
project.setDescription(description, null);
|
||||
}
|
||||
|
||||
|
|
|
@ -294,7 +294,10 @@ public class ScannerInfoCollector implements IScannerInfoCollector {
|
|||
String includePath = (String) i.next();
|
||||
IPath realPath = new Path(includePath);
|
||||
if (!realPath.toFile().exists()) {
|
||||
String translatedPath = new CygpathTranslator(currentProject, includePath).run();
|
||||
String translatedPath = includePath;
|
||||
if (Platform.getOS().equals(Platform.OS_WIN32)) {
|
||||
translatedPath = new CygpathTranslator(currentProject, includePath).run();
|
||||
}
|
||||
if (translatedPath != null) {
|
||||
if (!translatedPath.equals(includePath)) {
|
||||
// Check if the translated path exists
|
||||
|
|
|
@ -322,7 +322,7 @@ public class ScannerInfoConsoleParserUtility implements IScannerInfoConsoleParse
|
|||
for (Iterator i = includes.iterator(); i.hasNext(); ) {
|
||||
String include = (String) i.next();
|
||||
IPath includePath = new Path(include);
|
||||
if (!includePath.isAbsolute()) {
|
||||
if (!includePath.isAbsolute() && !includePath.isUNC()) { // do not translate UNC paths
|
||||
// First try the current working directory
|
||||
IPath cwd = getWorkingDirectory();
|
||||
if (!cwd.isAbsolute()) {
|
||||
|
|
|
@ -71,8 +71,6 @@ public class DiscoveryOptionsBlock extends AbstractCOptionPage {
|
|||
private static final String PREFIX_BP = "BuildPathInfoBlock"; //$NON-NLS-1$
|
||||
private static final String SC_GROUP_LABEL = PREFIX_BP + ".scGroup.label"; //$NON-NLS-1$
|
||||
private static final String SC_ENABLED_LABEL = PREFIX_BP + ".scGroup.enabled.label"; //$NON-NLS-1$
|
||||
// private static final String SC_OPTIONS_LABEL = PREFIX +
|
||||
// ".scGroup.options.label"; //$NON-NLS-1$
|
||||
private static final String MISSING_BUILDER_MSG = "ScannerConfigOptionsDialog.label.missingBuilderInformation"; //$NON-NLS-1$
|
||||
|
||||
private static final String PREFIX = "ScannerConfigOptionsDialog"; //$NON-NLS-1$
|
||||
|
@ -156,11 +154,15 @@ public class DiscoveryOptionsBlock extends AbstractCOptionPage {
|
|||
IScannerConfigBuilderInfo buildInfo;
|
||||
IProject project = getContainer().getProject();
|
||||
if (project != null) {
|
||||
if (needsSCNature) {
|
||||
ScannerConfigNature.addScannerConfigNature(getContainer().getProject());
|
||||
needsSCNature = false;
|
||||
}
|
||||
buildInfo = MakeCorePlugin.createScannerConfigBuildInfo(project, ScannerConfigBuilder.BUILDER_ID);
|
||||
if (isScannerConfigDiscoveryEnabled()) {
|
||||
createDiscoveredPathContainer(project);
|
||||
createDiscoveredPathContainer(project, monitor);
|
||||
} else {
|
||||
removeDiscoveredPathContainer(project);
|
||||
removeDiscoveredPathContainer(project, monitor);
|
||||
}
|
||||
// create a new discovered scanner config store
|
||||
MakeCorePlugin.getDefault().getDiscoveryManager().removeDiscoveredInfo(project);
|
||||
|
@ -193,9 +195,10 @@ public class DiscoveryOptionsBlock extends AbstractCOptionPage {
|
|||
}
|
||||
/**
|
||||
* @param project
|
||||
* @param monitor
|
||||
* @throws CModelException
|
||||
*/
|
||||
private void createDiscoveredPathContainer(IProject project) throws CModelException {
|
||||
private void createDiscoveredPathContainer(IProject project, IProgressMonitor monitor) throws CModelException {
|
||||
IPathEntry container = CoreModel.newContainerEntry(DiscoveredPathContainer.CONTAINER_ID);
|
||||
ICProject cProject = CoreModel.getDefault().create(project);
|
||||
if (cProject != null) {
|
||||
|
@ -203,13 +206,12 @@ public class DiscoveryOptionsBlock extends AbstractCOptionPage {
|
|||
List newEntries = new ArrayList(Arrays.asList(entries));
|
||||
if (!newEntries.contains(container)) {
|
||||
newEntries.add(container);
|
||||
cProject.setRawPathEntries((IPathEntry[])newEntries.toArray(new IPathEntry[newEntries.size()]),
|
||||
new NullProgressMonitor());
|
||||
cProject.setRawPathEntries((IPathEntry[])newEntries.toArray(new IPathEntry[newEntries.size()]), monitor);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void removeDiscoveredPathContainer(IProject project) throws CModelException {
|
||||
private void removeDiscoveredPathContainer(IProject project, IProgressMonitor monitor) throws CModelException {
|
||||
IPathEntry container = CoreModel.newContainerEntry(DiscoveredPathContainer.CONTAINER_ID);
|
||||
ICProject cProject = CoreModel.getDefault().create(project);
|
||||
if (cProject != null) {
|
||||
|
@ -217,8 +219,7 @@ public class DiscoveryOptionsBlock extends AbstractCOptionPage {
|
|||
List newEntries = new ArrayList(Arrays.asList(entries));
|
||||
if (newEntries.contains(container)) {
|
||||
newEntries.remove(container);
|
||||
cProject.setRawPathEntries((IPathEntry[])newEntries.toArray(new IPathEntry[newEntries.size()]),
|
||||
new NullProgressMonitor());
|
||||
cProject.setRawPathEntries((IPathEntry[])newEntries.toArray(new IPathEntry[newEntries.size()]), monitor);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -326,32 +327,14 @@ public class DiscoveryOptionsBlock extends AbstractCOptionPage {
|
|||
// VMIR* old projects will have discovery disabled by default
|
||||
scEnabledButton.setSelection(needsSCNature ? false : fBuildInfo.isAutoDiscoveryEnabled());
|
||||
scEnabledButton.addSelectionListener(new SelectionAdapter() {
|
||||
|
||||
public void widgetSelected(SelectionEvent e) {
|
||||
handleScannerConfigEnable();
|
||||
enableAllControls();
|
||||
}
|
||||
});
|
||||
// handleScannerConfigEnable(); Only if true in VMIR*
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Handles scanner configuration discovery selection change
|
||||
*/
|
||||
private void handleScannerConfigEnable() {
|
||||
boolean enable = scEnabledButton.getSelection();
|
||||
if (enable && needsSCNature) {
|
||||
// first install the SC nature
|
||||
try {
|
||||
ScannerConfigNature.addScannerConfigNature(getContainer().getProject());
|
||||
needsSCNature = false;
|
||||
} catch (CoreException e) {
|
||||
MakeCorePlugin.log(e.getStatus());
|
||||
}
|
||||
}
|
||||
enableAllControls();
|
||||
}
|
||||
|
||||
/**
|
||||
* Fills console parser maps
|
||||
*/
|
||||
|
|
Loading…
Add table
Reference in a new issue