Evolution and Composition of Object-Oriented Frameworks

Total Page:16

File Type:pdf, Size:1020Kb

Evolution and Composition of Object-Oriented Frameworks Evolution and Composition of Object-Oriented Frameworks Michael Mattsson University of Karlskrona/Ronneby Department of Software Engineering and Computer Science ISBN 91-628-3856-3 © Michael Mattsson, 2000 Cover background: Digital imagery® copyright 1999 PhotoDisc, Inc. Printed in Sweden Kaserntryckeriet AB Karlskrona, 2000 To Nisse, my father-in-law - who never had the opportunity to study as much as he would have liked to This thesis is submitted to the Faculty of Technology, University of Karlskrona/Ronneby, in partial fulfillment of the requirements for the degree of Doctor of Philosophy in Engineering. Contact Information: Michael Mattsson Department of Software Engineering and Computer Science University of Karlskrona/Ronneby Soft Center SE-372 25 RONNEBY SWEDEN Tel.: +46 457 38 50 00 Fax.: +46 457 27 125 Email: [email protected] URL: http://www.ipd.hk-r.se/rise Abstract This thesis comprises studies of evolution and composition of object-oriented frameworks, a certain kind of reusable asset. An object-oriented framework is a set of classes that embodies an abstract design for solutions to a family of related prob- lems. The work presented is based on and has its origin in industrial contexts where object-oriented frameworks have been developed, used, evolved and managed. Thus, the results are based on empirical observations. Both qualitative and quanti- tative approaches have been used in the studies performed which cover both tech- nical and managerial aspects of object-oriented framework technology. Historically, object-oriented frameworks are large monolithic assets which require several design iterations and are therefore costly to develop. With the requirement of building larger applications, software engineers have started to compose multiple frameworks, thereby encountering a number of problems. Five common framework composition problems, together with existing solution approaches and the underlying causes for the problems are presented in this thesis. Adopting a reuse technology, such as object-oriented frameworks, in a software development organization causes changes and additions of practices and proce- dures. We present problems and possible solutions related to these issues. Exam- ples of topics addressed are; domain scoping, business models, verification of the framework’s abstract behavior, and when to release a framework. Object-oriented frameworks, as all software, evolve due to changed and new requirements. The evolution of object-oriented framework can be more costly than conventional soft- ware since there generally exist several applications based on and forced to evolve with the framework. In our studies, we characterize different views of framework evolution. Aspects investigated are structural and behavioral stability, change and growth rates using historical information and effort distribution of framework development and customization. We also provide an assessment of the methods used for characterizing the evolution against the following management issues; identification of evolution-prone modules, framework deployment, change impact analysis, benchmarking and requirements management. As part of these studies, we have extended and validated two proposed methods for software evolution; one for quantitatively assessing stability of a framework, which has been extended with a set of framework stability indicators, and one for identifying evolution-prone modules based on historical information (adapted for object-orientation). Our stud- ies have validated that these methods are feasible and possible to apply on indus- trial object-oriented frameworks. In addition, we provide quantitative evidence that Preface The research work presented in thesis has been carried out as part- time Ph.D. studies since the summer 1992 when I joined the Univer- sity of Karlskrona/Ronneby. This thesis includes a collection of six papers and is organized in the following three parts: n Introduction. The introduction gives a background to the pre- sented papers. Section 1 introduces the notion of object-ori- ented frameworks and our view of effective utilization of framework technology. The section also discusses the follow- ing activities; development & usage, composition and evolu- tion of object-oriented frameworks. Each of the activities is illustrated with one or more typical examples to give the reader an understanding of the phenomena. Section 2 presents an overview of research topics in the framework field. The over- view is presented in a triplet form, <background, existing approaches, research questions>, thereby also giving an over- view of related work. Section 3 describes the research methods used, the main contributions and a summary of the papers. n Framework Composition. This part includes two papers, I-II, the first is about problems and experiences of adopting frame- work technology in an organisation. The second paper lists five problems which may occur when composing two or more frameworks. Except the problems, existing solutions approaches as well as the causes for the problems is presented. Preface n Framework Evolution. This part includes four papers, III-VI, regarding framework evolution. Paper III presents a method for assessing structural and behavioural stability of an evolving framework and its application. Paper IV presents and applies a method for identifying and characterizing the evolution-pron- ess of a framework, its subsystem and their modules. In paper V the relative distribution of effort per development phase and version for a framework and the relationship between frame- work development effort and framework instantiation effort is presented. In Paper VI we have compared and assessed the methods presented and used in papers III-V. The comparison is between the methods and the assessment against a set of evolu- tion issues comprising identification of evolution-prone mod- ules, framework deployment, change impact analysis, benchmarking and requirements management. Through these studies we have obtained knowledge and information about the nature of framework evolution that, hopefully, will assist man- agement making well-informed decisions about a framework’s evolution, thereby ensuring controlled and predictable evolu- tion of functionality and costs for future framework develop- ment efforts. December 1999 Michael Mattsson Acknowledgements The work presented in this thesis was financially supported in parts by Blekinge Forskningsstiftelse and the Foundation for Knowledge and Competence. I am deeply indebted to many persons who have provided help, support and encouragement throughout my work with this thesis. First of all, I want to express my gratitude to my supervisor, colleague and friend Prof. Jan Bosch who always believed in me, for all the work we have done together and for being a friend. Thank you Jan. A special thanks to my friend and colleague PO (PerOlof) Bengtsson for fruitful discussions about meaning- ful and meaningless things. Many thanks to Lennart Olsson, Utilia Consult AB, who introduced me to the field of object-oriented frameworks in the early nineties. He is the reason, directly or indirectly, that many swedish companies, a few mentioned below, were early successful adopters of framework technology, which has been beneficial for my research work. Warm thanks to the co-authors of some publications, Peter Molin (now Symbian AB), Mohamed Fayad, University of Nebraska, Lincoln, and Christer Lundberg, University of Kalmar. I would also thank my other col- leagues and friends in the software engineering research group (RiSE) in Ronneby. Special thanks to the following of our industrial partners for their co- operation; Ericsson Software Technology AB, Axis Communications AB, Althin Medical AB and EC-gruppen AB. A very special thanks to Mikael Roos, Ericsson Software Technology AB, for providing me access to the Billing Gateway framework and to Rolf Svensson and Drazen Milicic (now Wilnor AB) for assistance with source code, documentation and other infor- mation. I would also express my warmest gratitude to my parents, Bertil and Mona, for always being there and having time to take care of our children during high workloads or long journeys. Finally, thanks to my beloved wife Helena and my children Max and Contents Introduction 5 1. Object-Oriented Frameworks ................................................................6 2. Research Topics in the Framework Field ............................................19 3. Research Results ..................................................................................26 Framework Problems and Experiences 41 1. Introduction .........................................................................................42 2. Object-Oriented Frameworks ..............................................................44 3. Examples of Application Frameworks ................................................48 4. Problems and Experiences ...................................................................51 5. Summary .............................................................................................74 Composition Problems, Causes, and Solutions 81 1. Introduction .........................................................................................82 2. Object-Oriented Framework Examples ...............................................84 3. Framework Composition Problems .....................................................87 4. Underlying Causes ..............................................................................93
Recommended publications
  • Ioc Containers in Spring
    301AA - Advanced Programming Lecturer: Andrea Corradini [email protected] http://pages.di.unipi.it/corradini/ AP-2018-11: Frameworks and Inversion of Control Frameworks and Inversion of Control • Recap: JavaBeans as Components • Frameworks, Component Frameworks and their features • Frameworks vs IDEs • Inversion of Control and Containers • Frameworks vs Libraries • Decoupling Components • Dependency Injection • IoC Containers in Spring 2 Components: a recap A software component is a unit of composition with contractually specified interfaces and explicit context dependencies only. A software component can be deployed independently and is subject to composition by third party. Clemens Szyperski, ECOOP 1996 • Examples: Java Beans, CLR Assemblies • Contractually specified interfaces: events, methods and properties • Explicit context dependencies: serializable, constructor with no argument • Subject to composition: connection to other beans – Using connection oriented programming (event source and listeners/delegates) 3 Towards Component Frameworks • Software Framework: A collection of common code providing generic functionality that can be selectively overridden or specialized by user code providing specific functionality • Application Framework: A software framework used to implement the standard structure of an application for a specific development environment. • Examples: – GUI Frameworks – Web Frameworks – Concurrency Frameworks 4 Examples of Frameworks Web Application Frameworks GUI Toolkits 5 Examples: General Software Frameworks – .NET – Windows platform. Provides language interoperability – Android SDK – Supports development of apps in Java (but does not use a JVM!) – Cocoa – Apple’s native OO API for macOS. Includes C standard library and the Objective-C runtime. – Eclipse – Cross-platform, easily extensible IDE with plugins 6 Examples: GUI Frameworks • Frameworks for Application with GUI – MFC - Microsoft Foundation Class Library.
    [Show full text]
  • Automated Support for Software Development with Frameworks
    Automated Support for Software Development with Frameworks Albert Schappert and Peter Sommerlad Wolfgang Pree Siemens AG - Dept.: ZFE T SE C. Doppler Laboratory for Software Engineering D-81730 Munich, Germany Johannes Kepler University - A-4040 Linz, Austria Voice: ++49 89 636-48148 Fax: -45111 Voice: ++43 70 2468-9431 Fax: -9430 g E-mail: falbert.schappert,peter.sommerlad @zfe.siemens.de E-mail: [email protected] Abstract However, the object–oriented concepts and frameworks intro- duce additional complexity to software development. A framework This document presents some of the results of an industrial research gains its functionality by the cooperation of different components. project on automation of software development. The project’s ob- Thus, the use of a single component may be based on its interrela- jective is to improve productivity and quality of software devel- tionships with others that must be understood and mastered by the opment. We see software development based on frameworks and application developer. libraries of prefabricated components as a step in this direction. Present work on software architecture also emphasizes the in- An adequate development style consists of two complementary terrelationships between software components depending on each activities: the creation of frameworks and new components for other to get control on this additional complexity. There the term de- functionality not available and the composition and configuration sign pattern is used to describe and specify component interaction of existing components. mechanisms in an informal way[Pree, 1994a][Buschmann et al., Just providing adequate frameworks and components does not 1994][Gamma et al., 1994].
    [Show full text]
  • The Power of Interoperability: Why Objects Are Inevitable
    The Power of Interoperability: Why Objects Are Inevitable Jonathan Aldrich Carnegie Mellon University Pittsburgh, PA, USA [email protected] Abstract 1. Introduction Three years ago in this venue, Cook argued that in Object-oriented programming has been highly suc- their essence, objects are what Reynolds called proce- cessful in practice, and has arguably become the dom- dural data structures. His observation raises a natural inant programming paradigm for writing applications question: if procedural data structures are the essence software in industry. This success can be documented of objects, has this contributed to the empirical success in many ways. For example, of the top ten program- of objects, and if so, how? ming languages at the LangPop.com index, six are pri- This essay attempts to answer that question. After marily object-oriented, and an additional two (PHP reviewing Cook’s definition, I propose the term ser- and Perl) have object-oriented features.1 The equiva- vice abstractions to capture the essential nature of ob- lent numbers for the top ten languages in the TIOBE in- jects. This terminology emphasizes, following Kay, that dex are six and three.2 SourceForge’s most popular lan- objects are not primarily about representing and ma- guages are Java and C++;3 GitHub’s are JavaScript and nipulating data, but are more about providing ser- Ruby.4 Furthermore, objects’ influence is not limited vices in support of higher-level goals. Using examples to object-oriented languages; Cook [8] argues that Mi- taken from object-oriented frameworks, I illustrate the crosoft’s Component Object Model (COM), which has unique design leverage that service abstractions pro- a C language interface, is “one of the most pure object- vide: the ability to define abstractions that can be ex- oriented programming models yet defined.” Academ- tended, and whose extensions are interoperable in a ically, object-oriented programming is a primary focus first-class way.
    [Show full text]
  • Mystic Microsoft
    Kraig Brockschmidt Mystic Microsoft A Journey of Transformation in the Halls of High Technology Kraig Brockschmidt You’re invited to copy, print, and share this book… It’s free and it’s legal Mystic Microsoft is published under the Creative Commons Attribution-Noncommercial- No Derivative Works 2.5 License (see next page) This means you may freely and legally share, copy, distribute, and display this book without the need to worry about lawyers, royalties, and all that sort of stuff. This book’s website (www.mysticmicrosoft.com) even gives you all the files you need to print and bind your own copies. Of course, you are not allowed to make any changes to this work, nor are you allowed to use it for commercial purposes or profit from it in any way without permission from the author. As this book is offered freely, readers are encouraged, though not required, to reciprocate in two ways: (1) Express gratitude to the author by making a monetary contribution to the author’s work and/or writing a positive testimonial about the book with permission to use your words in promotional activities. See www.mysticmicrosoft.com for details or write to the author’s address on the next page. (2) “Pay it forward” by sharing the book with others and/or making a gift of money or volunteered time to a worthy cause of your choice. So that these gifts do not go unnoticed, please inform the author of your gifts via www.mysticmicrosoft.com (or regular mail) so the website can show the positive contributions that this work has inspired.
    [Show full text]
  • Comprehensive Support for Developing Graphical Highly
    AN ABSTRACT OF THE THESIS OF J-Iuan -Chao Keh for the degree of Doctor of Philosophy in Computer Science presented on July 29. 1991 Title:Comprehensive Support for Developing Graphical. Highly Interactive User Interface Systems A Redacted for Privacy Abstract approved: ed G. Lewis The general problem of application development of interactive GUI applications has been addressed by toolkits, libraries, user interface management systems, and more recently domain-specific application frameworks. However, the most sophisticated solution offered by frameworks still lacks a number of features which are addressed by this research: 1) limited functionality -- the framework does little to help the developer implement the application's functionality. 2) weak model of the application -- the framework does not incorporate a strong model of the overall architecture of the application program. 3) representation of control sequences is difficult to understand, edit, and reuse -- higher-level, direct-manipulation tools are needed. We address these problems with a new framework design calledOregon Speedcode Universe version 3.0 (OSU v3.0) which is shown, by demonstration,to overcome the limitations above: 1) functionality is provided by a rich set of built-in functions organizedas a class hierarchy, 2) a strong model is provided by OSU v3.0 in the form ofa modified MVC paradigm, and a Petri net based sequencing language which together form the architectural structure of all applications produced by OSU v3.0. 3) representation of control sequences is easily constructed within OSU v3.0 using a Petri net editor, and other direct manipulation tools builton top of the framework. In ddition: 1) applications developed in OSU v3.0 are partially portable because the framework can be moved to another platform, and applicationsare dependent on the class hierarchy of OSU v3.0 rather than the operating system of a particular platform, 2) the functionality of OSU v3.0 is extendable through addition of classes, subclassing, and overriding of existing methods.
    [Show full text]
  • The Principles of Object-Oriented Javascript Zakas
    TAKETAKE CONTROLCONTROL OFOF Foreword by Cody Lindley, Best-selling Author and Principal Frontend Architect JAVASCRIPT THE PRINCIPLES OF OBJECT-ORIENTED JAVASCRIPT JAVASCRIPT THE PRINCIPLES OF OBJECT-ORIENTED JAVASCRIPT THETHE PRINCIPLESPRINCIPLES OFOF OBJECTSOBJECTS at TandemSeven OBJECT-ORIENTEDOBJECT-ORIENTED If you’ve used a more traditional object-oriented • How to define your own constructors JAVASCRIPTJAVASCRIPT language, such as C++ or Java, JavaScript probably • How to work with and understand prototypes doesn’t seem object-oriented at all. It has no concept of classes, and you don’t even need to define any • Inheritance patterns for types and objects objects in order to write code. But don’t be fooled — The Principles of Object-Oriented JavaScript will leave NICHOLAS C. ZAKAS JavaScript is an incredibly powerful and expressive even experienced developers with a deeper understand- object-oriented language that puts many design ing of JavaScript. Unlock the secrets behind how objects decisions right into your hands. work in JavaScript so you can write clearer, more In The Principles of Object-Oriented JavaScript, flexible, and more efficient code. Nicholas C. Zakas thoroughly explores JavaScript’s object-oriented nature, revealing the language’s A B O U T T H E A U T H O R unique implementation of inheritance and other key characteristics. You’ll learn: Nicholas C. Zakas is a software engineer at Box and is known for writing on and speaking about the latest • The difference between primitive and reference in JavaScript best practices. He honed his experience values during his five years at Yahoo!, where he was principal • What makes JavaScript functions so unique frontend engineer for the Yahoo! home page.
    [Show full text]
  • Software Development a Practical Approach!
    Software Development A Practical Approach! Hans-Petter Halvorsen https://www.halvorsen.blog https://halvorsen.blog Software Development A Practical Approach! Hans-Petter Halvorsen Software Development A Practical Approach! Hans-Petter Halvorsen Copyright © 2020 ISBN: 978-82-691106-0-9 Publisher Identifier: 978-82-691106 https://halvorsen.blog ii Preface The main goal with this document: • To give you an overview of what software engineering is • To take you beyond programming to engineering software What is Software Development? It is a complex process to develop modern and professional software today. This document tries to give a brief overview of Software Development. This document tries to focus on a practical approach regarding Software Development. So why do we need System Engineering? Here are some key factors: • Understand Customer Requirements o What does the customer needs (because they may not know it!) o Transform Customer requirements into working software • Planning o How do we reach our goals? o Will we finish within deadline? o Resources o What can go wrong? • Implementation o What kind of platforms and architecture should be used? o Split your work into manageable pieces iii • Quality and Performance o Make sure the software fulfills the customers’ needs We will learn how to build good (i.e. high quality) software, which includes: • Requirements Specification • Technical Design • Good User Experience (UX) • Improved Code Quality and Implementation • Testing • System Documentation • User Documentation • etc. You will find additional resources on this web page: http://www.halvorsen.blog/documents/programming/software_engineering/ iv Information about the author: Hans-Petter Halvorsen The author currently works at the University of South-Eastern Norway.
    [Show full text]
  • Everyware Software Framework
    Device Application Framework Everyware Software Framework • Quickly develop your application using M2M/IoT Java packages and services • Build solid, secure, network-centric embedded devices leveraging field proven networking services • Remotely configure and upgrade your application throughout its lifecycle • Take advantage of a solid queuing system for back-end connectivity • Bring your product to market quickly and deterministically while reducing efforts and risks FEATURES Eurotech Everyware Software Framework (ESF) is a device application framework specialized to build machine-to-machine (M2M) or Internet of Things (IoT) applications. ESF provides a highly cost-effective, flexible and IT- oriented framework to build the new generation of connected, smart devices and applications. ESF enables developers to concentrate on the application by providing a set of field proven M2M/IoT building blocks like: • Device abstraction: provides a complete Java consistent software abstraction across all the hardware interfaces like WiFi, Cellular, GPS, Serial, USBs, CAN ports, Digital I/Os, Analog I/Os… • Security: Provides a full set of security features across all layers of the framework (gateway middleware): Authentication, certificate management , secure execution environment, signed bundles, encrypted messaging and firewall. • Gateway basic service: offers ready to use services like time synchronization, serial port configuration, application monitoring, cellular management, Ethernet management… • Network configuration: IP, DHCP, NAT, NTP, and Firewall are just some of the networking services that can be easily configured. • Connectivity and Delivery: default services include sophisticated queuing, always-on connection and self-restoring of the connection. • Field protocols: field-tested industrial, transportation and healthcare protocols are available through Java APIs. Support for custom protocols design.
    [Show full text]
  • Essential Pascal
    Marco Cantù Essential Pascal 2nd Edition, March 2003 (version 2.01) APOLLO, THE GOD WORSHIPED AT DELPHI, IN AN ITALIAN 17TH CENTURY FRESCO. Essential Pascal [Copyright 1995-2003 Marco Cantù] www.marcocantu.com/epascal 1 Introduction he first few editions of Mastering Delphi, the best selling Delphi book I've written, provided an introduction to the Pascal language in Delphi. Due to space constraints and T because many Delphi programmers look for more advanced information, in the latest edition this material was completely omitted. To overcome the absence of this information, I've started putting together this ebook, titled Essential Pascal. This is a detailed book on Pascal, which for the moment will be available for free on my web site (I really don't know what will happen next, I might even find a publisher). This is a work in progress, and any feedback is welcome. The first complete version of this book, dated July '99, has been published on the Delphi 5 Companion CD. Note to the Second Edition After a few years (in the early 2003), the book had a complete revision, trying to refocus it even more on the core features of the Pascal language. Alongside, the book covers the language from the perspective of the Delphi for Windows programmer, but also of the Kylix and Delphi for .NET programmer. Differences among these different versions of the language will be mentioned. This change in focus (not only Delphi with the VCL library) was another reason to change most of the examples from visual ones to console based ones – something I plan doing but that I still haven't done.
    [Show full text]
  • Agent-Based Modeling with the JABM Toolkit
    Noname manuscript No. (will be inserted by the editor) Agent-Based Modeling with the JABM Toolkit Steve Phelps Centre for Computational Finance and Economic Agents (CCFEA) [email protected] the date of receipt and acceptance should be inserted later Abstract In many areas of science, agent-based models have become increasingly important. These models are often sufficiently complex that deriving closed-form solutions for quantitative aspects of their macroscopic behaviour is often impracti- cal if not impossible, and hence they are often analysed using discrete-event simu- lation and Monte-Carlo methods. In this paper we give an overview of agent-based modeling with an emphasis on its application to multi-agent systems research, and show how a software design pattern called \dependency injection" can be used to implement highly configurable simulation models which are able to incorporate various assumptions about agents' rationality and learning. We then show how these ideas have been implemented in the Java Agent-Based Modelling (JABM) toolkit | an open-source framework for building agent-based models. 1 Introduction In this paper we describe practical aspects of developing agent-based simulation models with particular emphasis on agent-based computational economics and work carried out within the trading-agent design and analysis community. We introduce a new software framework for building agent-based models | the Java Agent Based Modeling (JABM) toolkit1. Work on JABM arose out of an earlier project | Java Auction Simulator API (JASA)2 | which was designed as a toolkit for performing experiments in Agent-based Computational Economics (ACE)3 and was subsequently used as the basis of the JCAT software used to run the CAT tournament which is part of the Trading Agent Competition (Cai et al, 2009).
    [Show full text]
  • La Guía De Delphi Por Francisco Charte
    La guía de Delphi por Francisco Charte © Danysoft 2012 2 - DERECHOS RESERVADOS El contenido de esta publicación tiene todos los derechos reservados, por lo que no se puede reproducir, transcribir, transmitir, almacenar en un sistema de recuperación o traducir a otro idioma de ninguna forma o por ningún medio mecánico, manual, electrónico, magnético, químico, óptico, o de otro modo. La persecución de una reproducción no autorizada tiene como consecuencia la cárcel y/o multas. LIMITACIÓN DE LA RESPONSABILIDAD Tanto el autor como en Danysoft hemos revisado el texto para evitar cualquier tipo de error, pero no podemos prometerle que el libro esté siempre libre de errores. Por ello le rogamos nos remita por e-mail sus comentarios sobre el libro a [email protected] DESCUENTOS ESPECIALES Recuerde que Danysoft ofrece descuentos especiales a centros de formación y en adquisiciones por volumen. Para más detalles, consulte con Danysoft. MARCAS REGISTRADAS Todos los productos y marcas se mencionan únicamente con fines de identificación y están registrados por sus respectivas compañías. Autor: Francisco Charte Publicado en castellano por Danysoft Avda. de la Industria, 4 Edif. 1 3º 28108 Alcobendas, Madrid. España. 902 123146 | www.danysoft.com ISBN: 978-84-939910-1-2 Depósito Legal: M-9679-2012 Por acuerdo entre el Autor y Editor, este libro se ofrece sin coste. El contenido no se puede modificar, ni obtener beneficio por su redistribución, ni eliminar la información del autor y editor del mismo. IMPRESO EN ESPAÑA © Danysoft | Madrid, 2012 La guía de DELPHI por Francisco Charte Prólogo - 3 Prólogo A mis hijos: David y Alejandro A mi alma gemela en esta travesía: María Jesús El libro que tienes en tus manos ha sido escrito pensando en los distintos tipos de desarrolladores que podrían estar interesados en la última versión de la herramienta estrella de Embarcadero: Delphi XE2.
    [Show full text]
  • 14. Advanced Windows Concepts
    • multi-tasking or multi-threading of a single application, which 14. Advanced Windows Concepts allow parts of an application to still move ahead with useful This section will survey some advanced concepts used in MS- computations even though other parts of the same application Windows programming. First, we will look at a number of are blocked. forms of Inter-Process Communication (IPC). IPC is the generic Optional Readings: the rest of the chapters from [Shildt95] term used for passing data between different processes, programs, or threads: • The clipboard can be used to cut and paste not only within one application, but between applications. • Drag-And-Drop is a feature for dragging a file to an application window or icon, and having the destination application know what to do with it (and if not running, to be started to deal with it). • Dynamic Data Exchange (DDE) is a simple way for a data server process to allow access by client processes. • Object Linking and Embedding (OLE) has developed past simple embedding another application’s objects (e.g. diagrams or tables) in a document. • Component Object Model (COM) is the underlying mechanism by which the sophisticated features of OLE can work; in fact COM has recently been extended to provide inter- communication between application running on different computers (‘Distributed COM’). We will also briefly look into Dynamic Link Libraries, which allow run-time linking to application or system procedure libraries. Finally, if time permits, we may discuss: • how some of the complications of Windows programming can be abstracted and simplified using a C++ OO class library of various window and control types.
    [Show full text]