La descarga está en progreso. Por favor, espere

La descarga está en progreso. Por favor, espere

Compilación y depuración Modos de ejecución GWT Google Web Toolkit Prof. Ing. Esteban Ramírez.

Presentaciones similares


Presentación del tema: "Compilación y depuración Modos de ejecución GWT Google Web Toolkit Prof. Ing. Esteban Ramírez."— Transcripción de la presentación:

1 Compilación y depuración Modos de ejecución GWT Google Web Toolkit Prof. Ing. Esteban Ramírez

2 Contenido Etapas de un proyecto GWT Debugging in Development Mode. Code Spliting GWT History Mechanism Compilador GWT

3 Etapas de un proyecto GWT

4

5 Debugging in Development Mode Debug Run

6 Run - Development Mode HTTP SERVER CODE SERVER Developer PlugIn Static Content Servlets Client Side Code IDE Run

7 Run - Development Mode HTTP SERVER CODE SERVER Developer PlugIn Static Content Servlets Client Side Code IDE Jetty is a pure Java-based HTTP server and Servlet container

8 Development Mode - GWT

9

10

11

12 Development Mode - Eclipse

13

14 Development Mode – Chrome Plugin En caso que el servidor no este disponible el Plugin emite este mensaje.

15 Debug - in Development Mode Debug

16 Debug - in Development Mode Resume Suspend Terminate F5 Step Into (F5) F7 Step Return (F7) Use step filters F6 Step Over (F6) Drop to frame

17 Compilador Es un programa informático que traduce un programa escrito en un lenguaje de programación a otro lenguaje de programación. Lenguaje 1 Lenguaje 2

18 Compilador GWT

19 Compilador javaScript

20 Compilador javaScript - Detailed java.lang.StringBuffer append(String valor)

21 Compilador javaScript - Pretty java.lang.StringBuffer append(String valor)

22 Compilador javaScript - Obfuscated java.lang.StringBuffer append(String valor)

23 Compilador javaScript

24

25

26 .nocache.js.cache.html.gwt.rpc Host HTML.html

27 Compilador javaScript OpciónDescripción -logLevel The level of logging detail: ERROR, WARN, INFO, TRACE, DEBUG, SPAM, or ALL -workDir The compiler working directory for internal use (must be writeable; defaults to a system temp dir) -gen Debugging: causes normally-transient generated types to be saved in the specified directory -style Script output style: OBF[USCATED], PRETTY, or DETAILED (defaults to OBF) -ea Debugging: causes the compiled output to check assert statements -XdisableClassMetadata EXPERIMENTAL: Disables some java.lang.Class methods (e.g. getName()) -XdisableCastChecking EXPERIMENTAL: Disables run-time checking of cast operations -validateOnly Validate all source code, but do not compile -draftCompile Enable faster, but less-optimized, compilations -optimize Sets the optimization level used by the compiler. 0=none 9=maximum. -compileReport Create a compile report that tells the Story of Your Compile -strict Only succeed if no input files have errors -localWorkers The number of local workers to use when compiling permutations -war The directory into which deployable output files will be written (defaults to 'war') -extra The directory into which extra files, not intended for deployment, will be written

28 Compilador javaScript Optimizaciones : Dead Code Elimination. Constant Folding. Window.alert( Hello + World) $wnd.alert(Hello World) Copy Propagation. a=15; int b= a*a+5; a=15; b=230 String Interning. Code Inlining. Monolithic compilation

29 Compilador javaScript Puntos a tener en cuenta : Paquetes soportados en client – side: java.lang (includes exceptions, classes, general utility methods) java.util (three classes useful for date/time processing) java.io (sorely restricted! including just the Serializable interface) java.sql (also quite limited, includes three classes useful for date/time) obj.getClass().getName() isnt available, but GWT.getTypeName(obj) is. Class.forName("MyClass"), which has GWT.create(MyClass)

30 Deploy module

31 Compilador javaScript

32 Compile Report -compileReport

33 Compile Report -compileReport

34 Compile Report -compileReport

35 Compile Report -compileReport

36 Compile Report -compileReport

37 Compile Report -compileReport

38 Compile Report -compileReport

39 Compile Report -compileReport Have four major use cases: 1.To reduce total download size 2.To reduce download size of initial fragment 3.To reduce download size of specific code fragments as produced by code splitting 4.To compare between permutations, for example, differences between user agents

40 GWT Code Splitting En las aplicaciones AJAX los fuentes de JavaScripts suelen crecer fácilmente. Para ayudar en este inconveniente GWT provee Dead-for-now (DFN) code splitting. Para implementar la segmentacion del codigo simplemente se dbe insertar llamadas al metodo GWT.runAsync en los lugares donde el programa pausará la descarga. Estos puntos son llamados split points.

41 GWT Code Splitting

42

43 Sin split points Con split points

44 GWT Code Splitting

45 GWT History Mechanism Historial del Navegador GWT provee un mecanismo para administrar el historial del navegador que funciona con aplicaciones del tipo Ajax. Para acceder al mismo, es necesario escribir un manejador de eventos que implemente la interfaz HistoryListener y luego éste debe ser registrado en el objeto History : History.newItem("overview"); …. History.newItem("reports");

46 Ejercicios 1- Probar el debug con puntos de corte en el calculo del promedio del curso del proyecto. 2 - Compilar todos los proyectos realizados en los diferentes modos de optimización y comparar los tamaños de los.js generados. 3- Publicar y probar los.war generados en el Apache Tomcat. 4- Probar la generación del reporte de compilación y analizar su contenido. 5- Crear dos proyectos, uno TestSinSplit y otro TestConSplit implementando el ejemplo de esta presentación. 6- Probar el proyecto GestionAcademicaWebHist donde se implementó el mecanismo de histórico de navegación.


Descargar ppt "Compilación y depuración Modos de ejecución GWT Google Web Toolkit Prof. Ing. Esteban Ramírez."

Presentaciones similares


Anuncios Google