You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@maven.apache.org by "Stephen Bannasch (JIRA)" <ji...@codehaus.org> on 2010/11/07 02:15:03 UTC

[jira] Commented: (MCOMPILER-114) Setting the debug option to false still compiles the code with line numbers resulting in increased class file.

    [ http://jira.codehaus.org/browse/MCOMPILER-114?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=242301#action_242301 ] 

Stephen Bannasch commented on MCOMPILER-114:
--------------------------------------------

When I compile with {{-Dmaven.compiler.debug=true}} I *do* get a reduction in size however compiled code is still 10-20% larger than that compiled by either ant with debug=false or javac with the '-g:none' option.

Here's a closer look at the same class extracted from jars created with maven and ant using debug-false:

{code}
$ javap -l -verbose -c org/concord/mw2d/ActionStateEvent
{code}

The maven-generated class had three constants not in the ant-generated class:

{noformat}
const #12 = Asciz	LineNumberTable;
const #16 = Asciz	SourceFile;
const #17 = Asciz	ActionStateEvent.java;
{noformat}

In addition each method in the class had a LineNumberTable like this:

{code}
LineNumberTable:
 line 30: 0
 line 31: 5
 line 32: 10
 line 33: 15
{code}

It seems the only way to get maven to compile without the debugging resources is to add 'g:none' as a compiler argument for javac ... and this doesn't work from the command line -- it only works if it is in the configuration element for the maven-compiler-plugin in the pom like this:

{code}
<build>
  <plugins>
    <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-compiler-plugin</artifactId>
      <configuration>
        <compilerArgument>-g:none</compilerArgument>
        <source>1.5</source>
        <target>1.5</target>
      </configuration>
    </plugin>
  </plugins>
</build>
{code}

If the compilerArgument to 'g:none' is not set in the pom I can't get any variation of the following command line arguments to compile without some debugging info.

with or without:

{noformat}
maven.compiler.debug=false
{noformat}

with or without any of the following:

{noformat}
maven.compiler.compilerArgument=g:none
maven.compiler.compilerArgument='g:none'
maven.compiler.compilerArguments=g:none
maven.compiler.compilerArgument='g:none'
{noformat}

But I'd like the default to include debugging resources and to be able to easily optionally package without the debug resources -- the easiest way would be able to pass in a command line argument ...


> Setting the debug option to false still compiles the code with line numbers resulting in increased class file.
> --------------------------------------------------------------------------------------------------------------
>
>                 Key: MCOMPILER-114
>                 URL: http://jira.codehaus.org/browse/MCOMPILER-114
>             Project: Maven 2.x Compiler Plugin
>          Issue Type: Bug
>    Affects Versions: 2.1
>         Environment: Windows XP Professional Version 5.1.2600 Service Pack 3 Build 2600, Dell OptiPlex GX280, Total Physical Memory 4,096.00 MB
>            Reporter: Grzegorz Solecki
>         Attachments: TestApp.zip
>
>
> Given the following example:
> {code:title=Bar.java|borderStyle=solid}
> public class Main {
>    public static void main(String[] args) {
>       for (StackTraceElement stackTraceElement : Thread.currentThread().getStackTrace())
>          System.out.println(stackTraceElement);
>    }
> }
> {code} 
> and pom.xml
> {code:xml}
> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
>    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
>    <modelVersion>4.0.0</modelVersion>
>    <groupId>com.greg</groupId>
>    <artifactId>TestApp</artifactId>
>    <version>1</version>
>    <build>
>       <plugins>
>          <plugin>
>             <groupId>org.apache.maven.plugins</groupId>
>             <artifactId>maven-compiler-plugin</artifactId>
>             <configuration>
>                <debug>none</debug>
>                <source>1.5</source>
>                <target>1.5</target>
>             </configuration>
>          </plugin>
>       </plugins>
>    </build>
> </project>
> {code} 
> after compiling and running we get:
> {panel:title=cmd}
> {noformat}
> {TestApp}\target\classes>dir Main.class
> 05/02/2010  XX:XX               564 Main.class
> {TestApp}\target\classes>java -cp . Main
> java.lang.Thread.dumpThreads(Native Method)
> java.lang.Thread.getStackTrace(Thread.java:1383)
> Main.main(Main.java:3)
> {noformat} 
> {panel}
> *NOTE !!!: the number of line (Main.java:3) has been shown*
> However when you compile the same java code using the javac we get:
> {panel:title=cmd}
> {noformat}
> {TestApp}\src\main\java>javac -g:none -source 1.5 -target 1.5 Main.java
> {TestApp}\src\main\java>dir Main.class
> 05/02/2010  XX:XX               477 Main.class
> {TestApp}\src\main\java>java -cp . Main
> java.lang.Thread.dumpThreads(Native Method)
> java.lang.Thread.getStackTrace(Thread.java:1383)
> Main.main(Unknown Source){noformat} 
> {panel}
> *NOTE !!!: the number of line has not been shown*
> Please find the whole sample project in Eclipse that uses m2eclipse plugin, that is configured for using external maven 2.2.1

-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://jira.codehaus.org/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira