123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- /*
- * generated by Xtext 2.10.0
- */
- package be.uantwerpen.ansymo.semanticadaptation.cg.cpp.tests
- import be.uantwerpen.ansymo.semanticadaptation.semanticAdaptation.SemanticAdaptation
- import be.uantwerpen.ansymo.semanticadaptation.tests.AbstractSemanticAdaptationTest
- import be.uantwerpen.ansymo.semanticadaptation.tests.SemanticAdaptationInjectorProvider
- import com.google.inject.Inject
- import java.io.File
- import java.util.regex.Pattern
- import org.eclipse.emf.ecore.EObject
- import org.eclipse.emf.ecore.resource.ResourceSet
- import org.eclipse.xtext.generator.IGeneratorContext
- import org.eclipse.xtext.generator.InMemoryFileSystemAccess
- import org.eclipse.xtext.testing.InjectWith
- import org.eclipse.xtext.testing.XtextRunner
- import org.eclipse.xtext.testing.util.ParseHelper
- import org.eclipse.xtext.testing.validation.ValidationTestHelper
- import org.junit.Test
- import org.junit.runner.RunWith
- import static org.junit.Assert.assertTrue
- import org.junit.Ignore
- import be.uantwerpen.ansymo.semanticadaptation.cg.cpp.generation.CppGenerator
- @RunWith(XtextRunner)
- @InjectWith(SemanticAdaptationInjectorProvider)
- class CgCppModuleTest extends AbstractSemanticAdaptationTest {
- // @Inject CppGenerator underTest
- @Inject extension ParseHelper<SemanticAdaptation>
- @Inject extension ValidationTestHelper
- @Ignore
- @Test def powerwindow_model_only() { __parseNoErrors('input/single_folder_spec/window/window_sa_canonical.BASE.sa') }
- def __parseNoErrors(String filename) {
- val file = new File(filename)
- assertTrue("File not found: " + filename, file.exists);
-
- var SemanticAdaptation model = null;
- if (file.isDirectory) {
- for (f : file.listFiles) {
- if (model === null) {
- model = __parse(f.absolutePath)
- } else {
- model = __parse(f.absolutePath, model.eResource.resourceSet)
- }
- __assertNoParseErrors(model, f.absolutePath)
- }
- } else {
- model = __parse(filename)
- __assertNoParseErrors(model, filename)
- }
- val fsa = new InMemoryFileSystemAccess()
- val IGeneratorContext ctxt = null;
- new CppGenerator().doGenerate(model.eResource, fsa, ctxt)
- System.out.println(fsa.allFiles)
- }
- def __parseNoErrorsPrint(String filename) {
- val root = __parse(filename)
- print_ast(root)
- __assertNoParseErrors(root, filename)
- }
- def __parse(String filename) {
- return readFile(filename).parse
- }
- def __parse(String filename, ResourceSet resourceSetToUse) {
- return readFile(filename).parse(resourceSetToUse)
- }
- def __assertNoParseErrors(EObject root, String filename) {
- try {
- root.assertNoErrors
- } catch (AssertionError e) {
- val p = Pattern.compile(".*, offset (?<offset>[0-9]+), length (?<length>[0-9]+)")
- val code = readFile(filename)
- for (String line : e.message.split("\n")) {
- val m = p.matcher(line)
- m.matches()
- val count = __occurrencesInString(code.subSequence(0, Integer.valueOf(m.group("offset"))).toString(),
- "\n")
- print(filename + " at line " + (count + 1) + ": ")
- println(line)
- }
- throw e
- }
- }
- def __occurrencesInString(String str, String findstr) {
- var lastIndex = 0
- var count = 0
- while (lastIndex != -1) {
- lastIndex = str.indexOf(findstr, lastIndex)
- if (lastIndex != -1) {
- count++
- lastIndex += findstr.length()
- }
- }
- return count
- }
- }
|