diff --git a/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/CDOMTestBase.java b/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/CDOMTestBase.java deleted file mode 100644 index bfe1563930b..00000000000 --- a/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/CDOMTestBase.java +++ /dev/null @@ -1,62 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2005, 2013 IBM Corporation 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: - * IBM Corporation - initial API and implementation - *******************************************************************************/ -package org.eclipse.cdt.core.parser.tests.ast2; - -import org.eclipse.cdt.core.dom.CDOM; -import org.eclipse.cdt.core.dom.IASTServiceProvider.UnsupportedDialectException; -import org.eclipse.cdt.core.dom.ast.IASTTranslationUnit; -import org.eclipse.cdt.core.parser.tests.FileBasePluginTestCase; -import org.eclipse.core.resources.IFile; - -/** - * @author dsteffle - */ -public class CDOMTestBase extends FileBasePluginTestCase { - - public CDOMTestBase() { - } - - public CDOMTestBase(String name) { - super(name); - } - - public CDOMTestBase(String name, Class className) { - super(name, className); - } - - protected IASTTranslationUnit parse(String fileName, String contents) { - IFile file = null; - - try { - file = importFile(fileName, contents); - } catch (Exception e) { - e.printStackTrace(); - } - - return parse(file); - } - - protected IASTTranslationUnit parse(IFile file) { - IASTTranslationUnit tu = null; - - try { - tu = CDOM.getInstance().getASTService().getTranslationUnit( - file, - CDOM.getInstance().getCodeReaderFactory( - CDOM.PARSE_SAVED_RESOURCES)); - } catch (UnsupportedDialectException e) { - e.printStackTrace(); - } - - return tu; - } - -} diff --git a/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/CodeReaderCacheTest.java b/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/CodeReaderCacheTest.java deleted file mode 100644 index d490caf6013..00000000000 --- a/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/CodeReaderCacheTest.java +++ /dev/null @@ -1,175 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2004, 2013 IBM Corporation 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: - * IBM - Initial API and implementation - *******************************************************************************/ -package org.eclipse.cdt.core.parser.tests.ast2; - -import junit.framework.Test; -import junit.framework.TestSuite; - -import org.eclipse.cdt.core.dom.CDOM; -import org.eclipse.cdt.core.parser.CodeReader; -import org.eclipse.cdt.core.parser.CodeReaderCache; -import org.eclipse.cdt.core.parser.ICodeReaderCache; -import org.eclipse.core.resources.IFile; -import org.eclipse.core.runtime.IProgressMonitor; -import org.eclipse.core.runtime.IStatus; -import org.eclipse.core.runtime.Status; -import org.eclipse.core.runtime.jobs.Job; - -/** - * @author dsteffle - */ -public class CodeReaderCacheTest extends CDOMTestBase { - - public CodeReaderCacheTest() { - } - - public CodeReaderCacheTest(String name) { - super(name, CodeReaderCacheTest.class); - } - - public static Test suite() { - TestSuite suite = new TestSuite(CodeReaderCacheTest.class); - suite.addTest(new CodeReaderCacheTest("cleanupProject")); - return suite; - } - - private class UpdateFileJob extends Job { - private IFile file; - private final String fileName; - private final String code; - - public UpdateFileJob(String name, IFile file, String fileName, String code) { - super(name); - this.file = file; - this.fileName = fileName; - this.code = code; - } - - @Override - protected IStatus run(IProgressMonitor monitor) { - while (!monitor.isCanceled()) { - try { - file = importFile(fileName, code); - } catch (Exception e) { - } - } - return Status.OK_STATUS; - } - - public IFile getFile() { - return file; - } - } - - @Override - protected void setUp() throws Exception { - super.setUp(); - ICodeReaderCache cache = getCodeReaderCache(); - assertTrue(cache instanceof CodeReaderCache); - ((CodeReaderCache) cache).setCacheSize(CodeReaderCache.DEFAULT_CACHE_SIZE_IN_MB); - } - - @Override - public void tearDown() throws Exception { - ICodeReaderCache cache = getCodeReaderCache(); - assertTrue(cache instanceof CodeReaderCache); - ((CodeReaderCache) cache).setCacheSize(0); - super.tearDown(); - } - - private ICodeReaderCache getCodeReaderCache() { - return CDOM.getInstance().getCodeReaderFactory(CDOM.PARSE_SAVED_RESOURCES).getCodeReaderCache(); - } - - public void testSimpleCacheFunctionality() throws Exception { - StringBuilder code = new StringBuilder(); - code.append("int x;"); - - IFile file = importFile("test.c", code.toString()); - parse(file); - - ICodeReaderCache cache = getCodeReaderCache(); - cache.flush(); - assertEquals(0, cache.getCurrentSpace()); - CodeReader reader = cache.get(file.getLocation().toOSString()); - assertNotNull(reader); - assertEquals(1, cache.getCurrentSpace()); - assertEquals(String.valueOf(reader.filename), file.getLocation().toOSString()); - cache.remove(String.valueOf(reader.filename)); - assertEquals(0, cache.getCurrentSpace()); - } - - public void testResourceChangedUpdate() throws Exception { - boolean hasPassed = false; - StringBuilder code = new StringBuilder(); - code.append("int x;"); - ICodeReaderCache cache = getCodeReaderCache(); - - IFile file = importFile("test.c", code.toString()); - parse(file); - - // start a new job that repeatedly updates the file... - UpdateFileJob job = new UpdateFileJob("updater", file, "test.c", code.toString()); //$NON-NLS-2$ - job.schedule(); - - while (!hasPassed) { - if (file != null) { - parse(file); - } - - try { - Thread.sleep(1000); // give the updater thread some time to update the resource - file = job.getFile(); - } catch (InterruptedException e) { - e.printStackTrace(); - } - - if (cache.getCurrentSpace() == 0) // item was properly removed by the updater thread - hasPassed = true; - } - - job.cancel(); - } - - // This is broken. - // I have a mind to delete any test that has a Thread.sleep() in it. - public void testResourceChangedNestedPathUpdate(int off) throws Exception { - boolean hasPassed = false; - StringBuilder code = new StringBuilder(); - code.append("int x;"); - ICodeReaderCache cache = getCodeReaderCache(); - - importFolder("test"); - IFile file = importFile("test/test.c", code.toString()); - - // start a new job that repeatedly updates the file... - UpdateFileJob job = new UpdateFileJob("updater", file, "test/test.c", code.toString()); - job.schedule(); - - while (!hasPassed) { - if (file != null) { - parse(file); - } - - try { - Thread.sleep(1000); // give the updater thread some time to update the resource - file = job.getFile(); - } catch (InterruptedException e) { - e.printStackTrace(); - } - - if (cache.getCurrentSpace() == 0) // item was properly removed by the updater thread - hasPassed = true; - } - - job.cancel(); - } -} diff --git a/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/DOMLocationInclusionTests.java b/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/DOMLocationInclusionTests.java deleted file mode 100644 index 0f3b16c10c3..00000000000 --- a/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/DOMLocationInclusionTests.java +++ /dev/null @@ -1,782 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2004, 2016 IBM Corporation 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: - * IBM - Initial API and implementation - * Markus Schorn (Wind River Systems) - *******************************************************************************/ -package org.eclipse.cdt.core.parser.tests.ast2; - -import java.io.File; -import java.util.Collections; - -import junit.framework.Test; -import junit.framework.TestSuite; - -import org.eclipse.cdt.core.CCorePlugin; -import org.eclipse.cdt.core.dom.CDOM; -import org.eclipse.cdt.core.dom.IParserConfiguration; -import org.eclipse.cdt.core.dom.ast.IASTDeclaration; -import org.eclipse.cdt.core.dom.ast.IASTFileLocation; -import org.eclipse.cdt.core.dom.ast.IASTFunctionDefinition; -import org.eclipse.cdt.core.dom.ast.IASTName; -import org.eclipse.cdt.core.dom.ast.IASTNode; -import org.eclipse.cdt.core.dom.ast.IASTNodeLocation; -import org.eclipse.cdt.core.dom.ast.IASTPreprocessorIncludeStatement; -import org.eclipse.cdt.core.dom.ast.IASTPreprocessorMacroDefinition; -import org.eclipse.cdt.core.dom.ast.IASTProblem; -import org.eclipse.cdt.core.dom.ast.IASTSimpleDeclaration; -import org.eclipse.cdt.core.dom.ast.IASTTranslationUnit; -import org.eclipse.cdt.core.parser.ExtendedScannerInfo; -import org.eclipse.cdt.core.parser.IExtendedScannerInfo; -import org.eclipse.cdt.core.parser.IScannerInfo; -import org.eclipse.cdt.core.parser.ParserLanguage; -import org.eclipse.cdt.core.parser.ScannerInfo; -import org.eclipse.cdt.internal.core.dom.SavedCodeReaderFactory; -import org.eclipse.core.resources.IFile; -import org.eclipse.core.resources.IProject; -import org.eclipse.core.runtime.content.IContentType; - -/** - * @author jcamelon - */ -public class DOMLocationInclusionTests extends AST2FileBasePluginTestCase { - - public DOMLocationInclusionTests() { - } - - public DOMLocationInclusionTests(String name, Class className) { - super(name, className); - } - - public void testBug97967() throws Exception { - StringBuilder buffer = new StringBuilder(); - buffer.append("#ifndef _INCLUDE_H_\n"); //$NON-NLS-1$ - buffer.append("#define _INCLUDE_H_\n"); //$NON-NLS-1$ - buffer.append("typedef void (*vfp)();\n"); //$NON-NLS-1$ - buffer.append("typedef int (*ifp)();\n"); //$NON-NLS-1$ - buffer.append("struct Include {\n"); //$NON-NLS-1$ - buffer.append("int i;\n"); //$NON-NLS-1$ - buffer.append("};\n"); //$NON-NLS-1$ - buffer.append("#endif /*_INCLUDE_H_*/\n"); //$NON-NLS-1$ - String[] macros = { importFile( - "macro.h", "#define JEDEN 1\n#define DVA 2\n#define TRI 3\n").getLocation().toOSString() }; //$NON-NLS-1$ //$NON-NLS-2$ - String[] includes = { importFile("include.h", buffer.toString()).getLocation().toOSString() }; //$NON-NLS-1$ - IExtendedScannerInfo scannerInfo = new ExtendedScannerInfo( - Collections.EMPTY_MAP, EMPTY_STRING_ARRAY, macros, includes); - String code = "int main() { return BEAST * sizeof( Include ); } "; //$NON-NLS-1$ - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "main.cc" : "main.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile c = importFile(filename, code); - - IASTTranslationUnit tu = parse(c, scannerInfo); - IASTFunctionDefinition fd = (IASTFunctionDefinition) tu.getDeclarations()[3]; - IASTFileLocation floc = fd.getFileLocation(); - assertEquals(floc.getNodeOffset(), - code.indexOf("int main() { return BEAST * sizeof( Include ); }")); //$NON-NLS-1$ - assertEquals(floc.getNodeLength(), - "int main() { return BEAST * sizeof( Include ); }".length()); //$NON-NLS-1$ - } - } - - public void testBug101875() throws Exception { - for (int i = 0; i < 4; ++i) { - StringBuilder buffer = new StringBuilder(); - buffer.append("#ifndef _BLAH_H_\n"); //$NON-NLS-1$ - buffer.append("#endif"); //$NON-NLS-1$ - if (i > 1) - buffer.append(" /* _BLAH_H_ */"); //$NON-NLS-1$ - if ((i % 2) == 1) - buffer.append("\n"); //$NON-NLS-1$ - importFile("blah.h", buffer.toString()); //$NON-NLS-1$ - buffer = new StringBuilder(); - buffer.append("#include \"blah.h\"\n"); //$NON-NLS-1$ - buffer.append("/**\n"); //$NON-NLS-1$ - buffer.append(" * A type used by test functions.\n"); //$NON-NLS-1$ - buffer.append("*/\n"); //$NON-NLS-1$ - buffer.append("int SomeStructure;\n"); //$NON-NLS-1$ - String code = buffer.toString(); - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "blah.cc" : "blah.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile source = importFile(filename, code); - IASTTranslationUnit tu = parse(source); - IASTSimpleDeclaration declaration = (IASTSimpleDeclaration) tu.getDeclarations()[0]; - assertSoleFileLocation(declaration.getDeclarators()[0], filename, - code.indexOf("SomeStructure"), "SomeStructure".length()); //$NON-NLS-1$ //$NON-NLS-2$ - } - } - } - - private class TestParserConfiguration implements IParserConfiguration { - private final IScannerInfo info; - - private final String dialect; - - public TestParserConfiguration(IScannerInfo s, IFile code) { - this.info = s; - String filename = code.getLocation().toOSString(); - IProject prj = code.getProject(); - - // FIXME: ALAIN, for headers should we assume CPP ?? - // The problem is that it really depends on how the header was - // included. - String id = null; - IContentType contentType = CCorePlugin.getContentType(prj, filename); - if (contentType != null) { - id = contentType.getId(); - } - - if (id != null) { - if (CCorePlugin.CONTENT_TYPE_CSOURCE.equals(id)) - dialect = "GNUC"; //$NON-NLS-1$ - else - dialect = "GNUC++"; //$NON-NLS-1$ - } else - dialect = "GNUC++"; //$NON-NLS-1$ - - } - - @Override - public IScannerInfo getScannerInfo() { - return info; - } - - @Override - public String getParserDialect() { - return dialect; - } - } - - private static final String[] EMPTY_STRING_ARRAY = new String[0]; - - public DOMLocationInclusionTests(String name) { - super(name, DOMLocationInclusionTests.class); - } - - protected IASTTranslationUnit parse(IFile code) throws Exception { - SavedCodeReaderFactory.getInstance().getCodeReaderCache().flush(); - return CDOM.getInstance().getTranslationUnit(code); - } - - protected IASTTranslationUnit parse(IFile code, IScannerInfo s) - throws Exception { - SavedCodeReaderFactory.getInstance().getCodeReaderCache().flush(); - return CDOM.getInstance().getTranslationUnit( - code, - CDOM.getInstance().getCodeReaderFactory(CDOM.PARSE_SAVED_RESOURCES), - new TestParserConfiguration(s, code)); - } - - protected void assertSoleFileLocation(IASTNode n, String pathEndsWith, int offset, int length) { - IASTNodeLocation[] locations = n.getNodeLocations(); - assertEquals(locations.length, 1); - IASTFileLocation nodeLocation = (IASTFileLocation) locations[0]; - assertTrue(nodeLocation.getFileName().endsWith(pathEndsWith)); - assertEquals(offset, nodeLocation.getNodeOffset()); - assertEquals(length, nodeLocation.getNodeLength()); - } - - private void assertFileLocation(IASTNode n, String pathEndsWith, int offset, int length) { - IASTFileLocation location = n.getFileLocation(); - assertTrue(location.getFileName().endsWith(pathEndsWith)); - assertEquals(offset, location.getNodeOffset()); - assertEquals(length, location.getNodeLength()); - } - - public void testSimpleInclusion() throws Exception { - String foo = "int FOO;"; //$NON-NLS-1$ - String code = "int bar;\n#include \"foo.h\"\n"; //$NON-NLS-1$ - - importFile("foo.h", foo); //$NON-NLS-1$ - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "code.cc" : "code.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile cpp = importFile(filename, code); - IASTTranslationUnit tu = parse(cpp); - IASTDeclaration[] declarations = tu.getDeclarations(); - assertEquals(declarations.length, 2); - IASTSimpleDeclaration bar = (IASTSimpleDeclaration) declarations[0]; - IASTSimpleDeclaration FOO = (IASTSimpleDeclaration) declarations[1]; - assertSoleFileLocation(bar, filename, code.indexOf("int"), code.indexOf(";") + 1); //$NON-NLS-1$ //$NON-NLS-2$ - - assertSoleFileLocation(FOO, "foo.h", foo.indexOf("int"), foo.indexOf(";") + 1); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - IASTPreprocessorIncludeStatement[] incs = tu.getIncludeDirectives(); - assertNotNull(incs); - assertEquals(incs.length, 1); - assertSoleFileLocation(incs[0], filename, code.indexOf("#inc"), "#include \"foo.h\"".length()); - // test bug 166026 - assertEquals(tu.getFilePath(), incs[0].getContainingFilename()); - - checkInclude(incs[0], filename, code, "foo.h", false); - } - } - - protected void checkInclude(IASTPreprocessorIncludeStatement inc, String file, String code, String name, boolean system) { - IASTName incName= inc.getName(); - - assertEquals(system, inc.isSystemInclude()); - assertEquals(name, incName.toString()); - assertSoleFileLocation(incName, file, code.indexOf(name), name.length()); - - } - - public void testSimpleInclusion2() throws Exception { - String foo = "int FOO;"; //$NON-NLS-1$ - String code = "int bar;\n#include \"foo.h\"\nfloat byob;\n"; //$NON-NLS-1$ - - importFile("foo.h", foo); //$NON-NLS-1$ - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "code.cc" : "code.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile cpp = importFile(filename, code); - IASTTranslationUnit tu = parse(cpp); - IASTDeclaration[] declarations = tu.getDeclarations(); - assertEquals(declarations.length, 3); - IASTSimpleDeclaration bar = (IASTSimpleDeclaration) declarations[0]; - IASTSimpleDeclaration FOO = (IASTSimpleDeclaration) declarations[1]; - IASTSimpleDeclaration byob = (IASTSimpleDeclaration) declarations[2]; - assertSoleFileLocation( - bar, - filename, - code.indexOf("int"), code.indexOf("r;") + 2 - code.indexOf("int")); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation( - FOO, - "foo.h", foo.indexOf("int"), foo.indexOf(";") + 1 - foo.indexOf("int")); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ - assertSoleFileLocation( - byob, - filename, - code.indexOf("float"), code.indexOf("b;") + 2 - code.indexOf("float")); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - IASTPreprocessorIncludeStatement[] incs = tu.getIncludeDirectives(); - assertNotNull(incs); - assertEquals(incs.length, 1); - assertSoleFileLocation( - incs[0], - filename, - code.indexOf("#inc"), code.indexOf(".h\"\n") + ".h\"".length() - code.indexOf("#inc")); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ - } - } - - public void testMacrosInIncludeFile() throws Exception { - String c_file_code = "#define X 4\n\n#include \"blarg.h\"\n\n#define POST_INCLUDE\n\n"; //$NON-NLS-1$ - String h_file_code = "#ifndef _BLARG_H_\r\n#define _BLARG_H_\r\n// macro\r\n#define PRINT(s,m) printf(s,m)\r\n#endif //_BLARG_H_\r\n"; //$NON-NLS-1$ - importFile("blarg.h", h_file_code); //$NON-NLS-1$ - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "blah.cc" : "blah.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile c_file = importFile(filename, c_file_code); - IASTTranslationUnit tu = parse(c_file); - assertEquals(tu.getDeclarations().length, 0); - IASTPreprocessorMacroDefinition[] macroDefinitions = tu - .getMacroDefinitions(); - assertNotNull(macroDefinitions); - assertEquals(macroDefinitions.length, 4); - assertSoleFileLocation( - macroDefinitions[0], - filename, - c_file_code.indexOf("#define"), c_file_code.indexOf("4") + 1 - c_file_code.indexOf("#define")); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation(macroDefinitions[0].getName(), filename, - c_file_code.indexOf("X"), 1); //$NON-NLS-1$ - assertSoleFileLocation( - macroDefinitions[1], - "blarg.h", h_file_code.indexOf("#define _BLARG_H_"), "#define _BLARG_H_".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation( - macroDefinitions[1].getName(), - "blarg.h", h_file_code.indexOf("e _BLARG_H_") + 2, "_BLARG_H_".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation( - macroDefinitions[2], - "blarg.h", h_file_code.indexOf("#define PRINT(s,m) printf(s,m)\r"), "#define PRINT(s,m) printf(s,m)".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation(macroDefinitions[2].getName(), - "blarg.h", h_file_code.indexOf("PRINT"), "PRINT".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation( - macroDefinitions[3], - filename, - c_file_code.indexOf("#define POST_INCLUDE"), "#define POST_INCLUDE".length()); //$NON-NLS-1$ //$NON-NLS-2$ - assertSoleFileLocation( - macroDefinitions[3].getName(), - filename, - c_file_code.indexOf("POST_INCLUDE"), "POST_INCLUDE".length()); //$NON-NLS-1$ //$NON-NLS-2$ - } - } - - public void testBug84451() throws Exception { - String header1_code = "int x;\n"; //$NON-NLS-1$ - String header2_code = "int y;\n"; //$NON-NLS-1$ - String cpp_code = "#include \"header1.h\"\n#include \"header2.h\"\nint z;\n"; //$NON-NLS-1$ - importFile("header1.h", header1_code); //$NON-NLS-1$ - importFile("header2.h", header2_code); //$NON-NLS-1$ - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "source.cc" : "source.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile f = importFile(filename, cpp_code); - IASTTranslationUnit tu = parse(f); - IASTDeclaration[] declarations = tu.getDeclarations(); - IASTPreprocessorIncludeStatement[] includeDirectives = tu - .getIncludeDirectives(); - assertSoleFileLocation( - includeDirectives[0], - filename, - cpp_code.indexOf("#include \"header1.h\""), "#include \"header1.h\"".length()); //$NON-NLS-1$ //$NON-NLS-2$ - assertSoleFileLocation(declarations[0], - "header1.h", 0, "int x;".length()); //$NON-NLS-1$ //$NON-NLS-2$ - assertSoleFileLocation(declarations[1], - "header2.h", 0, "int y;".length()); //$NON-NLS-1$ //$NON-NLS-2$ - assertSoleFileLocation( - includeDirectives[1], - filename, - cpp_code.indexOf("#include \"header2.h\""), "#include \"header2.h\"".length()); //$NON-NLS-1$ //$NON-NLS-2$ - assertSoleFileLocation(declarations[2], filename, cpp_code - .indexOf("int z;"), "int z;".length()); //$NON-NLS-1$ //$NON-NLS-2$ - - IASTTranslationUnit.IDependencyTree tree = tu.getDependencyTree(); - assertEquals(tree.getInclusions().length, 2); - - } - } - - public void testMacrosInIncludeFile2() throws Exception { - String c_file_code = "#define X 4\n\n#include \"blarg.h\"\n\n#define POST_INCLUDE\n#include \"second.h\"\n#define POST_SECOND\n"; //$NON-NLS-1$ - String h_file_code = "#ifndef _BLARG_H_\r\n#define _BLARG_H_\r\n//macro\r\n#define PRINT(s,m) printf(s,m)\r\n#endif //_BLARG_H_\r\n"; //$NON-NLS-1$ - String h_file2_code = "#ifndef _SECOND_H_ \n#define _SECOND_H_\n#endif\n"; //$NON-NLS-1$ - importFile("blarg.h", h_file_code); //$NON-NLS-1$ - importFile("second.h", h_file2_code); //$NON-NLS-1$ - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "blah.cc" : "blah.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile c_file = importFile(filename, c_file_code); - IASTTranslationUnit tu = parse(c_file); - assertEquals(tu.getDeclarations().length, 0); - IASTPreprocessorMacroDefinition[] macroDefinitions = tu.getMacroDefinitions(); - assertNotNull(macroDefinitions); - assertEquals(macroDefinitions.length, 6); - assertSoleFileLocation( - macroDefinitions[0], - filename, - c_file_code.indexOf("#define"), c_file_code.indexOf("4") + 1 - c_file_code.indexOf("#define")); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation(macroDefinitions[0].getName(), filename, - c_file_code.indexOf("X"), 1); //$NON-NLS-1$ - assertSoleFileLocation( - macroDefinitions[1], - "blarg.h", h_file_code.indexOf("#define _BLARG_H_"), "#define _BLARG_H_".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation( - macroDefinitions[1].getName(), - "blarg.h", h_file_code.indexOf("e _BLARG_H_") + 2, "_BLARG_H_".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation( - macroDefinitions[2], - "blarg.h", h_file_code.indexOf("#define PRINT(s,m) printf(s,m)\r"), "#define PRINT(s,m) printf(s,m)".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation(macroDefinitions[2].getName(), - "blarg.h", h_file_code.indexOf("PRINT"), "PRINT".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation( - macroDefinitions[3], - filename, - c_file_code.indexOf("#define POST_INCLUDE"), "#define POST_INCLUDE".length()); //$NON-NLS-1$ //$NON-NLS-2$ - assertSoleFileLocation( - macroDefinitions[3].getName(), - filename, - c_file_code.indexOf("POST_INCLUDE"), "POST_INCLUDE".length()); //$NON-NLS-1$ //$NON-NLS-2$ - assertSoleFileLocation( - macroDefinitions[4], - "second.h", h_file2_code.indexOf("#define _SECOND_H_"), "#define _SECOND_H_".length()); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ - assertSoleFileLocation( - macroDefinitions[5], - filename, - c_file_code.indexOf("#define POST_SECOND"), "#define POST_SECOND".length()); //$NON-NLS-1$ //$NON-NLS-2$ - - } - } - - public void testBug90851() throws Exception { - IFile imacro_file = importFile("macro.h", "#define BEAST 666\n"); //$NON-NLS-1$ //$NON-NLS-2$ - StringBuilder buffer = new StringBuilder(); - buffer.append("#ifndef _INCLUDE_H_\n"); //$NON-NLS-1$ - buffer.append("#define _INCLUDE_H_\n"); //$NON-NLS-1$ - buffer.append("typedef void (*vfp)();\n"); //$NON-NLS-1$ - buffer.append("typedef int (*ifp)();\n"); //$NON-NLS-1$ - buffer.append("struct Include {\n"); //$NON-NLS-1$ - buffer.append("int i;\n"); //$NON-NLS-1$ - buffer.append("};\n"); //$NON-NLS-1$ - buffer.append("#endif /*_INCLUDE_H_*/\n"); //$NON-NLS-1$ - final String inc_file_code = buffer.toString(); - IFile include_file = importFile("include.h", inc_file_code); //$NON-NLS-1$ - String[] macros = { imacro_file.getLocation().toOSString() }; - String[] includes = { include_file.getLocation().toOSString() }; - IExtendedScannerInfo scannerInfo = new ExtendedScannerInfo(Collections.EMPTY_MAP, EMPTY_STRING_ARRAY, macros, includes); - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "main.cc" : "main.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile code = importFile(filename, "int main() { return BEAST * sizeof( Include ); } "); //$NON-NLS-1$ - IASTTranslationUnit tu = parse(code, scannerInfo); - IASTPreprocessorMacroDefinition[] macro_defs = tu.getMacroDefinitions(); - assertEquals(macro_defs.length, 2); - IASTPreprocessorMacroDefinition BEAST = macro_defs[0]; - assertEquals(BEAST.getName().toString(), "BEAST"); //$NON-NLS-1$ - IASTPreprocessorMacroDefinition INCLUDE_H = macro_defs[1]; - final IASTNodeLocation[] nodeLocations = INCLUDE_H.getName().getNodeLocations(); - assertEquals(nodeLocations.length, 1); - final IASTFileLocation flatLoc = INCLUDE_H.getName().getFileLocation(); - assertNotNull(flatLoc); - assertEquals(include_file.getLocation().toOSString(), flatLoc.getFileName()); - assertEquals(inc_file_code.indexOf("#define _INCLUDE_H_") + "#define ".length(), flatLoc.getNodeOffset()); //$NON-NLS-1$ //$NON-NLS-2$ - assertEquals("_INCLUDE_H_".length(), flatLoc.getNodeLength()); //$NON-NLS-1$ - } - } - - public void testIProblemLocation() throws Exception { - StringBuilder buffer = new StringBuilder(); - buffer.append("#include \n"); //$NON-NLS-1$ - buffer.append("int x,y,z;"); //$NON-NLS-1$ - String code = buffer.toString(); - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "blah.cc" : "blah.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile f = importFile(filename, code); - IASTTranslationUnit tu = parse(f); - IASTProblem[] prbs = tu.getPreprocessorProblems(); - assertEquals(prbs.length, 1); - IASTNodeLocation[] locs = prbs[0].getNodeLocations(); - assertEquals(locs.length, 1); - IASTFileLocation fileLoc = (IASTFileLocation) locs[0]; - assertEquals(code.indexOf("#include"), fileLoc.getNodeOffset()); //$NON-NLS-1$ - assertEquals("#include ".length(), fileLoc.getNodeLength()); //$NON-NLS-1$ - } - - } - - public static Test suite() { - TestSuite suite = new TestSuite(DOMLocationInclusionTests.class); - suite.addTest(new DOMLocationInclusionTests("cleanupProject")); //$NON-NLS-1$ - return suite; - } - - public void testBug97603() throws Exception { - IFile imacro_file = importFile("macro.h", "#define JEDEN 1\n#define DVA 2\n#define TRI 3\n"); //$NON-NLS-1$ //$NON-NLS-2$ - StringBuilder buffer = new StringBuilder(); - buffer.append("#ifndef _INCLUDE_H_\n"); //$NON-NLS-1$ - buffer.append("#define _INCLUDE_H_\n"); //$NON-NLS-1$ - buffer.append("typedef void (*vfp)();\n"); //$NON-NLS-1$ - buffer.append("typedef int (*ifp)();\n"); //$NON-NLS-1$ - buffer.append("struct Include {\n"); //$NON-NLS-1$ - buffer.append("int i;\n"); //$NON-NLS-1$ - buffer.append("};\n"); //$NON-NLS-1$ - buffer.append("#endif /*_INCLUDE_H_*/\n"); //$NON-NLS-1$ - final String inc_file_code = buffer.toString(); - IFile include_file = importFile("include.h", inc_file_code); //$NON-NLS-1$ - String[] macros = { imacro_file.getLocation().toOSString() }; - String[] includes = { include_file.getLocation().toOSString() }; - IExtendedScannerInfo scannerInfo = new ExtendedScannerInfo( - Collections.EMPTY_MAP, EMPTY_STRING_ARRAY, macros, includes); - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "main.cc" : "main.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile code = importFile(filename, "int main() { return BEAST * sizeof( Include ); } "); //$NON-NLS-1$ - - IASTTranslationUnit tu = parse(code, scannerInfo); - IASTPreprocessorMacroDefinition[] macro_defs = tu.getMacroDefinitions(); - assertEquals(macro_defs.length, 4); - IASTPreprocessorMacroDefinition BEAST = macro_defs[0]; - assertEquals(BEAST.getName().toString(), "JEDEN"); //$NON-NLS-1$ - IASTPreprocessorMacroDefinition INCLUDE_H = macro_defs[3]; - final IASTNodeLocation[] nodeLocations = INCLUDE_H.getName().getNodeLocations(); - assertEquals(nodeLocations.length, 1); - final IASTFileLocation flatLoc = INCLUDE_H.getName().getFileLocation(); - assertNotNull(flatLoc); - assertEquals(include_file.getLocation().toOSString(), flatLoc.getFileName()); - assertEquals(inc_file_code.indexOf("#define _INCLUDE_H_") + "#define ".length(), flatLoc.getNodeOffset()); //$NON-NLS-1$ //$NON-NLS-2$ - assertEquals("_INCLUDE_H_".length(), flatLoc.getNodeLength()); //$NON-NLS-1$ - for (int j = 0; j < macro_defs.length; ++j) - assertNotNull(macro_defs[j].getName().getFileLocation()); - - } - } - - public void testBug97603_2() throws Exception { - IFile imacro_file1= importFile("macro1.h", "#define JEDEN 1\n"); - IFile imacro_file2= importFile("macro2.h", "#define DVA 2\n#define TRI 3\n"); - StringBuilder buffer = new StringBuilder(); - buffer.append("#ifndef _INCLUDE_H_\n"); //$NON-NLS-1$ - buffer.append("#define _INCLUDE_H_\n"); //$NON-NLS-1$ - buffer.append("typedef void (*vfp)();\n"); //$NON-NLS-1$ - buffer.append("typedef int (*ifp)();\n"); //$NON-NLS-1$ - buffer.append("struct Include {\n"); //$NON-NLS-1$ - buffer.append("int i;\n"); //$NON-NLS-1$ - buffer.append("};\n"); //$NON-NLS-1$ - buffer.append("#endif /*_INCLUDE_H_*/\n"); //$NON-NLS-1$ - final String inc_file_code = buffer.toString(); - IFile include_file = importFile("include.h", inc_file_code); //$NON-NLS-1$ - String[] macros = { imacro_file1.getLocation().toOSString(), imacro_file2.getLocation().toOSString() }; - String[] includes = { include_file.getLocation().toOSString() }; - IExtendedScannerInfo scannerInfo = new ExtendedScannerInfo(Collections.EMPTY_MAP, EMPTY_STRING_ARRAY, macros, includes); - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "main.cc" : "main.c"; //$NON-NLS-1$ //$NON-NLS-2$ - IFile code = importFile(filename, "int main() { return BEAST * sizeof( Include ); } "); //$NON-NLS-1$ - - IASTTranslationUnit tu = parse(code, scannerInfo); - IASTPreprocessorMacroDefinition[] macro_defs = tu.getMacroDefinitions(); - assertEquals(macro_defs.length, 4); - IASTPreprocessorMacroDefinition BEAST = macro_defs[0]; - assertEquals(BEAST.getName().toString(), "JEDEN"); //$NON-NLS-1$ - IASTPreprocessorMacroDefinition INCLUDE_H = macro_defs[3]; - final IASTNodeLocation[] nodeLocations = INCLUDE_H.getName().getNodeLocations(); - assertEquals(nodeLocations.length, 1); - final IASTFileLocation flatLoc = INCLUDE_H.getName().getFileLocation(); - assertNotNull(flatLoc); - assertEquals(include_file.getLocation().toOSString(), flatLoc.getFileName()); - assertEquals(inc_file_code.indexOf("#define _INCLUDE_H_") + "#define ".length(), flatLoc.getNodeOffset()); //$NON-NLS-1$ //$NON-NLS-2$ - assertEquals("_INCLUDE_H_".length(), flatLoc.getNodeLength()); //$NON-NLS-1$ - for (int j = 0; j < macro_defs.length; ++j) - assertNotNull(macro_defs[j].getName().getFileLocation()); - - } - } - - public void testSystemInclude() throws Exception { - IFile incsh= importFile("incs.h", ""); - StringBuilder buffer = new StringBuilder(); - buffer.append("#include \n"); - buffer.append("#include <../AST2BasedProjectMofo/incs.h>\n"); - buffer.append("#define TARG \n"); - buffer.append("#include TARG\n"); - String code= buffer.toString(); - IExtendedScannerInfo scannerInfo = new ExtendedScannerInfo(Collections.EMPTY_MAP, new String[] {incsh.getLocation().removeLastSegments(1).toOSString()}, null, null); - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "main.cc" : "main.c"; - IFile sfile = importFile(filename, code); - IASTTranslationUnit tu = parse(sfile, scannerInfo); - - IASTPreprocessorIncludeStatement[] incs = tu.getIncludeDirectives(); - assertNotNull(incs); - assertEquals(3, incs.length); - - assertSoleFileLocation(incs[0], filename, code.indexOf("#include "), "#include ".length()); - checkInclude(incs[0], filename, code, "incs.h", true); - - assertSoleFileLocation(incs[1], filename, code.indexOf("#include <../AST2BasedProjectMofo/incs.h>"), "#include <../AST2BasedProjectMofo/incs.h>".length()); - checkInclude(incs[1], filename, code, "../AST2BasedProjectMofo/incs.h", true); - - assertFileLocation(incs[2], filename, code.indexOf("#include TARG"), "#include TARG".length()); - IASTName incName= incs[2].getName(); - - assertEquals(true, incs[2].isSystemInclude()); - assertEquals("incs.h", incName.toString()); - assertFileLocation(incName, filename, code.lastIndexOf("TARG"), "TARG".length()); - } - } - - // #define NAME test.h - // #define MAKE_INCLUDE(path, header) - // #include MAKE_INCLUDE(test_bug164644, NAME) - public void testBug164644() throws Exception { - String tmpDir= System.getProperty("java.io.tmpdir"); - File tmpFile= new File(tmpDir + "/test_bug164644/test.h").getCanonicalFile(); - tmpFile.getParentFile().mkdirs(); - tmpFile.createNewFile(); - try { - String code= getContents(1)[0].toString(); - IExtendedScannerInfo scannerInfo = new ExtendedScannerInfo( - Collections.EMPTY_MAP, new String[] {tmpDir}, null, null); - - for (ParserLanguage p : ParserLanguage.values()) { - String filename = (p == ParserLanguage.CPP) ? "main.cc" : "main.c"; - IFile sfile = importFile(filename, code); - IASTTranslationUnit tu = parse(sfile, scannerInfo); - - IASTPreprocessorIncludeStatement[] incs = tu.getIncludeDirectives(); - assertNotNull(incs); - assertEquals(1, incs.length); - - assertEquals(tmpFile.getAbsolutePath(), incs[0].getPath()); - assertFileLocation(incs[0], filename, code.indexOf("#include MAKE_INCLUDE(test_bug164644, NAME)"), "#include MAKE_INCLUDE(test_bug164644, NAME)".length()); - IASTPreprocessorIncludeStatement inc = incs[0]; - IASTName incName= inc.getName(); - assertEquals(true, inc.isSystemInclude()); - } - } - finally { - tmpFile.delete(); - tmpFile.getParentFile().delete(); - } - } - - // // comment - // - // #ifndef guard - // #define guard - // bla bla - // #if 1 - // #endif - // bla bla - // #endif - // //comment - - // // comment - // - // #if !defined(guard) - // #define guard - // bla bla - // #if 1 - // #endif - // bla bla - // #endif - // //comment - - // // comment - // - // #if ((!defined guard)) - // #define guard - // bla bla - // #if 1 - // #endif - // bla bla - // #endif - // //comment - - // // comment - // #pragma once - - // // Some comment - // - // #ifndef AN_UNIQUE_INCLUDE_GUARD_H_ - // #define AN_UNIQUE_INCLUDE_GUARD_H_ - // - // #include - // - // Some code without any macro references - // - // #endif // AN_UNIQUE_INCLUDE_GUARD_H_ - public void testPragmaOnceDetection_197989a() throws Exception { - CharSequence[] contents= getContents(5); - - int i= 0; - for (CharSequence content : contents) { - String headerName = i + ".h"; - IFile base = importFile("base" + headerName, "#include \"" + headerName + "\""); - importFile(headerName, content.toString()); - IASTTranslationUnit tu = parse(base, new ScannerInfo()); - IASTPreprocessorIncludeStatement[] incs = tu.getIncludeDirectives(); - assertTrue(incs.length > 0); - assertTrue(incs[0].hasPragmaOnceSemantics()); - } - } - - // #ifndef guard - // #define guard2 - // #endif - - // #if !defined guard - // #define guard2 - // #endif - - // #if !defined(guard) && !defined(guard2) - // #define guard - // #endif - - // #if (0) - // #pragma once - // #endif - - // leading - // #ifndef guard - // #define guard2 - // #endif - - // #ifndef guard - // #define guard2 - // #endif - // #ifdef xx - // trailing - // #endif - public void testPragmaOnceDetection_197989b() throws Exception { - CharSequence[] contents= getContents(6); - - int i= 0; - for (CharSequence content : contents) { - String headerName = i + ".h"; - IFile base = importFile("base" + headerName, "#include \"" + headerName + "\""); - importFile(headerName, content.toString()); - IASTTranslationUnit tu = parse(base, new ScannerInfo()); - IASTPreprocessorIncludeStatement[] incs = tu.getIncludeDirectives(); - assertEquals(1, incs.length); - assertFalse(incs[0].hasPragmaOnceSemantics()); - } - } - - - // // header.h - // #ifdef AH - // #endif - // #ifndef BH - // #endif - // #define h - // #if CH || DH - // #elif EH==1 - // #endif - - // #define BH - // #define DH 0 - // #define EH 1 - // #include "header.h" - // #ifdef h // defined in header - // #endif - // #ifdef A - // #ifdef a // inactive - // #endif - // #else - // #ifndef B - // #endif - // #endif - // #if defined C - // #elif ((!((defined(D))))) - // #endif - // #define A - // #define B - // #define AH - // #define h - // #undef u - // #ifdef h // locally defined - // #endif - // #ifndef u // locally undefined - // #endif - public void testSignificantMacros_197989a() throws Exception { - CharSequence[] contents= getContents(2); - - IFile h = importFile("header.h", contents[0].toString()); - IFile c = importFile("source.c", contents[1].toString()); - - IASTTranslationUnit tu = parse(c, new ScannerInfo()); - IASTPreprocessorIncludeStatement[] incs = tu.getIncludeDirectives(); - assertEquals(1, incs.length); - assertEquals("{AH=null,BH=*,CH=null,DH=0,EH=1}", - incs[0].getSignificantMacros().toString()); - assertEquals("{A=null,AH=null,B=null,C=null,CH=null,D=null}", - tu.getSignificantMacros().toString()); - } - - // // header.h - // #if EQ(A,B) - // #endif - - // #define EQ(x,y) x==y - // #define A A1 - // #define B 1 - // #include "header.h" - public void testSignificantMacros_197989b() throws Exception { - CharSequence[] contents= getContents(2); - - IFile h = importFile("header.h", contents[0].toString()); - IFile c = importFile("source.c", contents[1].toString()); - - IASTTranslationUnit tu = parse(c, new ScannerInfo()); - IASTPreprocessorIncludeStatement[] incs = tu.getIncludeDirectives(); - assertEquals(1, incs.length); - assertEquals("{A=A1,A1=null,B=1,EQ=x==y}", - incs[0].getSignificantMacros().toString()); - assertEquals("{A1=null}", - tu.getSignificantMacros().toString()); - } - -} diff --git a/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/DOMParserTestSuite.java b/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/DOMParserTestSuite.java index e27ab1474dc..9966344e85b 100644 --- a/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/DOMParserTestSuite.java +++ b/core/org.eclipse.cdt.core.tests/parser/org/eclipse/cdt/core/parser/tests/ast2/DOMParserTestSuite.java @@ -13,12 +13,12 @@ *******************************************************************************/ package org.eclipse.cdt.core.parser.tests.ast2; +import org.eclipse.cdt.core.parser.tests.prefix.CompletionTestSuite; + import junit.framework.Test; import junit.framework.TestCase; import junit.framework.TestSuite; -import org.eclipse.cdt.core.parser.tests.prefix.CompletionTestSuite; - /** * @author jcamelon */ @@ -37,13 +37,11 @@ public class DOMParserTestSuite extends TestCase { suite.addTest(DOMLocationTests.suite()); suite.addTestSuite(DOMLocationMacroTests.class); suite.addTest(ImageLocationTests.suite()); - suite.addTest(DOMLocationInclusionTests.suite()); suite.addTestSuite(AST2KnRTests.class); suite.addTestSuite(AST2UtilTests.class); suite.addTestSuite(AST2UtilOldTests.class); suite.addTestSuite(AST2SelectionParseTest.class); suite.addTest(ASTNodeSelectorTest.suite()); - suite.addTestSuite(CodeReaderCacheTest.class); suite.addTest(AST2CPPSpecTest.suite()); suite.addTestSuite(AST2CSpecTest.class); suite.addTestSuite(DOMSelectionParseTest.class); diff --git a/core/org.eclipse.cdt.core/src/org/eclipse/cdt/core/dom/CDOM.java b/core/org.eclipse.cdt.core/src/org/eclipse/cdt/core/dom/CDOM.java index 169e81465a4..09c9de469f9 100644 --- a/core/org.eclipse.cdt.core/src/org/eclipse/cdt/core/dom/CDOM.java +++ b/core/org.eclipse.cdt.core/src/org/eclipse/cdt/core/dom/CDOM.java @@ -13,9 +13,6 @@ import org.eclipse.cdt.core.dom.ast.IASTCompletionNode; import org.eclipse.cdt.core.dom.ast.IASTTranslationUnit; import org.eclipse.cdt.core.model.IWorkingCopyProvider; import org.eclipse.cdt.internal.core.dom.InternalASTServiceProvider; -import org.eclipse.cdt.internal.core.dom.PartialWorkingCopyCodeReaderFactory; -import org.eclipse.cdt.internal.core.dom.SavedCodeReaderFactory; -import org.eclipse.cdt.internal.core.dom.WorkingCopyCodeReaderFactory; import org.eclipse.core.resources.IFile; import org.eclipse.core.resources.IProject; import org.eclipse.core.resources.IStorage; @@ -33,12 +30,10 @@ import org.eclipse.core.resources.IStorage; */ @Deprecated public class CDOM implements IASTServiceProvider { - /** * Singleton - Constructor is private. */ - private CDOM() - { + private CDOM() { } /** @@ -50,8 +45,7 @@ public class CDOM implements IASTServiceProvider { * accessor for singleton instance * @return instance */ - public static CDOM getInstance() - { + public static CDOM getInstance() { return instance; } @@ -60,7 +54,6 @@ public class CDOM implements IASTServiceProvider { */ private IASTServiceProvider defaultService = new InternalASTServiceProvider(); - /** * @return IASTServiceProvider, the mechanism for obtaining an AST */ @@ -74,7 +67,6 @@ public class CDOM implements IASTServiceProvider { return this; } - /** * Constant PARSE_SAVED_RESOURCES - Parse saved resources in the workspace */ @@ -90,37 +82,13 @@ public class CDOM implements IASTServiceProvider { */ public static final int PARSE_WORKING_COPY_WHENEVER_POSSIBLE = 2; - /** - * provider is registered by the UI as a IWorkingCopyProvider. + * This method always returns null. */ - private IWorkingCopyProvider provider; - - /** - * This is the factory function that returns an ICodeReaderFactory instance based upon the key provided. - * - * @param key one of PARSE_SAVED_RESOURCES, PARSE_WORKING_COPY_WITH_SAVED_INCLUSIONS, PARSE_WORKING_COPY_WHENEVER_POSSIBLE - * @return an implementation that works according to the key specified or null for an invalid key - */ - public ICodeReaderFactory getCodeReaderFactory( int key ) - { - //TODO - eventually these factories will need to hook into the - //CodeReader caches - switch( key ) - { - case PARSE_SAVED_RESOURCES: - return SavedCodeReaderFactory.getInstance(); - case PARSE_WORKING_COPY_WITH_SAVED_INCLUSIONS: - return new PartialWorkingCopyCodeReaderFactory(provider, null); - case PARSE_WORKING_COPY_WHENEVER_POSSIBLE: - return new WorkingCopyCodeReaderFactory( provider, null ); - } + public ICodeReaderFactory getCodeReaderFactory(int key) { return null; } - /* (non-Javadoc) - * @see org.eclipse.cdt.core.dom.IASTServiceProvider#getTranslationUnit(org.eclipse.core.resources.IFile) - */ @Override public IASTTranslationUnit getTranslationUnit(IFile fileToParse) throws UnsupportedDialectException { //TODO - At this time, we purely delegate blindly @@ -128,9 +96,6 @@ public class CDOM implements IASTServiceProvider { return defaultService.getTranslationUnit(fileToParse); } - /* (non-Javadoc) - * @see org.eclipse.cdt.core.dom.IASTServiceProvider#getTranslationUnit(org.eclipse.core.resources.IFile, org.eclipse.cdt.core.dom.ICodeReaderFactory) - */ @Override public IASTTranslationUnit getTranslationUnit(IFile fileToParse, ICodeReaderFactory fileCreator) throws UnsupportedDialectException { //TODO - At this time, we purely delegate blindly @@ -138,9 +103,6 @@ public class CDOM implements IASTServiceProvider { return defaultService.getTranslationUnit(fileToParse, fileCreator ); } - /* (non-Javadoc) - * @see org.eclipse.cdt.core.dom.IASTServiceProvider#getTranslationUnit(org.eclipse.core.resources.IFile, org.eclipse.cdt.core.dom.ICodeReaderFactory, org.eclipse.cdt.core.dom.IParserConfiguration) - */ @Override public IASTTranslationUnit getTranslationUnit(IFile fileToParse, ICodeReaderFactory fileCreator, IParserConfiguration configuration) throws UnsupportedDialectException { //TODO - At this time, we purely delegate blindly @@ -165,12 +127,9 @@ public class CDOM implements IASTServiceProvider { } /** - * This method allows a UI component to register its IWorkingCopyProvider to the CDOM. - * - * @param workingCopyProvider - UI components buffer manager + * This method has no effect. */ public void setWorkingCopyProvider(IWorkingCopyProvider workingCopyProvider) { - this.provider = workingCopyProvider; } @Override @@ -192,5 +151,4 @@ public class CDOM implements IASTServiceProvider { public IASTTranslationUnit getTranslationUnit(IFile fileToParse, ICodeReaderFactory fileCreator, boolean parseComments) throws UnsupportedDialectException { return defaultService.getTranslationUnit(fileToParse, fileCreator, parseComments); } - } diff --git a/core/org.eclipse.cdt.ui/src/org/eclipse/cdt/ui/CUIPlugin.java b/core/org.eclipse.cdt.ui/src/org/eclipse/cdt/ui/CUIPlugin.java index 74c58edaa60..4073e4a4ce2 100644 --- a/core/org.eclipse.cdt.ui/src/org/eclipse/cdt/ui/CUIPlugin.java +++ b/core/org.eclipse.cdt.ui/src/org/eclipse/cdt/ui/CUIPlugin.java @@ -80,7 +80,6 @@ import org.eclipse.cdt.core.CCorePlugin; import org.eclipse.cdt.core.model.CoreModel; import org.eclipse.cdt.core.model.ICElement; import org.eclipse.cdt.core.model.IWorkingCopy; -import org.eclipse.cdt.core.model.IWorkingCopyProvider; import org.eclipse.cdt.internal.core.dom.rewrite.ASTRewriteAnalyzer; import org.eclipse.cdt.internal.core.model.IBufferFactory; @@ -578,13 +577,6 @@ public class CUIPlugin extends AbstractUIPlugin { configurePluginDebugOptions(); registerAdapters(); - IWorkingCopyProvider workingCopyProvider = new IWorkingCopyProvider() { - @Override - public IWorkingCopy[] getWorkingCopies() { - return CUIPlugin.getSharedWorkingCopies(); - } - }; - CCorePlugin.getDefault().getDOM().setWorkingCopyProvider(workingCopyProvider); if (PlatformUI.isWorkbenchRunning()) { // Initialize AST provider diff --git a/lrparser/org.eclipse.cdt.core.lrparser.tests/src/org/eclipse/cdt/core/lrparser/tests/LRDOMLocationInclusionTests.java b/lrparser/org.eclipse.cdt.core.lrparser.tests/src/org/eclipse/cdt/core/lrparser/tests/LRDOMLocationInclusionTests.java deleted file mode 100644 index 9ce5a543597..00000000000 --- a/lrparser/org.eclipse.cdt.core.lrparser.tests/src/org/eclipse/cdt/core/lrparser/tests/LRDOMLocationInclusionTests.java +++ /dev/null @@ -1,72 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2006, 2009 IBM Corporation 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: - * IBM Corporation - initial API and implementation - *******************************************************************************/ -package org.eclipse.cdt.core.lrparser.tests; - -import junit.framework.TestSuite; - -import org.eclipse.cdt.core.dom.ast.IASTTranslationUnit; -import org.eclipse.cdt.core.dom.lrparser.gnu.GCCLanguage; -import org.eclipse.cdt.core.dom.lrparser.gnu.GPPLanguage; -import org.eclipse.cdt.core.model.ILanguage; -import org.eclipse.cdt.core.parser.CodeReader; -import org.eclipse.cdt.core.parser.ExtendedScannerInfo; -import org.eclipse.cdt.core.parser.IScannerInfo; -import org.eclipse.cdt.core.parser.ParserUtil; -import org.eclipse.cdt.core.parser.tests.ast2.DOMLocationInclusionTests; -import org.eclipse.cdt.internal.core.dom.SavedCodeReaderFactory; -import org.eclipse.core.resources.IFile; - -@SuppressWarnings("restriction") -public class LRDOMLocationInclusionTests extends DOMLocationInclusionTests { - - public static TestSuite suite() { - return new TestSuite(LRDOMLocationInclusionTests.class); - } - - public LRDOMLocationInclusionTests() { - } - - public LRDOMLocationInclusionTests(String name, Class className) { - super(name, className); - } - - public LRDOMLocationInclusionTests(String name) { - super(name); - } - - @Override - protected IASTTranslationUnit parse(IFile code, IScannerInfo s)throws Exception { - // TODO: total freakin hack! the test suite needs to be refactored - ILanguage lang = code.getName().endsWith("cc") ? getCPPLanguage() : getCLanguage(); //$NON-NLS-1$ - - CodeReader codeReader = new CodeReader(code.getLocation().toOSString()); - IASTTranslationUnit tu = lang.getASTTranslationUnit(codeReader, s, SavedCodeReaderFactory.getInstance(), null, ILanguage.OPTION_ADD_COMMENTS, ParserUtil.getParserLogService()); - - return tu; - } - - @Override - protected IASTTranslationUnit parse(IFile code) throws Exception { - - return parse(code, new ExtendedScannerInfo()); - } - - - protected ILanguage getCLanguage() { - return GCCLanguage.getDefault(); - } - - protected ILanguage getCPPLanguage() { - return GPPLanguage.getDefault(); - } - - -} diff --git a/lrparser/org.eclipse.cdt.core.lrparser.tests/src/org/eclipse/cdt/core/lrparser/tests/LRParserTestSuite.java b/lrparser/org.eclipse.cdt.core.lrparser.tests/src/org/eclipse/cdt/core/lrparser/tests/LRParserTestSuite.java index bcbc5e371c8..48a614d9ad4 100644 --- a/lrparser/org.eclipse.cdt.core.lrparser.tests/src/org/eclipse/cdt/core/lrparser/tests/LRParserTestSuite.java +++ b/lrparser/org.eclipse.cdt.core.lrparser.tests/src/org/eclipse/cdt/core/lrparser/tests/LRParserTestSuite.java @@ -37,7 +37,6 @@ public class LRParserTestSuite extends TestSuite { addTest(LRCPPTests.suite()); addTest(LRCSpecTests.suite()); // a couple of failures addTest(LRDigraphTrigraphTests.suite()); - addTest(LRDOMLocationInclusionTests.suite()); addTest(LRDOMLocationMacroTests.suite()); addTest(LRDOMLocationTests.suite()); addTest(LRDOMPreprocessorInformationTest.suite()); diff --git a/upc/org.eclipse.cdt.core.parser.upc.tests/src/org/eclipse/cdt/core/parser/upc/tests/UPCDOMLocationInclusionTests.java b/upc/org.eclipse.cdt.core.parser.upc.tests/src/org/eclipse/cdt/core/parser/upc/tests/UPCDOMLocationInclusionTests.java deleted file mode 100644 index 43d8a893b5f..00000000000 --- a/upc/org.eclipse.cdt.core.parser.upc.tests/src/org/eclipse/cdt/core/parser/upc/tests/UPCDOMLocationInclusionTests.java +++ /dev/null @@ -1,30 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2006, 2009 IBM Corporation 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: - * IBM Corporation - initial API and implementation - *******************************************************************************/ -package org.eclipse.cdt.core.parser.upc.tests; - -import org.eclipse.cdt.core.dom.upc.UPCLanguage; -import org.eclipse.cdt.core.lrparser.tests.LRDOMLocationInclusionTests; -import org.eclipse.cdt.core.model.ILanguage; - -public class UPCDOMLocationInclusionTests extends LRDOMLocationInclusionTests { - - public UPCDOMLocationInclusionTests() { - } - - public UPCDOMLocationInclusionTests(String name) { - super(name); - } - - @Override - protected ILanguage getCLanguage() { - return UPCLanguage.getDefault(); - } -} diff --git a/upc/org.eclipse.cdt.core.parser.upc.tests/src/org/eclipse/cdt/core/parser/upc/tests/UPCParserTestSuite.java b/upc/org.eclipse.cdt.core.parser.upc.tests/src/org/eclipse/cdt/core/parser/upc/tests/UPCParserTestSuite.java index ff84f06c478..f8959bf35aa 100644 --- a/upc/org.eclipse.cdt.core.parser.upc.tests/src/org/eclipse/cdt/core/parser/upc/tests/UPCParserTestSuite.java +++ b/upc/org.eclipse.cdt.core.parser.upc.tests/src/org/eclipse/cdt/core/parser/upc/tests/UPCParserTestSuite.java @@ -20,7 +20,6 @@ public class UPCParserTestSuite extends TestSuite { addTestSuite(UPCCommentTests.class); addTestSuite(UPCCompletionBasicTest.class); addTestSuite(UPCCompletionParseTest.class); - addTestSuite(UPCDOMLocationInclusionTests.class); addTestSuite(UPCDOMLocationMacroTests.class); addTestSuite(UPCDOMLocationTests.class); addTestSuite(UPCDOMPreprocessorInformationTest.class); diff --git a/xlc/org.eclipse.cdt.core.lrparser.xlc.tests/src/org/eclipse/cdt/core/parser/xlc/tests/base/XlcLRDOMLocationInclusionTests.java b/xlc/org.eclipse.cdt.core.lrparser.xlc.tests/src/org/eclipse/cdt/core/parser/xlc/tests/base/XlcLRDOMLocationInclusionTests.java deleted file mode 100644 index bd593c97705..00000000000 --- a/xlc/org.eclipse.cdt.core.lrparser.xlc.tests/src/org/eclipse/cdt/core/parser/xlc/tests/base/XlcLRDOMLocationInclusionTests.java +++ /dev/null @@ -1,45 +0,0 @@ -/******************************************************************************* - * Copyright (c) 2009 IBM Corporation 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: - * IBM Corporation - initial API and implementation - *******************************************************************************/ -package org.eclipse.cdt.core.parser.xlc.tests.base; - -import junit.framework.TestSuite; - -import org.eclipse.cdt.core.lrparser.tests.LRDOMLocationInclusionTests; -import org.eclipse.cdt.core.lrparser.xlc.XlcCLanguage; -import org.eclipse.cdt.core.lrparser.xlc.XlcCPPLanguage; -import org.eclipse.cdt.core.model.ILanguage; - -public class XlcLRDOMLocationInclusionTests extends LRDOMLocationInclusionTests { - - public XlcLRDOMLocationInclusionTests() { - super(); - } - - public XlcLRDOMLocationInclusionTests(String name, Class className) { - super(name, className); - } - - public XlcLRDOMLocationInclusionTests(String name) { - super(name); - } - - public static TestSuite suite() { - return new TestSuite(XlcLRDOMLocationInclusionTests.class); - } - - protected ILanguage getCLanguage() { - return XlcCLanguage.getDefault(); - } - - protected ILanguage getCPPLanguage() { - return XlcCPPLanguage.getDefault(); - } -} diff --git a/xlc/org.eclipse.cdt.core.lrparser.xlc.tests/src/org/eclipse/cdt/core/parser/xlc/tests/base/XlcLRParserTestSuite.java b/xlc/org.eclipse.cdt.core.lrparser.xlc.tests/src/org/eclipse/cdt/core/parser/xlc/tests/base/XlcLRParserTestSuite.java index d612bcd4599..aea4443936d 100644 --- a/xlc/org.eclipse.cdt.core.lrparser.xlc.tests/src/org/eclipse/cdt/core/parser/xlc/tests/base/XlcLRParserTestSuite.java +++ b/xlc/org.eclipse.cdt.core.lrparser.xlc.tests/src/org/eclipse/cdt/core/parser/xlc/tests/base/XlcLRParserTestSuite.java @@ -37,7 +37,6 @@ public class XlcLRParserTestSuite extends TestSuite { addTest(XlcLRCPPTests.suite()); addTest(XlcLRCSpecTests.suite()); // a couple of failures addTest(XlcLRDigraphTrigraphTests.suite()); - addTest(XlcLRDOMLocationInclusionTests.suite()); addTest(XlcLRDOMLocationMacroTests.suite()); addTest(XlcLRDOMLocationTests.suite()); addTest(XlcLRDOMPreprocessorInformationTest.suite());