Skip to main content

Notice: this Wiki will be going read only early in 2024 and edits will no longer be possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.

Jump to: navigation, search

Difference between revisions of "Acceleo/ReleaseReview/3.2"

(First version of the Acceleo 3.2 release review page.)
 
(Schedule)
 
(21 intermediate revisions by one other user not shown)
Line 1: Line 1:
=Indigo Release Review - Acceleo 3.2=
+
=3.2 Release Review - Acceleo 3.2=
  
 
Mariot Chauvin ''(mariot.chauvin@obeo.fr)''
 
Mariot Chauvin ''(mariot.chauvin@obeo.fr)''
Line 14: Line 14:
  
 
===New and noteworthy===
 
===New and noteworthy===
 +
==== Interpreter view ====
 +
The interpreter view allows the user to enter Acceleo expressions and to execute them without the need to launch a generation.
  
==== Language improvements ====
+
[[Image:Acceleo_Interpreter_Variable_Sample.png|thumb|none|800px|The interpreter view]]
* Support for documentation for templates, queries and modules.
+
[[Image:TemplateDocumentation.png|none|]]
+
  
* Support for TODO and FIXME
+
This new view is available directly in the Acceleo perspective.
[[Image:AcceleoTodo.png|none|]]
+
  
==== Tooling improvements ====
+
==== Performances ====
* Improved real time error detections with new errors detected and warning support.
+
Performances improvements in the compilation and the tooling.
  
[[Image:AcceleoDeprecated.png|none|]]
 
  
* Brand new wizard for the creation of new projects and new modules.
 
  
[[Image:AcceleoWizard.png|none|]]
+
==== JRE selection in the new project wizard ====
 +
When creating a new Acceleo project, you can now choose the JRE of your choice.
  
* Documentation in completion and hover
+
[[Image:Acceleo jre.png|thumb|none|600px|The new project wizard]]
  
[[Image:AcceleoDocumentation.png|none|]]
+
==== Improved compilation ====
 +
The compilation has been improved and as such compiled Acceleo modules (".emtl" files) are now way smaller.
  
* New outline view
+
==== New dynamic modules extension point ====
 +
Users who were using the dynamic module extension point to extends a generator can now use the brand new extension point created to contribute to a specific generator.
  
[[Image:AcceleoOutline.png|none|]]
+
[[Image:Acceleo dynamic modules extension point.png|thumb|none|542px|The new extension point with the old deprecated one.]]
  
* Improved support for metamodels that have not been deployed in a plugin.
+
Acceleo 3.2 is compatible with Eclipse 3.4 (Ganymede), Eclipse 3.5 (Galileo), Eclipse 3.6 (Helios) and Eclipse 3.7 (Indigo).
* New refactoring options
+
 
+
==== Ant and Maven support ====
+
The compilation and the generation can be launched with dedicated Ant tasks and now Acceleo can generated tycho based pom.xml file to build an Acceleo project with maven.
+
 
+
==== New serialization option ====
+
Support of binary resource serialization for Acceleo modules.
+
 
+
[[Image:AcceleoBinaryResource.png|none|]]
+
 
+
Acceleo 3.1 is compatible with Eclipse 3.4 (Ganymede), Eclipse 3.5 (Galileo), Eclipse 3.6 (Helios) and Eclipse 3.7 (Indigo).
+
  
 
===Quality of APIs===
 
===Quality of APIs===
Line 57: Line 46:
  
 
===End of Life Issues===
 
===End of Life Issues===
None
+
The extension point for dynamic templates ("org.eclipse.acceleo.engine.dynamic.templates") is now deprecated. It still works but a new extension point has been contributed instead ("org.eclipse.acceleo.engine.dynamic.modules").
  
 
===Committer Diversity===
 
===Committer Diversity===
Line 66: Line 55:
  
 
CQ 2518 - The Content includes items that have been sourced from the OMG MTL 1.0 specification : http://www.omg.org/spec/MOFM2T/1.0/
 
CQ 2518 - The Content includes items that have been sourced from the OMG MTL 1.0 specification : http://www.omg.org/spec/MOFM2T/1.0/
 +
CQ 5533 - Google Collections Version: 1.0 (PB Orbit CQ3830)
  
 
All other contributions (code, documentation, images, etc) have been committed by individuals who are either Members of the Foundation, or have signed the appropriate Committer Agreement. In either case, these are individuals who have signed, and are abiding by, the Eclipse IP Policy. The other contributions of the IP log are not significant or are written 100% by employees of the same employer (Obeo) as the Submitting Committer (http://www.eclipse.org/legal/EclipseLegalProcessPoster.pdf).
 
All other contributions (code, documentation, images, etc) have been committed by individuals who are either Members of the Foundation, or have signed the appropriate Committer Agreement. In either case, these are individuals who have signed, and are abiding by, the Eclipse IP Policy. The other contributions of the IP log are not significant or are written 100% by employees of the same employer (Obeo) as the Submitting Committer (http://www.eclipse.org/legal/EclipseLegalProcessPoster.pdf).
Line 82: Line 72:
  
 
===Unit tests===
 
===Unit tests===
1803 unit tests are launched every day.
+
2789 unit tests are launched every day.
  
 
Code coverage is about:
 
Code coverage is about:
* 82 % of the traceability engine
+
* 82.9 % of the traceability engine
* 80 % of the compiler
+
* 80.6 % of the compiler
* 65.7 % of the code generation engine
+
* 61.7 % of the code generation engine
  
 
===Code quality===
 
===Code quality===
Line 112: Line 102:
  
 
==Documentation==
 
==Documentation==
The documentation that comes with Acceleo 3.1 is available in the Help menu : Acceleo Model To Text Transformation Language.
+
The documentation that comes with Acceleo 3.2 is available in the Help menu : Acceleo Model To Text Transformation Language.
  
 
Each document of the documentation set deals with a different aspect of mastering Acceleo :
 
Each document of the documentation set deals with a different aspect of mastering Acceleo :
Line 136: Line 126:
 
| blocker
 
| blocker
 
! style="background: #CECEF2;" | 0
 
! style="background: #CECEF2;" | 0
| 1
 
 
| 0
 
| 0
! style="background: #CECEF2;" | 4
+
| 0
! style="background: #CEF2CE;" | 5
+
! style="background: #CECEF2;" | 3
 +
! style="background: #CEF2CE;" | 3
 
|-
 
|-
 
| critical
 
| critical
! style="background: #CECEF2;" | 2
+
! style="background: #CECEF2;" | 1
| 0
+
| 1
 
| 0
 
| 0
! style="background: #CECEF2;" | 3
+
! style="background: #CECEF2;" | 6
! style="background: #CEF2CE;" | 5
+
! style="background: #CEF2CE;" | 8
 
|-
 
|-
 
| major
 
| major
! style="background: #CECEF2;" | 5
+
! style="background: #CECEF2;" | 3
| 0
+
| 3
 
| 0
 
| 0
! style="background: #CECEF2;" | 19
+
! style="background: #CECEF2;" | 8
! style="background: #CEF2CE;" | 24
+
! style="background: #CEF2CE;" | 14
 
|-
 
|-
 
| normal
 
| normal
! style="background: #CECEF2;" | 38
+
! style="background: #CECEF2;" | 23
| 4
+
| 18
 
| 0
 
| 0
! style="background: #CECEF2;" | 129
+
! style="background: #CECEF2;" | 34
! style="background: #CEF2CE;" | 171
+
! style="background: #CEF2CE;" | 75
 
|-
 
|-
 
| minor
 
| minor
! style="background: #CECEF2;" | 5
+
! style="background: #CECEF2;" | 1
| 0
+
| 1
 
| 0
 
| 0
! style="background: #CECEF2;" | 10
+
! style="background: #CECEF2;" | 8
! style="background: #CEF2CE;" | 15
+
! style="background: #CEF2CE;" | 10
 
|-
 
|-
 
| enhancement
 
| enhancement
! style="background: #CECEF2;" | 15
+
! style="background: #CECEF2;" | 7
 
| 3
 
| 3
 
| 0
 
| 0
! style="background: #CECEF2;" | 26
+
! style="background: #CECEF2;" | 6
! style="background: #CEF2CE;" | 44
+
! style="background: #CEF2CE;" | 16
 
|-
 
|-
 
! style="background: #CEF2CE;" | TOTAL
 
! style="background: #CEF2CE;" | TOTAL
 +
! style="background: #CEF2CE;" | 35
 +
! style="background: #CEF2CE;" | 26
 +
! style="background: #CEF2CE;" | 0
 
! style="background: #CEF2CE;" | 65
 
! style="background: #CEF2CE;" | 65
! style="background: #CEF2CE;" | 8
+
! style="background: #CEF2CE;" | 126
! style="background: #CEF2CE;" | 0
+
! style="background: #CEF2CE;" | 191
+
! style="background: #CEF2CE;" | 264
+
 
|}
 
|}
  
Note : these figures are subject to changes as the whole team is in the process of fixing bugs until the final release (this snapshot has been taken on May 17, 2011)‏
+
Note : these figures are subject to changes as the whole team is in the process of fixing bugs until the final release (this snapshot has been taken on September 27, 2011)‏
  
 
==Tool usability==
 
==Tool usability==
Line 197: Line 187:
 
==Communities==
 
==Communities==
 
Talks have been given on the following events:
 
Talks have been given on the following events:
 
* Acceleo at the Eclipse Summit Europe 2010: http://www.eclipsecon.org/summiteurope2010/sessions/?page=sessions&id=1833
 
* Acceleo on e4 during the modeling symposium at the Eclipse Summit Europe 2010: http://www.eclipsecon.org/summiteurope2010/sessions/?page=sessions&id=1898
 
* Acceleo at the Topcased Days 2011: http://www.topcased.org/index.php/content/view/53
 
 
* Acceleo at Code Generation 2011: http://www.codegeneration.net/cg2011/sessioninfo.php?session=24
 
* Acceleo at Code Generation 2011: http://www.codegeneration.net/cg2011/sessioninfo.php?session=24
 +
 +
Talks will be given during EclipseCon Europe 2011.
  
 
Other medium:
 
Other medium:
* Activity on the M2T newsgroup (eclipse.modeling.m2t): more than 170 messages on Acceleo from June 2010 to May 2011
+
* Activity on the M2T newsgroup (eclipse.modeling.m2t): more than 80 threads on Acceleo from June 2010 to May 2011
 
* Twitter account of the Acceleo project: http://twitter.com/acceleo
 
* Twitter account of the Acceleo project: http://twitter.com/acceleo
 
* Acceleo on stack overflow: http://stackoverflow.com/tags/acceleo/info
 
* Acceleo on stack overflow: http://stackoverflow.com/tags/acceleo/info
 
  
 
== Committer Changes ==
 
== Committer Changes ==
Stephane Begaudeau is now committer on Acceleo
+
None
 
+
Mariot Chauvin is now committer on Acceleo and new project lead
+
  
 
==Schedule==
 
==Schedule==
Since the feature freeze our commitment was to follow the EMF and the MDT OCL builds as closely as possible.
+
Acceleo 3.2 Release Plan
 
+
  RC1 10/10/2011
Acceleo 3.1 Release Plan
+
  RC2 10/15/2011
  M1 08/18/2009
+
  Final 10/23/2011
  M2 09/29/2009
+
  3.2    10/24/2011
M3 11/10/2009
+
M4 12/15/2009
+
M5 02/02/2010
+
M6 03/16/2010
+
M7 05/04/2010
+
RC1 05/17/2010
+
RC2 05/25/2010
+
RC3 06/01/2010
+
RC4 06/08/2010
+
  Final 06/16/2010
+
  3.1 06/23/2010
+
 
+
The schedule used is matching the schelude of the [[Indigo/Simultaneous_Release_Plan|release train]] for "+2" projects.
+
  
 
==Project Plan==
 
==Project Plan==
The Indigo project plan is available at http://www.eclipse.org/projects/project-plan.php?planurl=http://www.eclipse.org/modeling/m2t/acceleo/plan-indigo.xml
+
The Acceleo 3.2 project plan is available at http://www.eclipse.org/projects/project-plan.php?planurl=http://www.eclipse.org/modeling/m2t/acceleo/plan-3_2_0.xml
  
 
What's next?
 
What's next?

Latest revision as of 09:20, 10 October 2011

3.2 Release Review - Acceleo 3.2

Mariot Chauvin (mariot.chauvin@obeo.fr)

Release Review : October 1, 2011

Communication Channel : eclipse.modeling.m2t newsgroup

Process Documentation : http://www.eclipse.org/projects/dev_process/development_process.php

Project Plan : http://www.eclipse.org/projects/project-plan.php?planurl=http://www.eclipse.org/modeling/m2t/acceleo/plan-indigo.xml

3.2 Release Highlights

New and noteworthy

Interpreter view

The interpreter view allows the user to enter Acceleo expressions and to execute them without the need to launch a generation.

The interpreter view

This new view is available directly in the Acceleo perspective.

Performances

Performances improvements in the compilation and the tooling.


JRE selection in the new project wizard

When creating a new Acceleo project, you can now choose the JRE of your choice.

The new project wizard

Improved compilation

The compilation has been improved and as such compiled Acceleo modules (".emtl" files) are now way smaller.

New dynamic modules extension point

Users who were using the dynamic module extension point to extends a generator can now use the brand new extension point created to contribute to a specific generator.

The new extension point with the old deprecated one.

Acceleo 3.2 is compatible with Eclipse 3.4 (Ganymede), Eclipse 3.5 (Galileo), Eclipse 3.6 (Helios) and Eclipse 3.7 (Indigo).

Quality of APIs

The component lead certifies that the requirements for Eclipse Quality APIs have been met for this release. All non-API code is in "internal" packages.

End of Life Issues

The extension point for dynamic templates ("org.eclipse.acceleo.engine.dynamic.templates") is now deprecated. It still works but a new extension point has been contributed instead ("org.eclipse.acceleo.engine.dynamic.modules").

Committer Diversity

4 Committers from Obeo, and 2 individual committers.

IP Issues

The about files and use licenses are in place as per the Guidelines to Legal Documentation.

CQ 2518 - The Content includes items that have been sourced from the OMG MTL 1.0 specification : http://www.omg.org/spec/MOFM2T/1.0/ CQ 5533 - Google Collections Version: 1.0 (PB Orbit CQ3830)

All other contributions (code, documentation, images, etc) have been committed by individuals who are either Members of the Foundation, or have signed the appropriate Committer Agreement. In either case, these are individuals who have signed, and are abiding by, the Eclipse IP Policy. The other contributions of the IP log are not significant or are written 100% by employees of the same employer (Obeo) as the Submitting Committer (http://www.eclipse.org/legal/EclipseLegalProcessPoster.pdf).

All contribution Questionnaires have been completed.

The "provider" field of each plugin is set to "Eclipse Modeling Project".

The "copyright" field of each plugin is set to the copyright owner.

Any third-party logos or trademarks included in the distribution (icons, logos, etc) have been licensed under the EPL.

The Acceleo IP log is located at http://www.eclipse.org/projects/ip_log.php?projectid=modeling.m2t.acceleo

Non-Code Aspects

Unit tests

2789 unit tests are launched every day.

Code coverage is about:

  • 82.9 % of the traceability engine
  • 80.6 % of the compiler
  • 61.7 % of the code generation engine

Code quality

Checkstyle activated on each distinct plug-in.

Eclemma used on a regular basis to improve test coverage.

Yourkit used on a regular basis to improve performances.

Javadoc represents more than 44% of the Java source code.

An Ohloh page is available at http://www.ohloh.net/p/acceleo-eclipse/analyses/latest

APIs

Metamodel definitions and interfaces are considered APIs.

Commitment to provide stand-alone code generation.

Non-API classes are separated from the exposed API through an "internal" namespace.

API Tooling is activated on all plugins to mark exceptions within the exposed API.

Non-API packages are exported with an internal visibility as such they are visible but with an illegal access warning.

Documentation

The documentation that comes with Acceleo 3.2 is available in the Help menu : Acceleo Model To Text Transformation Language.

Each document of the documentation set deals with a different aspect of mastering Acceleo : There are a Plug-in Overview, a Quick Start, an Android Code Generation Tutorial, a User Guide, several short tutotials to create code generation projects, an Acceleo/OCL operations reference to describe the Acceleo/OCL library, and a Text Production Rules document.

The main documentation is the User Guide because it fully describes each and every feature of Acceleo. From the installation to the execution with a trip through the editing features, it gives an in-depth description of everything there is to know about Acceleo.

Basic Examples are available in the example category : UML to Java, and Ecore to Python.

There is also a basic information page on the Eclipse Wiki http://wiki.eclipse.org/Acceleo

Bugzilla

NEW RESOLVED VERIFIED CLOSED TOTAL
blocker 0 0 0 3 3
critical 1 1 0 6 8
major 3 3 0 8 14
normal 23 18 0 34 75
minor 1 1 0 8 10
enhancement 7 3 0 6 16
TOTAL 35 26 0 65 126

Note : these figures are subject to changes as the whole team is in the process of fixing bugs until the final release (this snapshot has been taken on September 27, 2011)‏

Tool usability

Localization : integrated into Babel

Standards

This implementation of Acceleo is based on the OMG MOF Model-To-Text OMG Standard : http://www.omg.org/spec/MOFM2T/1.0/

End of Life

There are no specific end of life concerns for this release.

Communities

Talks have been given on the following events:

Talks will be given during EclipseCon Europe 2011.

Other medium:

Committer Changes

None

Schedule

Acceleo 3.2 Release Plan

RC1	10/10/2011
RC2	10/15/2011
Final	10/23/2011
3.2    10/24/2011

Project Plan

The Acceleo 3.2 project plan is available at http://www.eclipse.org/projects/project-plan.php?planurl=http://www.eclipse.org/modeling/m2t/acceleo/plan-3_2_0.xml

What's next?

Legal Notices

Java and all Java-based trademarks are trademarks of Oracle, Inc. in the United States, other countries, or both.

UML, OMG, EMOF, OCL and XMI are trademarks of the Object Management Group.

Other company, product, or service names may be trademarks or service marks of others.



Acceleo Portal
Project Project · Installation
Features Acceleo Features · Runtime · Acceleo editor · Views & Perspective · Interpreter · Maven
User documentation Getting Started · User Guide · Acceleo operations reference · OCL operations reference · Text Production Rules · Migration From Acceleo 2.x · Best Practices · Videos · FAQ
Developer documentation Source code · How to contribute · Compatibility · MOFM2T specification · OCL specification
Community Professional Support · Report a bug

Copyright © Eclipse Foundation, Inc. All Rights Reserved.