Dimensions of Object-Based Language Design Peter Wegner

Total Page:16

File Type:pdf, Size:1020Kb

Dimensions of Object-Based Language Design Peter Wegner Dimensions of Object-Based Language Design Peter Wegner Department of Computer Science Brown University Providence RI 02912 Abstract: These features span the design space of object-based The design space of object-based languages is languages. Each relates to a different aspect of com- characterized in terms of objects, classes, inheritance, putational behavior. Objects are autonomous enti- data abstraction, strong typing, concurrency, and ties that respond to messages or operations and share persistence. Language classes (paradigms) associated a state. Classes classify objects by their common with interesting subsets of these features are operations. Inheritance serves to classify classes by identified and language design issues for selected their shared behavior. Data abstraction hides the paradigms are examined. Orthogonal dimensions representation of data and the implementation of that span the object-oriented design space are related operations. Strong typing imposes static constraints to non-orthogonal features of real languages. The on the appiicability of operations, both within and self-referential application of object-oriented metho- among objects. Concurrency allows objects to exe- dology to the development of object-based language cute concurrently with other objects and to have paradigms is demonstrated. internal concurrency. Persistence allows object iden- tity to persist across applications and to be indepen- Delegation is defined as a generalization of dent of values or keys used in object selection. inheritance and design alternatives such as non-strict, multiple, and abstract inheritance are considered. Language classes worthy of special study are Actors and prototypes are presented as examples of identified and the efficiency, simplicity, and methodol- classless (delegation based) languages. Processes are ogy of the associated paradigms is examined. We classified by their degree of internal concurrency. first consider just objects, classes, and inheritance, The potential inconsistency of object-oriented sharing then add data abstraction and strong typing, and and distributed autonomy is discussed, suggesting finally consider concurrency and persistence. Along that compromises between sharing and autonomy will the way global properties of design dimensions such be necessary in designing strongly typed object- as consistency and orthogonality are introduced and oriented distributed database languages. related to non-orthogonal features that occur in real languages. 1. Design Space for Object-Based Languages 2. Objects, Classes, and Inheritance In order to examine design alternatives for object-based languages the following “dimensions” of Objects have the following properties: language design are considered: object: An object has a set of “operations” and a that remembers the effect of operations. objects “state” classes Objects may be contrasted with functions, which have no memory. Function values are completely inheritance determined by their arguments, being precisely the data abstraction same for each invocation. In contrast, the value strong typing returned by an operation on an object may depend concurrency on its state as well as its arguments. An object may persistence learn from experience, its reaction to an operation Permission to copy without fee all or part of this material is granted provided being determined by its invocation history. that the copies are not made or distributed for direct commerical advantage, the ACM copyright notice and the title of the publication and its date appear, and notice is given that copying is by permission of the Association for The term “object-based language” may now be Computing Machinery. To copy otherwise, or to republish, requires a fee and/ defined as follows: or specific permission. ici 1987 ACM O-8979 l-247-0/87/00 10-0168 $1.50 168 OOPSLA ‘87 Proceedings October 4-8,1987 object-based language: A language is object-based The class of object-oriented languages is nar- if it supports objects as a language feature. rower than the class of object-based languages, excluding languages like Ada, Modula, and CLU but including languages like Smalltalk and C++. Support of objects is a necessary but not sufficient requirement for being object-oriented. Ada is object-based but is not object-oriented Object-oriented languages must additionally support according to our definition because its objects (pack- object classes and class inheritance: ages) do not have a class (type). CLU’s clusters are effectively classes since they serve as templates for object-oriented language: An object-based creating instances and allow instances to be “first- language is object-oriented if its objects belong to class objects” in the sense that they can be assigned classes and class hierarchies may be incrementally to variables, be passed as parameters, and be com- defined by an inheritance mechanism. That is: ponents of structures. But CLU does not have an inheritance relation for defining hierarchical relations object-oriented = objects + classes + inheritance between clusters, and is therefore not object-oriented. In accordance with our approach of naming The notions “class” and “inheritance” used in “interesting*’ language classes we call object-based the above definition can be defined as follows: languages which require every object to have a class “class-based” or “classical” languages. class: A class is a template (cookie cutter) from which objects may be created by “create” or “new” class-based (classical) languages: An object-based operations. Objects of the same class have common language is class-based (classical) if every object has operations and therefore uniform behavior. Classes a class. have one or more “interfaces” that specify the opera- tions accessible to clients through that interface. A Class-based languages are a proper subset of “class body” specifies code for implementing opera- object-based languages, while object-oriented tions in the class interface. languages are in turn a proper subset of class-based languages. Ada is an example of an object-based inheritance: A class may inherit operations from language that is not class-based while CLU is an “superclasses” and may have its operations inherited example of a class-based language that is not object- by “subclasses”. An object of the class C created by oriented. This hierarchy of language classes is illus- the operation “C new” has C as its “base class” and trated in Figure 1. may use operations defined in its base class as well as operations defined in superclasses. Inheritance from a single superclass is called single inheritance; inheri- tance from multiple superclasses is called multiple t classes inheritance. i @&y&.;;;;:, Ada, Actors Inheritance is here defined narrowly as a mechanism for resource sharing in class hierarchies. In the literature the term is used loosely to denote a variety of other forms of hierarchical resource shar- i Simula,Smalltalk ing. We will later define “delegation” as a more gen- eral class-independent term for dynamic hierarchical resource sharing. Figure 1: From Object-Based to Object- The class of object-based languages includes Oriented Languages Ada [DOD], Modula [Wi], CLU [LSAS], and Actor languages [Ag] but not Pascal, Algol, or Fortran. Figure 1 may be viewed as an inheritance Ada’s objects are realized by packages, Modula’s hierarchy which uses object-oriented techniques to objects are called modules, and CLU’s objects are classify object-based languages. We may think of instances of clusters. class-based languages as inheriting the attributes of object-based languages, and of object-oriented languages as in turn inheriting the attributes of both 0&&r 4-a, i 987 OOPSLA‘87 Proceedings 189 the class-based and the object-based languages. This strong typing: A language is strongly typed if type self-application of object-oriented methodology to compatibility of all expressions representing values object-based languages both illustrates its general can be determined from the static program represen- power in classifying and organizing knowledge and tation at compile time. provides substantive insight into the particular domain which is the subject of this paper. Object-oriented languages with data abstrac- It is not surprising that object-oriented inheri- tion and strong typing are a narrower class of tance surfaces as a technique for defining the relation languages with stronger structuring properties than between language classes. Figure 1 classifies the class we have chosen to call object-oriented. This languages into hierarchies by imposing progressively narrower class excludes Simula, whose objects are not stronger requirements on the features they possess. data abstractions because their instance variables Such classification is precisely the purpose of inheri- can be accessed by other objects, and Smalltalk, tance in object-oriented systems, as pointed out in which is not strongly typed because its variables may [we]. be assigned values of different type at different points We briefly consider the impact of objects, of execution. The term “object-oriented” has been classes, and inheritance on programming methodol- carefully defined to be sufficiently narrow to exclude ogy. Objects serve to group operations with the data languages like Ada, Modula, and CLU and sufficiently they will transform and provide a data-oriented prin- broad to include languages like Simula and ciple for program design. Classes serve to manage Smalltalk. collections of objects, allowing
Recommended publications
  • Justice XML Data Model Technical Overview
    Justice XML Data Model Technical Overview April 2003 WhyWhy JusticeJustice XMLXML DataData ModelModel VersionVersion 3.0?3.0? • Aligned with standards (some were not available to RDD) • Model-based Æ consistent • Requirements-based – data elements, processes, and documents • Object-oriented Æ efficient extension and reuse • Expanded domain (courts, corrections, and juvenile) • Extensions to activity objects/processes • Relationships (to improve exchange information context) • Can evolve/advance with emerging technology (RDF/OWL) • Model provides the basis for an XML component registry that can provide • Searching/browsing components and metadata • Assistance for schema development/generation • Reference/cache XML schemas for validation • Interface (via standard specs) to external XML registries April 2003 DesignDesign PrinciplesPrinciples • Design and synthesize a common set of reusable, extensible data components for a Justice XML Data Dictionary (JXDD) that facilitates standard information exchange in XML. • Generalize JXDD for the justice and public safety communities – do NOT target specific applications. • Provide reference-able schema components primarily for schema developers. • JXDD and schema will evolve and, therefore, facilitate change and extension. • Best extension methods should minimize impact on prior schema and code investments. • Implement and represent domain relationships so they are globally understood. • Technical dependencies in requirements, solutions, and the time constraints of national priorities and demands
    [Show full text]
  • Object Query Language Reference Version: Itop 1.0
    Object Query Language Reference Version: Itop 1.0 Overview OQL aims at defining a subset of the data in a natural language, while hiding the complexity of the data model and benefit of the power of the object model (encapsulation, inheritance). Its syntax sticks to the syntax of SQL, and its grammar is a subset of SQL. As of now, only SELECT statements have been implemented. Such a statement do return objects of the expected class. The result will be used by programmatic means (to develop an API like ITOp). A famous example: the library Starter SELECT Book Do return any book existing in the Database. No need to specify the expected columns as we would do in a SQL SELECT clause: OQL do return plain objects. Join classes together I would like to list all books written by someone whose name starts with `Camus' SELECT Book JOIN Artist ON Book.written_by = Artist.id WHERE Artist.name LIKE 'Camus%' Note that there is no need to specify wether the JOIN is an INNER JOIN, or LEFT JOIN. This is well-known in the data model. The OQL engine will in turn create a SQL queries based on the relevant option, but we do not want to care about it, do we? © Combodo 2010 1 Now, you may consider that the name of the author of a book is of importance. This is the case if should be displayed anytime you will list a set of books, or if it is an important key to search for. Then you have the option to change the data model, and define the name of the author as an external field.
    [Show full text]
  • Foundations of the Unified Modeling Language
    Foundations of the Unified Modeling Language. CLARK, Anthony <http://orcid.org/0000-0003-3167-0739> and EVANS, Andy Available from Sheffield Hallam University Research Archive (SHURA) at: http://shura.shu.ac.uk/11889/ This document is the author deposited version. You are advised to consult the publisher's version if you wish to cite from it. Published version CLARK, Anthony and EVANS, Andy (1997). Foundations of the Unified Modeling Language. In: 2nd BCS-FACS Northern Formal Methods Workshop., Ilkley, UK, 14- 15 July 1997. Springer. Copyright and re-use policy See http://shura.shu.ac.uk/information.html Sheffield Hallam University Research Archive http://shura.shu.ac.uk Foundations of the Unified Modeling Language Tony Clark, Andy Evans Formal Methods Group, Department of Computing, University of Bradford, UK Abstract Object-oriented analysis and design is an increasingly popular software development method. The Unified Modeling Language (UML) has recently been proposed as a standard language for expressing object-oriented designs. Unfor- tunately, in its present form the UML lacks precisely defined semantics. This means that it is difficult to determine whether a design is consistent, whether a design modification is correct and whether a program correctly implements a design. Formal methods provide the rigor which is lacking in object-oriented design notations. This provision is often at the expense of clarity of exposition for the non-expert. Formal methods aim to use mathematical techniques in order to allow software development activities to be precisely defined, checked and ultimately automated. This paper aims to present an overview of work being undertaken to provide (a sub-set of) the UML with formal semantics.
    [Show full text]
  • Using Telelogic DOORS and Microsoft Visio to Model and Visualize Complex Business Processes
    Using Telelogic DOORS and Microsoft Visio to Model and Visualize Complex Business Processes “The Business Driven Application Lifecycle” Bob Sherman Procter & Gamble Pharmaceuticals [email protected] Michael Sutherland Galactic Solutions Group, LLC [email protected] Prepared for the Telelogic 2005 User Group Conference, Americas & Asia/Pacific http://www.telelogic.com/news/usergroup/us2005/index.cfm 24 October 2005 Abstract: The fact that most Information Technology (IT) projects fail as a result of requirements management problems is common knowledge. What is not commonly recognized is that the widely haled “use case” and Object Oriented Analysis and Design (OOAD) phenomenon have resulted in little (if any) abatement of IT project failures. In fact, ten years after the advent of these methods, every major IT industry research group remains aligned on the fact that these projects are still failing at an alarming rate (less than a 30% success rate). Ironically, the popularity of use case and OOAD (e.g. UML) methods may be doing more harm than good by diverting our attention away from addressing the real root cause of IT project failures (when you have a new hammer, everything looks like a nail). This paper asserts that, the real root cause of IT project failures centers around the failure to map requirements to an accurate, precise, comprehensive, optimized business model. This argument will be supported by a using a brief recap of the history of use case and OOAD methods to identify differences between the problems these methods were intended to address and the challenges of today’s IT projects.
    [Show full text]
  • Modelling, Analysis and Design of Computer Integrated Manueactur1ng Systems
    MODELLING, ANALYSIS AND DESIGN OF COMPUTER INTEGRATED MANUEACTUR1NG SYSTEMS Volume I of II ABDULRAHMAN MUSLLABAB ABDULLAH AL-AILMARJ October-1998 A thesis submitted for the DEGREE OP DOCTOR OF.PHILOSOPHY MECHANICAL ENGINEERING DEPARTMENT, THE UNIVERSITY OF SHEFFIELD 3n ti]S 5íamc of Allai]. ¿Hoot (gractouo. iHHoßt ¿Merciful. ACKNOWLEDGEMENTS I would like to express my appreciation and thanks to my supervisor Professor Keith Ridgway for devoting freely of his time to read, discuss, and guide this research, and for his assistance in selecting the research topic, obtaining special reference materials, and contacting industrial collaborations. His advice has been much appreciated and I am very grateful. I would like to thank Mr Bruce Lake at Brook Hansen Motors who has patiently answered my questions during the case study. Finally, I would like to thank my family for their constant understanding, support and patience. l To my parents, my wife and my son. ABSTRACT In the present climate of global competition, manufacturing organisations consider and seek strategies, means and tools to assist them to stay competitive. Computer Integrated Manufacturing (CIM) offers a number of potential opportunities for improving manufacturing systems. However, a number of researchers have reported the difficulties which arise during the analysis, design and implementation of CIM due to a lack of effective modelling methodologies and techniques and the complexity of the systems. The work reported in this thesis is related to the development of an integrated modelling method to support the analysis and design of advanced manufacturing systems. A survey of various modelling methods and techniques is carried out. The methods SSADM, IDEFO, IDEF1X, IDEF3, IDEF4, OOM, SADT, GRAI, PN, 10A MERISE, GIM and SIMULATION are reviewed.
    [Show full text]
  • IDEF0 Includes Both a Definition of a Graphical Model
    Faculty of Information Technologies Basic concepts of Business Process Modeling Šárka Květoňová Brno, 2006 Outline • Terminology • A Brief History on Business Activity • The basic approaches to Business Process Modeling – Formal x informal methods of specification and analysis – Verification of the informal defined methods • Software tools for Business Process specification and analysis (ARIS, BP Studio, JARP, Woflan, Flowmake, Oracle BPEL Process Manager, etc.) • Standards of BPM in context of BP Challenges – BPEL, BPMN, BPML, BPQL, BPSM, XPDL, XLANG, WSCI etc. • Mapping of UML Business Processes to BPEL4WS • Conclusions Terminology of BPM • Business Process is a set of one or more linked procedures or activities which collectively realize a business objective or policy goal, normally within the context of an organizational structure defining functional roles and relationships. • Business process model – is the representation of a business process in a form which supports automated manipulation, such as modeling or enactment. The process definition consists of a network of activities and their relationships, criteria to indicate the start and termination of the process, and information about the individual activities, such as participants, associated data, etc. • Workflow – is the automation of a business process, in whole or part, during which documents, information or tasks are passed from one participant to another for action, according to a set of procedural rules. Terminology of BPM • Method is well-considered (sophisticated) system
    [Show full text]
  • Real Time UML
    Fr 5 January 22th-26th, 2007, Munich/Germany Real Time UML Bruce Powel Douglass Organized by: Lindlaustr. 2c, 53842 Troisdorf, Tel.: +49 (0)2241 2341-100, Fax.: +49 (0)2241 2341-199 www.oopconference.com RealReal--TimeTime UMLUML Bruce Powel Douglass, PhD Chief Evangelist Telelogic Systems and Software Modeling Division www.telelogic.com/modeling groups.yahoo.com/group/RT-UML 1 Real-Time UML © Telelogic AB Basics of UML • What is UML? – How do we capture requirements using UML? – How do we describe structure using UML? – How do we model communication using UML? – How do we describe behavior using UML? • The “Real-Time UML” Profile • The Harmony Process 2 Real-Time UML © Telelogic AB What is UML? 3 Real-Time UML © Telelogic AB What is UML? • Unified Modeling Language • Comprehensive full life-cycle 3rd Generation modeling language – Standardized in 1997 by the OMG – Created by a consortium of 12 companies from various domains – Telelogic/I-Logix a key contributor to the UML including the definition of behavioral modeling • Incorporates state of the art Software and Systems A&D concepts • Matches the growing complexity of real-time systems – Large scale systems, Networking, Web enabling, Data management • Extensible and configurable • Unprecedented inter-disciplinary market penetration – Used for both software and systems engineering • UML 2.0 is latest version (2.1 in process…) 4 Real-Time UML © Telelogic AB UML supports Key Technologies for Development Iterative Development Real-Time Frameworks Visual Modeling Automated Requirements-
    [Show full text]
  • Working Document 5.5.4, V6.0 -. | Davide Taibi
    QualiPSo Quality Platform for Open Source Software IST-FP6-IP-034763 Working document 5.5.4, V6.0 User guides for the WP5.5 toolset Anja Hentschel (SIE) Klaus P. Berg (SIE) Vieri del Bianco (INS) Davide Taibi (INS) Davide Tosi (INS) Tomasz Krysztofiak (PNSC) Davide dalle Carbonare (ENG) Hongbo Xu (GMRC) Jonathan Pares (GMRC) Auri Vincenzi (USP) Paulo Meirelles (USP) Due date of deliverable: 31/10/2010 Actual submission date: 31/01/2011 This work is licensed under the Creative Commons Attribution-Share Alike 3.0 License. To view a copy of this license, visit http://creativecommons.org/licenses/by-sa/3.0/ or send a letter to Creative Commons, 171 Second Street, Suite 300, San Francisco, California, 94105, USA QualiPSo • 034763 • WD5.5.4_V6.0 • Page 1 of 138 Change History Version Date Status Author (Partner) Description 0.1 16/08/07 Draft Anja Hentschel Document structure and (SIE) initial content 0.2 22/10/07 Draft Anja Hentschel Input from Max. Almost (SIE) everything completely restructured. 0.3 31/10/07 Draft Anja Hentschel Input from Marion and (SIE) Abbas. 0.4 13/06/08 Draft Anja Hentschel New chapters: Testing (SIE), Klaus Berg (KB), User stories (VdB), (SIE), Vieri del Implementation concept Bianco (INS) (AH) Removed: description of evaluation methods 1.0 30/07/08 Release Anja Hentschel (SIE) 1.1 03/11/08 Draft All New chapters: Tool descriptions, Integration, Experiences and related appendices 1.2 07/11/08 Draft Anja Hentschel Some remaining gaps (SIE) filled 1.3 28/11/08 Draft Anja Hentschel Input from reviews (SIE) included;
    [Show full text]
  • The Java Object Model
    Java Object Model The Java Object Model Topics in this section include: • Java classes, including the use of access rights, inheritance, method definitions, constructors, and instance versus class members • Java packages. • Java interfaces, and why are they are so important • Java dynamic loading, and how application classes are loaded on demand Introduction A Java program consists of a set of class definitions, optionally grouped into packages. Each class encapsulates state and behavior appropriate to whatever the class models in the real world and may dictate access privileges of its members. In this chapter, you will learn how Java supports the primary features of an object- oriented programming system: encapsulation, data hiding, polymorphism, and inheritance. We assume a knowledge of the object-oriented paradigm. Classes Minimally, a class defines a collection of state variables, as well as the functionality for working with these variables. Classes are like C struct or Pascal record definitions that allow function definitions within them. The syntax for defining a class is straightforward: class ClassName { variables methods } For example, an Employee class might resemble: class Employee { String name; ... } Typically, Java classes are defined one per .java file so Employee would be in Employee.java and compiled to Employee.class. When a class references another class, the Java compiler finds the associated class definition to perform type checking and so on. For example, Employee references String, which the © 1996-2003 jGuru.com. All Rights Reserved. Java Object Model -1 Java Object Model compiler finds in file String.class stored in the standard Java class library. Variable Definitions Variable definitions are of the form: modifiers TypeName name; where modifiers include access specifiers (discussed in a section below) and static if the variable is a class variable.
    [Show full text]
  • Automated Analysis of Security-Critical Javascript Apis
    Automated Analysis of Security-Critical JavaScript APIs Ankur Taly Ulfar´ Erlingsson John C. Mitchell Mark S. Miller Jasvir Nagra Stanford University Google Inc. Stanford University Google Inc. Google Inc. [email protected] [email protected] [email protected] [email protected] [email protected] Abstract—JavaScript is widely used to provide client-side object and other critical objects, very little research has been functionality in Web applications. To provide services ranging devoted to rigorously analyzing API confinement. In this from maps to advertisements, Web applications may incor- paper, we therefore study and provide precise semantics for porate untrusted JavaScript code from third parties. The trusted portion of each application may then expose an API to a subset of JavaScript that supports confinement, present an untrusted code, interposing a reference monitor that mediates automated tool that provably verifies confinement, and use access to security-critical resources. However, a JavaScript this tool to analyze code designed to provide confinement. reference monitor can only be effective if it cannot be circum- We consider a variant of a recently-standardized version of vented through programming tricks or programming language JavaScript that supports static scoping and hiding of nested idiosyncracies. In order to verify complete mediation of critical resources for applications of interest, we define the semantics local variables. Using this language, our static analysis of a restricted version of JavaScript devised by the ECMA method examines trusted code used in a hosting page, Standards committee for isolation purposes, and develop and such as security-focused wrapping libraries, and determines test an automated tool that can soundly establish that a given whether it is secure against arbitrary untrusted code in the API cannot be circumvented or subverted.
    [Show full text]
  • Javascript Code Quality Analysis
    JavaScript Code Quality Analysis Master’s Thesis Joost-Wim Boekesteijn JavaScript Code Quality Analysis THESIS submitted in partial fulfillment of the requirements for the degree of MASTER OF SCIENCE in COMPUTER SCIENCE by Joost-Wim Boekesteijn born in Hoogeveen, the Netherlands Software Engineering Research Group m-industries Department of Software Technology M-Industries BV Faculty EEMCS, Delft University of Technology Rotterdamseweg 183c Delft, the Netherlands Delft, the Netherlands www.ewi.tudelft.nl www.m-industries.com c 2012 Joost-Wim Boekesteijn. JavaScript Code Quality Analysis Author: Joost-Wim Boekesteijn Student id: 1174355 Email: [email protected] Abstract Static analysis techniques provide a means to detect software errors early in the development process, without actually having to run the software that is being analyzed. These techniques are common for statically typed languages and have found their way into IDEs such as Eclipse and Visual Studio. However, applying the same techniques to dynamically typed languages is much less common. Tool support is less mature and the amount of published research is relatively small. For this project, we design and build a static analyis tool for JavaScript code. We start by giving background information on relevant parts of the JavaScript language, followed by a survey of existing tools and research. In the design of our analysis tool, we achieved a clear separation of responsibilities between the different modules for parsing, analysis, rule definition and reporting. The level of detail in the default reporter makes our tool an ideal candidate for integration in a JavaScript IDE. On the other hand, our tool is also suited for batch analysis of large code collections.
    [Show full text]
  • Continuous Integration INRIA Java Exercises
    Continuous Integration INRIA Java Exercises Vincent Rouvreau - https://sed.saclay.inria.fr ∗ February 28, 2017 Contents Java Exercises 1 Preamble To go through this exercise, you will need to install : 1. Git (sudo apt-get install git | sudo yum install git) 2. A JDK (sudo apt-get install openjdk-7-jdk | sudo yum install java-1.7.0- openjdk) 3. Maven (sudo apt-get install maven | sudo yum install apache-maven) 2 Unit testing 2.1 Local setup Clone the git repository from INRIA forge and create your own branch First, you will create your personal git repository on the INRIA forge as a branch of the main repository for the TPCISedSaclay project: • Go to https://gforge.inria.fr/projects/tpcisedsaclay • Click on the CODE SOURCE or SCM tab • Click on Request a personal repository ∗This practical tutorial has been originally written by Maurice Br´emond,Ga¨etanHarter and David Parsons from SED INRIA Rh^one-Alpes. I would like to thank them for their help and support. 1 Continuous Integration INRIA Java Exercises • Back to the SCM tab, look for the command to access your personal repository WARNING : do not use the anonymous access (containing anon- scm) Then on a terminal, clone the content of your personal git repository. The correct command should look like this: git clone\ git+ssh://<yourforgelogin>@scm.gforge.inria.fr/gitroot/ tpcisedsaclay/users/<yourforgelogin>.git cd <yourforgelogin>/cxx Project file tree You should have retrieved the following file tree: <yourforgelogin>/java |_ pom.xml |_ src |_ main | |_ java | |_ fr | |_ inria | |_ sed | |_ Sphere.java |_ tst |_ java |_ fr |_ inria |_ sed |_ TestSphere.java The project is made up of : • A Maven Project Object Model file named pom.xml • A file Sphere.java implementing the class Sphere • A file SphereTest.java implementing its test class SphereTest.
    [Show full text]