CORBA Programming with TAOX11. The C++11 CORBA Implementation



Similar documents
URI and UUID. Identifying things on the Web.

sqlpp11 - An SQL Library Worthy of Modern C++

C++ INTERVIEW QUESTIONS

An Incomplete C++ Primer. University of Wyoming MA 5310


N3458: Simple Database Integration in C++11

Introduction to Distributed Computing using CORBA

Netscape Internet Service Broker for C++ Programmer's Guide. Contents

Infrastructure that supports (distributed) componentbased application development

3F6 - Software Engineering and Design. Handout 10 Distributed Systems I With Markup. Steve Young

Storage Classes CS 110B - Rule Storage Classes Page 18-1 \handouts\storclas

C++ Overloading, Constructors, Assignment operator

C++FA 5.1 PRACTICE MID-TERM EXAM

PART-A Questions. 2. How does an enumerated statement differ from a typedef statement?

Getting Started with the Internet Communications Engine

Comp151. Definitions & Declarations

C++ Programming Language

OpenCL Static C++ Kernel Language Extension

Informatica e Sistemi in Tempo Reale

An API for Reading the MySQL Binary Log

Variable Base Interface

Corba. Corba services. The (very) global picture. Corba. Distributed Object Systems 3 CORBA/IDL. Corba. Features. Services

vector vec double # in # cl in ude <s ude tdexcept> tdexcept> // std::ou std t_of ::ou _range t_of class class V Vector { ector {

Object Oriented Software Design II

The C Programming Language course syllabus associate level

Applied Informatics C++ Coding Style Guide

Binary storage of graphs and related data

C++ for Safety-Critical Systems. DI Günter Obiltschnig Applied Informatics Software Engineering GmbH

Qt Signals and Slots. Olivier Goffart. October 2013

Embedded Programming in C/C++: Lesson-1: Programming Elements and Programming in C

Java Interview Questions and Answers

JAVA - QUICK GUIDE. Java SE is freely available from the link Download Java. So you download a version based on your operating system.

The omniorbpy version 3 User s Guide

Object Oriented Software Design II

Network Programming. Writing network and internet applications.

CpSc212 Goddard Notes Chapter 6. Yet More on Classes. We discuss the problems of comparing, copying, passing, outputting, and destructing

Distributed Network Management Using SNMP, Java, WWW and CORBA

Konzepte objektorientierter Programmierung

Channel Access Client Programming. Andrew Johnson Computer Scientist, AES-SSG

Tutorial on C Language Programming

MPLAB Harmony System Service Libraries Help

Course Name: ADVANCE COURSE IN SOFTWARE DEVELOPMENT (Specialization:.Net Technologies)

1 bool operator==(complex a, Complex b) { 2 return a.real()==b.real() 3 && a.imag()==b.imag(); 4 } 1 bool Complex::operator==(Complex b) {

Syntax Check of Embedded SQL in C++ with Proto

Intel EP80579 Software for Security Applications on Intel QuickAssist Technology Cryptographic API Reference

CS 111 Classes I 1. Software Organization View to this point:

SQLITE C/C++ TUTORIAL

AP Computer Science Java Subset

Pemrograman Dasar. Basic Elements Of Java

: provid.ir

1 Abstract Data Types Information Hiding

C++FA 3.1 OPTIMIZING C++

Introduction CORBA Distributed COM. Sections 9.1 & 9.2. Corba & DCOM. John P. Daigle. Department of Computer Science Georgia State University

An Overview of Java. overview-1

The programming language C. sws1 1

C++ Crash Kurs. C++ Object-Oriented Programming

Coding conventions and C++-style

The University of Alabama in Huntsville Electrical and Computer Engineering CPE Test #4 November 20, True or False (2 points each)

For the next three questions, consider the class declaration: Member function implementations put inline to save space.

Crash Course in Java

First Java Programs. V. Paúl Pauca. CSC 111D Fall, Department of Computer Science Wake Forest University. Introduction to Computer Science

How To Port A Program To Dynamic C (C) (C-Based) (Program) (For A Non Portable Program) (Un Portable) (Permanent) (Non Portable) C-Based (Programs) (Powerpoint)

TECHNOLOGY Computer Programming II Grade: 9-12 Standard 2: Technology and Society Interaction

C and C++: Case Studies in Compatibility

C++ Object Persistence with ODB

How to: Use Basic C++, Syntax and Operators

3.5. cmsg Developer s Guide. Data Acquisition Group JEFFERSON LAB. Version

How To Create A C++ Web Service

C++ program structure Variable Declarations

16 Collection Classes

UIL Computer Science for Dummies by Jake Warren and works from Mr. Fleming

Operator Overloading. Lecture 8. Operator Overloading. Running Example: Complex Numbers. Syntax. What can be overloaded. Syntax -- First Example

Polymorphism. Problems with switch statement. Solution - use virtual functions (polymorphism) Polymorphism

Computer Programming C++ Classes and Objects 15 th Lecture

Sources: On the Web: Slides will be available on:

Software documentation systems

C++ DATA STRUCTURES. Defining a Structure: Accessing Structure Members:

Middleware Lou Somers

Overview of CORBA 11.1 I NTRODUCTION TO CORBA Object services 11.5 New features in CORBA Summary

Web Services for Management Perl Library VMware ESX Server 3.5, VMware ESX Server 3i version 3.5, and VMware VirtualCenter 2.5

Java programming for C/C++ developers

Drawing Text with SDL

IVI Configuration Store

C++ Language Tutorial

Object Oriented Software Design II

TivaWare Utilities Library

Implementation of SQLite database support in program gama-local

PROBLEM SOLVING SEVENTH EDITION WALTER SAVITCH UNIVERSITY OF CALIFORNIA, SAN DIEGO CONTRIBUTOR KENRICK MOCK UNIVERSITY OF ALASKA, ANCHORAGE PEARSON

Keywords are identifiers having predefined meanings in C programming language. The list of keywords used in standard C are : unsigned void

Object-Oriented Design Lecture 4 CSU 370 Fall 2007 (Pucella) Tuesday, Sep 18, 2007

OMPT and OMPD: OpenMP Tools Application Programming Interfaces for Performance Analysis and Debugging

Introduction to Java

CORBAservices. Naming. Part of the CORBA Naming Service Interface in IDL. CORBA Naming Service

MPLAB TM C30 Managed PSV Pointers. Beta support included with MPLAB C30 V3.00

Why you shouldn't use set (and what you should use instead) Matt Austern

! " # $ %& %' ( ) ) *%%+, -..*/ *%%+ - 0 ) 1 2 1

Transcription:

CORBA Programming with TAOX11 The C++11 CORBA Implementation

TAOX11: the CORBA Implementation by Remedy IT TAOX11 simplifies development of CORBA based applications IDL to C++11 language mapping is easy to use Greatly reduces the CORBA learning curve Reduces common user mistakes Improves application stability and reliability Significant improvement of run-time performance CORBA AMI support Extended suite of unit tests and examples 2 Copyright Remedy IT

TAOX11 Commercial CORBA implementation by Remedy IT Compliant with the OMG IDL to C++11 language mapping IDL compiler with front end supporting IDL2, IDL3, and IDL3+ Free evaluation versions available from our software support portal! More details on http://taox11.remedy.nl 3 Copyright Remedy IT

Tutorial overview This tutorial gives an overview of the IDL to C++11 language mapping Introduces TAOX11, the C++11 CORBA implementation by Remedy IT It assumes basic understanding of IDL and CORBA 4 Copyright Remedy IT

Introduction 5 Copyright Remedy IT

Problems with IDL to C++ The IDL to C++ language mapping is from the 90 s IDL to C++ could not depend on various C++ features as C++ namespace C++ exceptions Standard Template Library As a result the IDL to C++ language mapping Is hard to use correctly Uses its own constructs for everything 6 Copyright Remedy IT

Why a new language mapping? IDL to C++ language mapping is impossible to change because Multiple implementations are on the market (open source and commercial) A huge amount of applications have been developed An updated IDL to C++ language mapping would force all vendors and users to update their products The standardization of a new C++ revision in 2011 (ISO/IEC 14882:2011, called C++11) gives the opportunity to define a new language mapping C++11 features are not backward compatible with C++03 or C++99 A new C++11 mapping leaves the existing mapping intact 7 Copyright Remedy IT

Goals of IDL to C++11 Simplify mapping for C++ Make use of the new C++11 features to Reduce amount of application code Reduce amount of possible errors made Gain runtime performance Speedup development and testing Faster time to market Reduced costs Reduced training time 8 Copyright Remedy IT

OMG Specification IDL to C++11 v1.2 available from the OMG website as formal/2015-08-01 Revision Task Force (RTF) is active to work on issues reported 9 Copyright Remedy IT

IDL Constructs 10 Copyright Remedy IT

Modules An IDL module maps to a C++ namespace with the same name IDL C++11 module M // definitions }; module A module B // definitions }; }; namespace M // definitions }; namespace A namespace B // definitions }; }; 11 Copyright Remedy IT

Basic Types IDL C++11 Default value short int16_t 0 long int32_t 0 long long int64_t 0 unsigned short uint16_t 0 unsigned long uint32_t 0 unsigned long long uint64_t 0 float float 0.0 double double 0.0 long double long double 0.0 char char 0 wchar wchar_t 0 boolean bool false octet uint8_t 0 12 Copyright Remedy IT

Constants IDL constants are mapped to C++11 constants using constexpr when possible IDL C++11 const string name = "testing"; interface A const float value = 6.23; }; const std::string name "testing"}; class A public: static constexpr float value 6.23F}; }; 13 Copyright Remedy IT

String Types No need to introduce an IDL specific type mapping but leverage STL IDL C++11 string name; wstring w_name; std::string name Hello }; std::wstring w_name; std::cout << name << std::endl; 14 Copyright Remedy IT

Enumerations IDL enums map to C++11 strongly typed enums IDL C++11 enum Color red, green, blue }; enum class Color : uint32_t red, green, blue }; Color mycolor Color::red}; if (mycolor == Color::red) std::cout << Correct color ; } else std::cerr << Incorrect color << mycolor << std::endl; } 15 Copyright Remedy IT

Sequence IDL unbounded sequence maps to std::vector IDL typedef sequence<long> LongSeq; typedef sequence<longseq, 3> LongSeqSeq; C++11 typedef std::vector <int32_t> LongSeq; typedef std::vector <LongSeq> LongSeqSeq; LongSeq mysequence; // Add an element to the vector mysequence.push_back (5); // Dump using C++11 range based for loop for (const int32_t& e : mysequence) std::cout << e << ; << std::end; } 16 Copyright Remedy IT

Struct (1) IDL struct maps to a C++ class with copy and move constructors/assignment operators and accessors IDL C++11 struct Variable string name; }; class Variable public: Variable (); ~Variable (); Variable (const Variable&); Variable (Variable&&); Variable& operator= (const Variable& x); Variable& operator= (Variable&& x); explicit Variable (std::string name); void name (const std::string& _name); void name (std::string&& _name); const std::string& name () const; std::string& name (); }; namespace std template <> void swap (Variable& m1, Variable& m2); }; 17 Copyright Remedy IT

Struct (2) IDL struct maps to a C++ class with copy and move constructors/assignment operators and accessors IDL C++11 struct Variable string name; }; Variable v; Variable v2 ( Hello ); std::string myname Hello }; // Set a struct member v.name (myname); // Get a struct member std::cout << name << v.name () << std::endl; if (v!= v2) std::cerr << names are different <<std::endl; } 18 Copyright Remedy IT

Array IDL array map to C++11 std::array IDL C++11 typedef long L[10]; typedef string V[10]; typedef string M[1][2][3]; typedef std::array <int32_t, 10> L; typedef std::array <std::string, 10> V; typedef std::array <std::array <std::array <std::string, 3>, 2>, 1> M; // Initialize the array F f = 1, 2, 3, 4, 5} } // Check the size of an array if (f.size ()!= 5) 19 Copyright Remedy IT

Reference Types (1) An IDL interface maps to so called reference types Reference types are reference counted, for example given type A Strong reference type behaves like std::shared_ptr and is available as IDL::traits<A>::ref_type Weak reference type behaves like std::weak_ptr and is available as IDL::traits<A>::weak_ref_type A nil reference type is represented as nullptr Invoking an operation on a nil reference results in a INV_OBJREF exception 20 Copyright Remedy IT

Reference Types (2) Given IDL type A the mapping delivers IDL::traits<A> with type traits IDL C++11 interface A // definitions }; // Obtain a reference IDL::traits<A>::ref_type a = //.. obtain a // reference // Obtain a weak reference IDL::traits<A>::weak_ref_type w = a.weak_reference(); // Obtain a strong reference from a weak one IDL::traits<A>::ref_type p = w.lock (); if (a == nullptr) // Legal comparisons if (a!= nullptr ) // legal comparison if (a) // legal usage, true if a!= nullptr if (!a) // legal usage, true if a == nullptr if (a == 0) // illegal, results in a compile // error delete a; // illegal, results in a compile error 21 Copyright Remedy IT

Reference Types (3) Reference types can only be constructed using CORBA::make_reference IDL C++11 interface A // definitions }; // Servant implementation class class A_impl final : public CORBA::servant_traits<A>::base_type } // Create a servant reference using // make_reference CORBA::servant_traits<A>::ref_type a_ref = CORBA::make_reference<A_impl> (); // We could use new, but the resulting // pointer can t be used for making any // CORBA call because the pointer can t be // used to construct a reference type which // is the only thing the API accepts A_impl* p = new ACE_impl (); // Or we can obtain a reference from another // method IDL::traits<A>::ref_type = foo->get_a (); 22 Copyright Remedy IT

Reference Types (4) Widening and narrowing references IDL C++11 interface A // definitions }; interface B : A // definitions }; IDL::traits<B>::ref_type bp =... // Implicit widening IDL::traits<A>::ref_type ap = bp; // Implicit widening IDL::traits<Object>::ref_type objp = bp; // Implicit widening objp = ap; // Explicit narrowing bp = IDL::traits<B>::narrow (ap) 23 Copyright Remedy IT

Argument Passing Simplified rules for argument passing compared to IDL to C++ No need for new/delete when passing arguments The C++11 move semantics can be used to prevent copying of data Given an argument of A of type P: In: for all primitive types, enums, and reference types, the argument is passed as P. For all other types, the argument is passed as const P& Inout: passed as P& Out: passed as P& Return type: returned as P 24 Copyright Remedy IT

IDL Traits For each IDL type a IDL::traits<> specialization will be provided The IDL traits contain a set of members with meta information for the specific IDL type The IDL traits are especially useful for template meta programming 25 Copyright Remedy IT

Implement Interfaces Given a local interface A the implementation has to be derived from IDL::traits<A>::base_type Given a regular interface A the CORBA servant implementation has to be derived from CORBA::servant_traits<A>::base_type In both cases a client reference is available as IDL::traits<A>::ref_type 26 Copyright Remedy IT

CORBA AMI TAOX11 has support for the callback CORBA AMI support The TAO AMI implementation has the disadvantage that when AMI is enabled for an IDL file all users have to include the TAO Messaging library TAOX11 separates CORBA AMI into a new set of source files, a client not needing AMI doesn t have to link any CORBA Messaging support! All sendc_ operations are member of a derived CORBA AMI stub, not part of the regular synchronous stub 27 Copyright Remedy IT

CORBA AMI Traits Instead of remembering some specific naming rules a new CORBA::amic_traits<> trait has been defined Contains the concrete types as members replyhandler_base_type: the base type for implementing the reply handler servant replyhandler_servant_ref_type: the type for a reference to the servant of the reply handler ref_type: the client reference to the stub with all synchronous operations 28 Copyright Remedy IT

CORBA AMI Example // Obtain a regular object reference from somewhere, Test::A has one method called foo IDL::traits<Test::A>::ref_type stub = ; // Narrow the regular object reference to the CORBA AMI stub (assuming this has been // enabled during code generation CORBA::amic_traits<Test::A>::ref_type async_stub = CORBA::amic_traits<Test::A>::narrow (stub); // Assume we have a Handler class as reply handler implemented, create it and // register this as CORBA servant CORBA::amic_traits<Test::A>::replyhandler_servant_ref_type h = CORBA::make_reference<Handler> (); PortableServer::ObjectId id = root_poa->activate_object (h); IDL::traits<CORBA::Object>::ref_type handler_ref = root_poa->id_to_reference (id); CORBA::amic_traits<Test::A>::replyhandler_ref_type test_handler = CORBA::amic_traits<Test::A>::replyhandler_traits:::narrow (handler_ref); // Invoke an asynchronous operation, can only be done on async_stub, not on stub async_stub->sendc_foo (test_handler, 12); // But we can also invoke a synchronous call async_stub->foo (12); 29 Copyright Remedy IT

Valuetypes Valuetypes are mapped to a set of classes which are accessible through the IDL::traits<> IDL::traits<>::base_type provides the abstract base class from which the valuetype implementation could be derived from IDL::traits<>::obv_type provides the object by value class that implements already all state accessors and from which the valuetype implementation can be derived from IDL::traits<>::factory_type provides base class for the valuetype factory implementation 30 Copyright Remedy IT

Example CORBA application 31 Copyright Remedy IT

CORBA Hello world IDL interface Hello /// Return a simple string string get_string (); /// A method to shutdown the server oneway void shutdown (); }; 32 Copyright Remedy IT

CORBA client int main(int argc, char* argv[]) try // Obtain the ORB IDL::traits<CORBA::ORB>::ref_type orb = CORBA::ORB_init (argc, argv); // Create the object reference IDL::traits<CORBA::Object>::ref_type obj = orb->string_to_object ("file://test.ior"); // Narrow it to the needed type IDL::traits<Test::Hello>::ref_type hello = IDL::traits<Test::Hello>::narrow (obj); // Invoke a method, invoking on a nil reference will result in an exception std::cout << "hello->get_string () returned " << hello->get_string () << std::endl; // Shutdown the server hello->shutdown (); } // Cleanup our ORB orb->destroy (); } catch (const std::exception& e) // All exceptions are derived from std::exception std::cerr << "exception caught: " << e.what () << std::endl; } return 0; 33 Copyright Remedy IT

CORBA servant C++11 CORBA servant for type T must be derived from CORBA::servant_traits<T>::base_type class Hello final : public CORBA::servant_traits<Test::Hello>::base_type public: // Constructor Hello (IDL::traits<CORBA::ORB>::ref_type orb) : orb_ (orb) } // Destructor virtual ~Hello () } // Implement pure virtual methods from the base_type virtual std::string get_string () override return Hello! ; } virtual void shutdown () override this->orb_->shutdown (false); } private: // Use an ORB reference to shutdown the application. IDL::traits<CORBA::ORB>::ref_type orb_; }; 34 Copyright Remedy IT

CORBA server (1) int main(int argc, char* argv[]) try // Obtain our ORB IDL::traits<CORBA::ORB>::ref_type orb = CORBA::ORB_init (argc, argv); // Obtain our POA and POAManager IDL::traits<CORBA::Object>::ref_type obj = orb->resolve_initial_references ("RootPOA"); IDL::traits<PortableServer::POA>::ref_type root_poa = IDL::traits<PortableServer::POA>::narrow (obj); IDL::traits<PortableServer::POAManager>::ref_type poaman = root_poa->the_poamanager (); // Create the servant CORBA::servant_traits<Test::Hello>::ref_type hello_impl = CORBA::make_reference<Hello> (orb); // Activate the servant as CORBA object PortableServer::ObjectId id = root_poa->activate_object (hello_impl); IDL::traits<CORBA::Object>::ref_type hello_obj = root_poa->id_to_reference (id); IDL::traits<Test::Hello>::ref_type hello = IDL::traits<Test::Hello>::narrow (hello_obj); // Put the IOR on disk std::string ior = orb->object_to_string (hello); std::ofstream fos("test.ior"); fos << ior; fos.close (); 35 Copyright Remedy IT

CORBA server (2) // Activate our POA poaman->activate (); // And run the ORB, this method will return at the moment the ORB has been shutdown orb->run (); // Cleanup our resources root_poa->destroy (true, true); orb->destroy (); } catch (const std::exception& e) // Any exception will be caught here std::cerr << "exception caught: " << e.what () << std::endl; } } return 0; 36 Copyright Remedy IT

Auto specifier C++11 has support for auto as new type specifier The compiler will deduce the type of a variable automatically from its initializers Will simplify the CORBA example further 37 Copyright Remedy IT

CORBA client int main(int argc, char* argv[]) try // Obtain the ORB auto orb = CORBA::ORB_init (argc, argv); // Create the object reference auto obj = orb->string_to_object ("file://test.ior"); // Narrow it to the needed type auto hello = IDL::traits<Test::Hello>::narrow (obj); // Invoke a method, invoking on a nil reference will result in an exception std::cout << "hello->get_string () returned " << hello->get_string () << std::endl; // Shutdown the server hello->shutdown (); } // Cleanup our ORB orb->destroy (); } catch (const std::exception& e) // All exceptions are derived from std::exception std::cerr << "exception caught: " << e.what () << std::endl; } return 0; 38 Copyright Remedy IT

CORBA servant C++11 CORBA servant for type T must be derived from CORBA::servant_traits<T>::base_type class Hello final : public CORBA::servant_traits<Test::Hello>::base_type public: // Constructor Hello (IDL::traits<CORBA::ORB>::ref_type orb) : orb_ (orb) } // Destructor virtual ~Hello () } // Implement pure virtual methods from the base_type virtual std::string get_string () override return Hello! ; } virtual void shutdown () override this->orb_->shutdown (false); } private: // Use an ORB reference to shutdown the application. IDL::traits<CORBA::ORB>::ref_type orb_; }; 39 Copyright Remedy IT

CORBA server (1) int main(int argc, char* argv[]) try // Obtain our ORB auto _orb = CORBA::ORB_init (argc, argv); // Obtain our POA and POAManager auto obj = _orb->resolve_initial_references ("RootPOA"); auto root_poa = IDL::traits<PortableServer::POA>::narrow (obj); auto poaman = root_poa->the_poamanager (); // Create the servant auto hello_impl = CORBA::make_reference<Hello> (orb); // Activate the servant as CORBA object auto id = root_poa->activate_object (hello_impl); auto hello_obj = root_poa->id_to_reference (id); auto hello = IDL::traits<Test::Hello>::narrow (hello_obj); // Put the IOR on disk auto ior = orb->object_to_string (hello); std::ofstream fos("test.ior"); fos << ior; fos.close (); 40 Copyright Remedy IT

CORBA server (2) // Activate our POA poaman->activate (); // And run the ORB, this method will return at the moment the ORB has been shutdown orb->run (); // Cleanup our resources root_poa->destroy (true, true); orb->destroy (); } catch (const std::exception& e) // Any exception will be caught here std::cerr << "exception caught: " << e.what () << std::endl; } } return 0; 41 Copyright Remedy IT

Tips & Tricks Don t use new/delete Use pass by value together with C++11 move semantics 42 Copyright Remedy IT

Conclusion C++11 simplifies CORBA programming The combination of reference counting and C++11 move semantics make the code much safer and secure Application code is much smaller and easier to read 43 Copyright Remedy IT

Want to know more? Look at the TAOX11 website at http://taox11.remedy.nl Check the Remedy IT provided examples at https://github.com/remedyit/idl2cpp11 Request your free-of-charge evaluation license, see http://swsupport.remedy.nl Contact us, see http://www.remedy.nl 44 Copyright Remedy IT

Contact Remedy IT Postbus 81 6930 AB Westervoort The Netherlands tel.: +31(0)88 053 0000 e-mail: sales@remedy.nl website: www.remedy.nl Twitter: @RemedyIT Slideshare: RemedyIT Subscribe to our mailing list 45 Copyright Remedy IT