From 434857453af8ddaed847b0b46f0489f642737ba0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dr=2E=20S=C3=B6ren=20Henning?= Date: Fri, 9 Apr 2021 14:59:33 +0200 Subject: [PATCH] The Simple Emf4cpp Parser does not Resolve References The parsing call was moved out of the assert statement so that it also gets executed in release builds. A test for working reference resolving was added to the emf4cpp.tests/company example. Change-Id: I6f67ea81358737d4406a44b968a843223613043c (cherry picked from commit 76d49f17a1a661805d3e7f5e4e2f696cc0e8114f) --- emf4cpp.tests/company/test/test.cpp | 6 +++++- emf4cpp/ecorecpp/parser/handler.cpp | 4 +++- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/emf4cpp.tests/company/test/test.cpp b/emf4cpp.tests/company/test/test.cpp index 6d14b2a7..94318b8c 100644 --- a/emf4cpp.tests/company/test/test.cpp +++ b/emf4cpp.tests/company/test/test.cpp @@ -67,7 +67,11 @@ int main(int argc, char* argv[]) EObject_ptr eobj = _dser.load ("UMU.xmi"); { - boost::intrusive_ptr umu (::ecore::as< Company >(eobj)); + Company_ptr umu (::ecore::as< Company >(eobj)); + const auto& departments = umu->getDepartments(); + auto manager = departments[0]->getManager(); + if (!manager) + std::cerr << "No reference to manager!" << std::endl; } } diff --git a/emf4cpp/ecorecpp/parser/handler.cpp b/emf4cpp/ecorecpp/parser/handler.cpp index f2a08e14..b3371744 100644 --- a/emf4cpp/ecorecpp/parser/handler.cpp +++ b/emf4cpp/ecorecpp/parser/handler.cpp @@ -318,7 +318,9 @@ void handler::resolveReferences() ref_parser::SemanticState ss; State< ref_parser::SemanticState > st(ss, s, size); - assert(ref_parser::grammar::references::match(st)); + bool parsingSuccessful = ref_parser::grammar::references::match(st); + assert(parsingSuccessful); + (void)parsingSuccessful; ref_parser::references_t& _references = ss.get_references();