/******************************************************************************* * Copyright (c) 2004, 2010 QNX Software Systems and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * QNX Software Systems - initial API and implementation *******************************************************************************/ package org.eclipse.cdt.internal.ui.dialogs.cpaths; import java.util.ArrayList; import java.util.List; import java.util.Set; import org.eclipse.core.runtime.IPath; import org.eclipse.jface.resource.ImageDescriptor; import org.eclipse.cdt.core.model.CoreModelUtil; import org.eclipse.cdt.core.model.IPathEntry; import org.eclipse.cdt.ui.dialogs.AbstractCOptionPage; /** * Abstract Option Page for C/C++ Project Paths page for 3.X projects. * * @deprecated as of CDT 4.0. This page was used to set preferences/properties * for 3.X style projects. */ @Deprecated public abstract class CPathBasePage extends AbstractCOptionPage { public CPathBasePage(String title) { super(title); } public CPathBasePage(String title, ImageDescriptor image) { super(title, image); } protected void fixNestingConflicts(List<CPElement> newEntries, List<CPElement> existingList, Set<CPElement> modifiedSourceEntries) { ArrayList<CPElement> existing = new ArrayList<CPElement>(existingList); for (int i = 0; i < newEntries.size(); i++) { CPElement curr = newEntries.get(i); addExclusionPatterns(curr, existing, modifiedSourceEntries); // add the entry to the existing list so it can be analyse also. existing.add(curr); } } private void addExclusionPatterns(CPElement newEntry, List<CPElement> existing, Set<CPElement> modifiedEntries) { IPath entryPath = newEntry.getPath(); for (int i = 0; i < existing.size(); i++) { CPElement curr = existing.get(i); if (curr.getEntryKind() == IPathEntry.CDT_SOURCE) { IPath currPath = curr.getPath(); if (currPath.isPrefixOf(entryPath) && !currPath.equals(entryPath)) { IPath[] exclusionFilters = (IPath[]) curr.getAttribute(CPElement.EXCLUSION); if (!CoreModelUtil.isExcludedPath(entryPath.removeFirstSegments(1), exclusionFilters)) { IPath pathToExclude = entryPath.removeFirstSegments(currPath.segmentCount()).addTrailingSeparator(); IPath[] newExclusionFilters = new IPath[exclusionFilters.length + 1]; System.arraycopy(exclusionFilters, 0, newExclusionFilters, 0, exclusionFilters.length); newExclusionFilters[exclusionFilters.length] = pathToExclude; curr.setAttribute(CPElement.EXCLUSION, newExclusionFilters); modifiedEntries.add(curr); } } } } } public abstract List<?> getSelection(); public abstract void setSelection(List<?> selection); public abstract boolean isEntryKind(int kind); protected List<CPElement> filterList(List<CPElement> cpelements) { ArrayList<CPElement> filtered = new ArrayList<CPElement>(); for (int i = 0; i < cpelements.size(); i++) { CPElement cpe = cpelements.get(i); if (isEntryKind(cpe.getEntryKind())) { filtered.add(cpe); } } return filtered; } }