1 Reverse Engineering of Declarative User Interfaces Examination committee: Prof. Bernard Fortz, Université catholique de Louvain, Examiner Prof. Jean-Luc.

Slides:



Advertisements
Similar presentations
Profiles Construction Eclipse ECESIS Project Construction of Complex UML Profiles UPM ETSI Telecomunicación Ciudad Universitaria s/n Madrid 28040,
Advertisements

ARCHITECTURES FOR ARTIFICIAL INTELLIGENCE SYSTEMS
Design Concepts and Principles
Presented by: Thabet Kacem Spring Outline Contributions Introduction Proposed Approach Related Work Reconception of ADLs XTEAM Tool Chain Discussion.
UML CASE Tool. ABSTRACT Domain analysis enables identifying families of applications and capturing their terminology in order to assist and guide system.
Ontologies Reasoning Components Agents Simulations An Overview of Model-Driven Engineering and Architecture Jacques Robin.
1/31 CS 426 Senior Projects Chapter 1: What is UML? Chapter 2: What is UP? [Arlow and Neustadt, 2005] January 22, 2009.
CS 290C: Formal Models for Web Software Lecture 6: Model Driven Development for Web Software with WebML Instructor: Tevfik Bultan.
The Software Product Life Cycle. Views of the Software Product Life Cycle  Management  Software engineering  Engineering design  Architectural design.
1 DSV-IS’2006, July 2006 Visual Design of User Interfaces by (De)composition Sophie Lepreux (1,2), Jean Vanderdonckt (1), Benjamin Michotte (1) 1.
The Re-engineering and Reuse of Software
Towards User Interface Derivation from Business Processes: A Model-Driven Approach for Organizational Engineering Kênia Sousa, Hildeberto Mendonça, Jean.
User Interfaces Composition with UsiXML Sophie LEPREUX (1), Jean VANDERDONCKT (2), Christophe KOLSKI (1) (1) LAMIH “Automated Reasoning and Human-Computer.
Reverse Engineering of Web Pages based on Derivations and Transformations L.Bouillon, Q.Limbourg, J.Vanderdonckt, B.Michotte Université catholique de Louvain,
1 Conceptual Modeling of User Interfaces to Workflow Information Systems Conceptual Modeling of User Interfaces to Workflow Information Systems By: Josefina.
UML Unified Markup Language Ziya Karakaya Atılım University, Computer Engineering
Aurora: A Conceptual Model for Web-content Adaptation to Support the Universal Accessibility of Web-based Services Anita W. Huang, Neel Sundaresan Presented.
Katanosh Morovat.   This concept is a formal approach for identifying the rules that encapsulate the structure, constraint, and control of the operation.
FH Augsburg - FB Informatik 1 CADUI' June FUNDP Namur Software Life Cycle Automation for Interactive Applications: The AME Design Environment.
Workshop on Integrated Application of Formal Languages, Geneva J.Fischer Mappings, Use of MOF for Language Families Joachim Fischer Workshop on.
Chapter 8 Architecture Analysis. 8 – Architecture Analysis 8.1 Analysis Techniques 8.2 Quantitative Analysis  Performance Views  Performance.
1 Belgian Laboratory of Computer-Human Interaction (BCHI) ::: UCL August 2007 Development Method for User Interfaces of Rich Internet Applications By Francisco.
2 1 Chapter 2 Data Models Database Systems: Design, Implementation, and Management, Seventh Edition, Rob and Coronel.
Chapter 1 Understanding the Web Design Environment Principles of Web Design, 4 th Edition.
1 ICAS’2008 – Gosier, March 16-21, 2008 A Transformational Approach for Pattern-based Design of User Interfaces Costin Pribeanu Jean Vanderdonckt National.
Towards supporting the user interfaces design using composition rules Sophie Lepreux, Jean Vanderdonckt {lepreux,
MDE Model Driven Engineering Xavier Blanc Université Pierre et Marie Curie
Introduction to MDA (Model Driven Architecture) CYT.
1 MDWE'2008, Toulouse, France, September 30, 2008 A Comparative Analysis of Transformation Engines for User Interface Development Juan Manuel González.
Assessing the Suitability of UML for Modeling Software Architectures Nenad Medvidovic Computer Science Department University of Southern California Los.
Alignment of ATL and QVT © 2006 ATLAS Nantes Alignment of ATL and QVT Ivan Kurtev ATLAS group, INRIA & University of Nantes, France
SOFTWARE DESIGN.
1 Workshop on Business-Driven Enterprise Application Design & Implementation Cristal City, Washington D.C., USA, July 21, 2008 How to Describe Workflow.
Design Options for Multimodal Web Applications Adrian Stanciulescu and Jean Vanderdonckt {stanciulescu, UCL/IAG/BCHI.
A language to describe software texture in abstract design models and implementation.
1 Geospatial and Business Intelligence Jean-Sébastien Turcotte Executive VP San Francisco - April 2007 Streamlining web mapping applications.
1 Cascading Dialog Modeling with UsiXML Marco Winckler 1,2,Jean Vanderdonckt 2, Adrian Stanciulescu 2, Francisco Trindade 3 1 IRIT, Université Toulouse.
Information Systems Engineering. Lecture Outline Information Systems Architecture Information System Architecture components Information Engineering Phases.
UsiXML July, 2004 (Hamburg, Germany) 1 USIXML: a Language Supporting Multi-Path Development of User Interfaces Quentin Limbourg 1, Jean Vanderdonckt 1,
A first draft of a Model-driven Method for Designing Graphical User Interfaces of Rich Internet Applications Francisco J. Martínez-Ruiz 1, Jaime Muñoz.
Elizabeth Furtado, Vasco Furtado, Kênia Sousa, Jean Vanderdonckt, Quentin Limbourg KnowiXML: A Knowledge-Based System Generating Multiple Abstract User.
1 November 9-11, Mérida, Mexico CLIHC’09 Towards Canonical Task Types for User Interface Design Juan Manuel Gonzalez-Calleros, Josefina Guerrero-
Model-Driven Engineering of Behaviors in User Interfaces Efrem Mbaki & Jean Vanderdonckt Université catholique de Louvain (UCL) Louvain School of Management.
Multi-Path Development of User Interfaces 1 Quentin Limbourg Louvain-la-Neuve, 4th November 2004.
A model-based development for 3D User Interfaces Juan Manuel Gonzalez Calleros Université catholique de Louvain, School of Management (IAG) Information.
Sheet 1 DocEng’03, Grenoble, November 2003 Model Driven Architecture based XML Processing Ivan Kurtev, Klaas van den Berg University of Twente, the Netherlands.
Mir Farooq Ali Computer Science, Virginia Tech May 9, 2003 Building Multi-platform User Interfaces using UIML.
A model-based development for 3D User Interfaces Juan Manuel Gonzalez Calleros 1, Jean Vanderdonckt 1, Jaime Muñoz Arteaga 2 1. Université catholique de.
Murielle Florins 1 IAG-Louvain School of Management ISYS-Information Systems Unit Graceful Degradation: a Method for Designing Multiplatform Graphical.
Software Architecture Evaluation Methodologies Presented By: Anthony Register.
Reference WPx/Tx.y/YY-MM-DD/PP UsiXML project # Generating User Interface for Information Applications from Task, Domain and User models.
Requirements Engineering-Based Conceptual Modelling From: Requirements Engineering E. Insfran, O. Pastor and R. Wieringa Presented by Chin-Yi Tsai.
Nathalie Aquino 1, Jean Vanderdonckt 2, Francisco Valverde 1, Oscar Pastor 1 1 Department of Information Systems and Computation, Valencia University of.
CIM LAB MEETING Presentation on UML Rakesh Mopidevi Kwangyeol Ryu.
A Transformational Approach for Multimodal Web User Interfaces based on UsiXML Adrian Stanciulescu, Quentin Limbourg, Jean Vanderdonckt, Benjamin Michotte.
Architecture View Models A model is a complete, simplified description of a system from a particular perspective or viewpoint. There is no single view.
Murielle Florins 1, Francisco Montero Simarro 2, Jean Vanderdonckt 1, Benjamin Michotte 1 1 Université catholique de Louvain 2 Universidad de Castilla-la-Mancha.
Cooperative Computing & Communication Laboratory A Survey on Transformation Tools for Model-Based User Interface Development Robbie Schäfer – Paderborn.
1 Technical & Business Writing (ENG-715) Muhammad Bilal Bashir UIIT, Rawalpindi.
© TAMODIA’061 The Comets Inspector: Towards Run Time Plasticity Control based on a Semantic Network Alexandre Demeure, Gaëlle Calvary, Joelle Coutaz, Jean.
Chapter 5 System Modeling. What is System modeling? System modeling is the process of developing abstract models of a system, with each model presenting.
21/1/ Analysis - Model of real-world situation - What ? System Design - Overall architecture (sub-systems) Object Design - Refinement of Design.
SEESCOASEESCOA SEESCOA Meeting Activities of LUC 9 May 2003.
Ontologies Reasoning Components Agents Simulations An Overview of Model-Driven Engineering and Architecture Jacques Robin.
Université catholique de Louvain (UCL) Belgian Laboratory of Computer-Human Interaction (BCHI) Place des Doyens, 1 B-1348 Louvain-la-Neuve (Belgium) Presented.
1 February 1-7, Cancun, Mexico ACHI’09 A structured approach to support 3D User Interface Development Juan Manuel Gonzalez-Calleros, Jean Vanderdonckt.
Viewpoint Modeling and Model-Based Media Generation for Systems Engineers Automatic View and Document Generation for Scalable Model- Based Engineering.
Unified Modeling Language
Complexity Time: 2 Hours.
Model-Driven Analysis Frameworks for Embedded Systems
Presentation transcript:

1 Reverse Engineering of Declarative User Interfaces Examination committee: Prof. Bernard Fortz, Université catholique de Louvain, Examiner Prof. Jean-Luc Hainaut, Facultés Universitaires Notre-Dame de la Paix, Reader Prof. Manuel Kolp, Université catholique de Louvain, Examiner Prof. Christophe Kolski, Université de Valenciennes et du Hainaut-Cambrésis, Reader Prof. Jean Vanderdonckt, Université catholique de Louvain, Advisor Louvain-la-Neuve, 21/6/2006 Laurent Bouillon Ph.D. in Management Sciences Information systems

2 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Presentation Outline 1.The reengineering problem 2.Objectives and working hypotheses 3.Reference framework 4.Retargeting 5.Our notation for RE rules 6.Reverse engineering of 1.Web pages (HTML) 2.Phone interfaces (WML & VoiceXML) 3.Windows applications (resource files) 7.Results evaluation 8.Conclusion

3 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ The Reengineering Problem Interactive Software evolution: context of use =(U,P,E) time Platform User Environment Language

4 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ The Reengineering Problem Reengineering of information systems Focuses on reverse engineering Forward engineering has been achieved in several other researches Centered on UI It represents 50% of the total code of an information system Other aspects of information systems are already treated Less portable code which has most of time to be rewritten entirely Reverse Engineering Forward Engineering Functional core Communication Data Base User Interface Source Information System Target Information System Functional core Communication Data Base User Interface Abstract Representation Functional core Communication Data Base User Interface

5 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Shortcomings of Current Approaches Lack of generality : approaches are generally dedicated to peculiar couples of languages or limited scope. Lack of flexibility :RE rules and techniques are applied in a rigid way Lack of controllability : designer can not control the process in the RE / non- explicit transformations

6 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Objectives and Working Hypotheses “The reverse engineering of UI at a higher level of abstraction than the code level supports UI reengineering with more flexibility while preserving predictability, more generality and controllability in the process than with code-to-code (transcoding) approaches or current reverse engineering approaches.” Working Hypotheses Scope: declarative languages (HTML, WML, VoiceXML, resources files) Methodology: model-based approach / model recovery Technique: static analysis Output language: XML compliant UI description language Context: focus on platform

7 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Reference Framework for Multi-Context UIs

8 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Retargeting Retargeting: RE rules tailored for a specific context of use.  Task& Concepts  Abstract UI  ConcreteUI  Final UI  Task& Concepts ‘ Abstract UI ’ ConcreteUI “ Final UI SourceplatformTargetplatform  Task& Concepts  Abstract UI  ConcreteUI  Final UI  Task& Concepts ‘ Abstract UI ’ ConcreteUI “ Final UI SourceplatformTargetplatform

9 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Retargeting (2) Gain Reduce the scope of possible results and translation operations: gain in efficiency Benefits from code to refine RE and allows to remove code know as platform specific: gain in adequacy to the new context of use Allow automated reengineering(no human intervention) Loss Loss of generality and maintanability Loss of distinction of RE and translation Loss of the platform independence of the produced model

10 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Our notation for RE rules Requirements Make explicit the reverse engineering process Use of a common representation for rules for various source (declarative) UIs Outline rules categories reusable for several types of UIs. Other techniques were considered (UML- OCL, TXL, graph transformation…)

11 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Our notation for RE rules Based on several notations and on graph / tree theories. Notation consists of derivation rules (described thanks to sets of operations-functions) applied on tree reprensentation of UI. Derivation rules consider the source language of the FUI and abstract it to another level, allowing to recover a CUI or AUI model thanks to a series of mappings between languages meta-models. Set of basic operations Addnode(x), ModifyAttribute(x.a), DeleteArc(x,y)… Set of functions ParentNode(x), IsLeaf(x), IsInPath(x)…

12 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Example of Derivation Rules Examples: For a textbox in HTML/WML  x  Ts : x = input ٨ (x.type=“text” ٧ x.type=“password” ٧ x.type=NULL)  Addnode (“textComponent”, idtext) where idtext= NodeAmount(Tt) For a table in HTML/WML  x  Ts : x = table ٨ x.border>0  Addnode (“table”, idtable) where idtable = NodeAmount(Tt)   x  Ts : x = table ٨ x.border=0  Addnode (“box”, idbox) where idbox = NodeAmount(Tt)  AddAttribute (idbox, “type”, “vertical”) Input Name=in1 Maxlength=15 Value=login Type=text Element B TextComponent Name=in1 Maxlength=15 defaultContent=login Id=in1 Element Y

13 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Derivation rules categories Rules can be classified into different categories, outlining the common issues in a RE process for various source UIs. Element recovery Attribute detection Layout / temporal ordering analysis Dialog recuperation Hierarchy recovery Multi-model transformations Retargeting operations Element 1Element 2 Element 3 Horizontal box Vertical box Element 1Element 2Line BreakElement 3  x  Tt: x=bix ٨ ((rigthSibling(x)!=table ٧ rigthSibling(x)!=bix ٧ rigthSibling(x)!=cell ٧ rigthSibling(x)!=box) ٨ rigthSibling(x)!=NULL)  CloneNode (rightSibling(x).id, idnew) ٨ RemoveNode (rightSibling(x), rightSibling(x).id) ٨ RemoveArc (ParentNode(rightSibling(x)), rightSibling(x)) ٨ AddArc(x.id, idnew) where idnew =∑ node  Tt Layout Analysis  x  to Tt i,y  to Tt 0 : x = window ٨ (y=box ٧ y=window) ٨x.filename =y.targetfile  CloneNode(x.id, idnew, Tt0) where idnew =∑ node  Tt 0 ٨ RemoveNode(x, x.id) ٨ RemoveArc(ParentNode(x).id, x.id) ٨ z=root(Tt i ) ٨ Remove Node(z,z.id) ٨ AddArc(y.id, idnew)  x  to Tt i,y  to Tt 0 : x = vocalGroup ٨ y=VocalGroup ٨x.filename =y.insertFile  CloneNode(x.id, idnew, Tt0) where idnew =∑ node  Tt0 ٨ RemoveNode(x, x.id) ٨ RemoveArc(ParentNode(x).id, x.id) ٨ z=root(Tt i ) ٨ Remove Node(z,z.id) ٨ AddArc(y.id, idnew) Multi-model transformations

14 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Web Pages:Vaquita First RE study with the following major working hypotheses: Focus on presentational aspects No recovery of layout and dialog XIML presentation model as ouput Static flexible RE of Web Pages

15 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Web Pages:Vaquita Flexibility ensured thanks to reverse engineering options - Implemented in VB 6 - About 10,000 LOC - Local Web page as input

16 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Reengineering with Envir3D a Label First (given) name: 7 sans-serif # normal Left 0 HTML Page Vaquita: reverse engineering XIML Page Envir3D: virtualisation of non-virtual user interface VRML97/X3D file VRML97-enabled browser

17 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Web Pages:ReversiXML Shortcomings Vaquita Requirements ReversiMXL Licensed usage of XIMLFree usage of UsiXML, open-source UIDL Limited recovery of the presentation Complete recovery of CUI (& AUI) including layout and dialog, (but not scripts or CSS) Off-line process permitting no context awareness On-line and off-line tool / on-line process allows the detection of the context of use InteractiveInteractive & batch Almost no interoperability with other tools Interoperability with several tools (IdealXML, QtkXML, GrafiXML…)  2nd reverse engineering tool to overcome shortcomings of Vaquita  Modified working hypothesis:

18 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Web Pages:ReversiXML 2. Syntax Correction 1. Web Page Extraction 3.Selection of Options Tidy 4. Global Scan 5. Local Scan 6. Layout Relations 7. Dialog Relations 8.Model Correction 9. Context Model 10. Save Model Configuration DB UI Model DB WhoAmI Context DB UI Model DB Server Temporary Pages Temporary Information

19 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Web Pages:ReversiXML Written in php 5 On-line RE About 12,000 LOC Set of libraries

20 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Phone Interfaces Major working hypotheses Static RE of WML 1.1 and voiceXML 2.0 up to the CUI in USIXML Recovery of the layout and hierarchy/temporal ordering. Dialog-Navigation analyzed (but not scripts) No retargeting operations Similar method to HTML applied for WML & VoiceXML reverse engineering Description of languages meta-models and derivation rules.

21 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Phone Interfaces WML Several derivation rules identical - or less constraining- to HTML (combined rules starts with T H/W ) RE prototype developed in [Cui05] VoiceXML Derivation rules completely different from HTML and WML Several losses due to ecmascripts integration (conditions, events…).

22 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of WML Phone Interfaces Example Prototype [Cui05] using XSLT + XPATH Local process allowing no design alternatives WML Yahoo! ID: <input name="login" value="" format="*m" />Password: <input type="password" name= "passwd" value="" format="*m" /> Submit <go method="post" href="/raw?"> USIXML <textComponent id= "textComponent_1" glueHorizontal ="left“ isVisible="true" isEnabled= "true" defaultContent="Yahoo! ID: <textComponent id= "textComponent_2" glueHorizontal= "left" defaultContent="" isEditable= "true" isVisible="true"/>

23 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Windows Interfaces Major working hypothesis Static RE of.RC files up to the CUI in USIXML No recovery of dialog No layout, hierarchy and retargeting not covered Resource file have to be modified in order to obtain a tree structure, so that derivation rules can be applied Major difficulties Compact attribute specifications: shortcuts notations / hexadecimal Layout expressed in absolute positions / overlapping elements Hierarchy of elements not clearly defined Attributes values defined/modified in the functional core

24 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Results of the Evaluation Theoretical validation of the HTML RE approach Coverage 93% of HTML tags recovered Coherence Coherent application of rules and, by analogy, of the entire rules set Performance 20 web pages reverse engineered in a classical RE and with retargeting 25% (up to 65%) of size reduction thanks to retargeting and 20% of process time diminution Correction Manual RE of 5 web pages Most important categories are always fully recovered Retargeting preserve correctness of models

25 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Results of the Evaluation Exploratory Study qualitative study achieved by 17 students of LINF2356 course Case studies illustrating various HTML RE techniques Study of reengineering of the Sedan-Bouillon Website thanks to two FE tools: Teresa and QtkXML

26 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Results of the Evaluation With Teresa RE applied without retargeting USIXML CUI model used as input in Teresa that performs translations for another context of use Produces the Web site designed for Pocket PC (XHTML)

27 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Results of theEvaluation With QtkiXML Original UIReengineered UI

28 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Conclusion - Contributions Conceptualization Development of a flexible method in a model- based approach addressing the problem of declarative UI RE process[Boui2a] Retargeting concept [Boui02b] Operationalization 2 HTML RE tools [RIHM,Boui02c, Boui03] Study of full reengineering with Teresa, Envir3D[Boui04], QtkiXML

29 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Conclusion - Contributions(2) Test The validation against four criterion (coverage, coherence, correction, performance) Exploratory study of the use of the tool and RE/retargeting evaluation Generalization Semi-formal notation for RE derivation rules Meta-models and derivation rules for XIML, HTML, WML, VoiceXML, Windows resource files and identification of common RE subproblems [Boui05].

30 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Conclusion - Projects Contributions Cameleon ( ): Approach for Web RE and tool support Contributions to USIXML Similar ( ): Extension of the approach to phone UI and windows applications Extension of USIXML

31 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Conclusion - limitations Dialog aspects of the UI (imperative language). Static RE implies losses, dynamicity needed to complete models. Retargeting concept. Notation for declarative UI with simple CF and representable as a tree. Limited automated reengineering (usability).

32 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Perspectives Short term Extend the coverage of the RE sub-problems for windows UI. Implement two new tools to RE VoiceXML and Windows resources files. Expand the existing implementation of ReversiXML. Long term Widen scope of sources languages (Visual Basic, Delphi…). RE of scripts to recover dialogue entirely. Explore new RE techniques. Complete RE of context model. Study of RE to other languages (UIML…)

33 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Perspectives Begin VB.Form Calculator BorderStyle = 1 'Fixed Single Caption = "Calculator" ClientHeight = 2970 ClientLeft = 2580 ClientTop = 1485 ClientWidth = 3270 ClipControls = 0 'False BeginProperty Font name = "System" charset = 1 weight = 700 size = 9.75 underline = 0 'False italic = 0 'False strikethrough = 0 'False EndProperty Height = 3375 Icon = "CALC.frx":0000 Left = 2520 LinkMode = 1 'Source LinkTopic = "Form1" MaxButton = 0 'False ScaleHeight = 2970 ScaleWidth = 3270 Top = 1140 Width = 3390 Begin VB.CommandButton Number Caption = "7" Height = 480 Index = 7 Left = 120 <Window id=“1” name=“1” isVisible=“true” isEnabled=“true” defaultBorderTitle=“Calculator” borderWidth=“1”height=“358” width=“309”> <Box id=“2” name=“2” type =“verticall” isVisible=“true” isEnabled=“true”> <button isEnabled=“true” … USIXML

34 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 The interactive systems of today are the legacy systems of tomorrow. Therefore, reverse engineering of information systems will never become an obsolete problem itself. THANK YOU FOR YOUR ATTENTION

35 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006

36 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Web Pages:Vaquita Web page extraction HTML Page Tidy Msxml3.dll XML File XIML Presentation model.RES Resource file Detection Structuration Manual modification V AQUITA Translation New DOM writing User Interface Generator WML, VoiceXML, HTM files Reverse Engineering Forward Engineering

37 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Windows Interfaces 14: GROUPBOX "Direction", -1, 135, 22, 60, 34, WS_GROUP 15: AUTORADIOBUTTON "&Up", 234, 140, 30, 45, 12, NOT WS_TABSTOP | WS_GROUP 16: AUTORADIOBUTTON "&Down", 235, 140, 42, 45, 12, NOT WS_TABSTOP <Box id=“18” name=“18” type=“vertical” isVisible=“true” isEnabled=“true” height=“90” width=“55” defaultBorderTitle=“Direction”> <textComponent id=“21” name=“9” defaultContent=“Up” isVisible=“true” isEnabled=“true” textSize=“8” textFont=“Ms Shell Dlg” /> <textComponent id=“24” name=“24” defaultContent=“Down” isVisible=“true” isEnabled=“true” textSize=“8” textFont=“Ms Shell Dlg” /> <button id=“25” name=“205” isVisible=“true” isEnabled=“true” defaultMnemonic=“f” defaultContent=“Find Next” />

38 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Windows Interfaces Windows.RC file Elements recovery Attribute recuperation Hierarchy detection Layout deduction Dialog relations Save model USIXML CUI KB of shortcut notations Windows.RES file DecompilationUI detection

39 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Architecture ReversiXML

40 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Architecture ReversiXML 1.2

41 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 UIML – other languages Valable car USIXML a des capacités d’expression très similaire à UIML (+contexte). Peu de changement conceptuellement, les principes restent les mêmes (détections éléments, attributs, layout…) Différences majeures: UIML plus proche du FUI (incorporation de « code »). Plus grande séparation entre présentation et contenu - (mais resource model en USIXML). Connections avec les autres parties de l’interface et comportement des objets plus précis USIXML plus riche en termes de modèles, différents niveaux d’abstraction et outils non-commerciaux.

42 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Conclusion Contributions categorized into four levels In the conceptualization: The development of a flexible method thanks to a model-based approach addressing the problem of declarative UI RE process The adaptation of the RE definitions to the UI domain and their positions in the conceptual framework (section 2.2). The retargeting concept (section 2.3) and some retargeting rules (appendix G). The constitution of a state of the art in RE (chapter 3) The identification of shortcomings of the output language that led to modifications of the USIXML language. The specification of meta-models illustrating the complete structure of XIML, HTML, WML, VoiceXML, Windows resources files in UML class diagrams (appendix A and B).

43 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Conclusion (2) The development of derivation rules based on these meta- models for HTML (6.3), WML (7.1.3), VoiceXML (7.2.3), Windows resource files (section 8.3) completed by appendix C. Derivation tables for HTML towards XIML presentation model were also described (5.3). For the operationalization: Vaquita for the static flexible RE of HTML files into an XIML presentation model. ReversiXML an online tool allowing the flexible RE of HTML files into a CUI or AUI model expressed in USIXML. A prototype of RE tool able to extract a CUI model from WML files. In the test phase: The validation against four criterion: coverage, correction, coherence and performance(section 9.1)

44 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Conclusion (3) An exploratory study describing a qualitative evaluation of the produced models, the tool, and the advantages of using retargeting (section 9.2.1). Three case studies of various complexities (section 9.2.2) An investigation of the full reengineering by combining the results of ReversiXML with TeresaXML and QtkXML (section 9.2.2) and the reengineering in a virtualization process is also described in section For the last step of generalization: A semi-formal notation for RE derivation rules (chapter 4 and appendix C) for various source UI. A generalization of the reverse engineering method thanks to an analysis of the process applied to a large scope of UI and the identification of common RE tasks to be achieved (section 4.4.8).

45 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 ReversiXML Shortcomings CSS support Javascript RE Embedded components (flash, java...) Universal access Box reduction Use of statistics to refine RE Pursue implementation Site RE Evolution to architecture 1.2 Context model & selection mechanism Complete the RE of AUI

46 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ RE of Phone Interfaces WML or VoiceXML file Elements & attribute recovery Hierarchy/temporal sequence detection Dialog relations Model Correction Model links Save model USIXML CUI Temporary Information

47 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ The Reengineering Problem Benefits of reengineering Practical benefits Economical benefits Theoretical benefits Importance of reengineering Amount of legacy systems (60%) New needs for reengineering New context of use (internet enabled platforms)

48 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 Integration with other works

49 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Results Evaluation Exploratory Study qualitative study achieved by 17 students of LINF2356 course Aim: use ReversiXML and GrafiXML to produce previews of UI suited for mobile phones and pocket PC, by using: retargeting operations manual modifications Conclusion: Produces correct and expected results with various configuration Flexible process/retargeting really important as it allows to save time and efforts during the reengineering process

50 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 MDA compliance Models are expressed in a unified notation and form the cornerstone to understanding software systems (semantics of the models are based on meta-models).  UsiXML models are well-formed models based on XML schema. The semantics of the models are based on meta-models expressed in terms of UML diagrams, from which the XML schema is derived. The building of software systems can be organized around a set of models by applying a series of transformations between models, organized into an architectural framework of layers and transformation.  Model-to-model transformations are specified in UsiXML. Model-to- code transformations are ensured thanks to a set of forward engineering tools. Code-to-model transformations are achieved by derivation rules that are based on the mapping between the meta- model of the source language and the meta-model of UsiXML.

51 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 MDA Compliance (2) A formal underpinning for describing models in a set of meta-models facilitates meaningful integration and transformation among models, and is the basis for automation  All transformations are explicitly defined, based on a series of predefined semantic relationship and a set of the primitive ones (abstraction, reification and translation). Acceptance and adoption of this model-driven approach requires industry standards to provide openness to consumers, and foster competition among vendors.  The last principle is on the way, as the potential wide adoption of the above techniques will validate the principle. Four levels of abstraction are almost similar with the various layers of MDA.

52 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/ Conclusion: rules categories Elements and attributes 46 rules sets Layout / Temporal ordering 6 rules sets/ 10 rules sets Dialog 11 rules sets Hierarchy 6 rules sets Multi-Model transfomation 6 rules sets Retargeting 14 rules sets

53 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 MDE Attention focuses first on the application's business functionality and behavior Same principle but focus on processing/communication UML + MOF

54 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 UsiXML model: Abstract user interface UsiXML model: Concrete user interface Rendering Final user interface UsiXML models: task, domain Generative programming Graph transformations Graph transformations Derivation rules IdealXML ReversiXML FlashiXML VisualiXML TransformiXML GrafiXML VisiXML SketchiXML FormiXML KnowiXML

55 Reverse engineering of declarative user interfaces – Thesis – Louvain-la-Neuve - 21/06/2006 QVT UML to UML mappings Too complex for the objectives of our notation Tools applies on UML diagrams, based on UML meta-models, not on code based on UML meta-models Open question, as released recently