Home | History | Annotate | Download | only in templates
      1 // Copyright 2013 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 package org.chromium.content.app;
      6 
      7 public class NativeLibraries {
      8     /**
      9      * IMPORTANT NOTE: The variables defined here must _not_ be 'final'.
     10      *
     11      * The reason for this is very subtle:
     12      *
     13      * - This template is used to generate several distinct, but similar
     14      *   files used in different contexts:
     15      *
     16      *   o .../gen/templates/org/chromium/content/app/NativeLibraries.java
     17      *
     18      *     This file is used to build content.jar, which is the library
     19      *     jar used by several content-based projects. However, the
     20      *     corresponding NativeLibraries.class file will _not_ be part
     21      *     of the final content.jar.
     22      *
     23      *   o .../$PROJECT/native_libraries_java/NativeLibraries.java
     24      *
     25      *     This file is used to build a content-based APK (e.g. $PROJECT
     26      *     could be 'content_shell_apk'). Its content will depend on
     27      *     this target's specific build configuration, and differ from
     28      *     the source file above.
     29      *
     30      * - During the final link, all .jar files are linked together into
     31      *   a single .dex file, and the second version of NativeLibraries.class
     32      *   will be put into the final output file, and used at runtime.
     33      *
     34      * - If the variables were defined as 'final', their value would be
     35      *   optimized out inside of 'content.jar', and could not be specialized
     36      *   for every content-based program.
     37      *
     38      * This exotic scheme is used to avoid injecting project-specific, or
     39      * even build-specific, values into the content layer. E.g. this is
     40      * how the component build is supported on Android without modifying
     41      * the sources of each and every Chromium-based target.
     42      */
     43     // Set to true to enable the use of the content Linker.
     44 #if defined(ENABLE_CONTENT_LINKER)
     45     public static boolean USE_LINKER = true;
     46 #else
     47     public static boolean USE_LINKER = false;
     48 #endif
     49 
     50 #if defined(ENABLE_CONTENT_LINKER_TESTS)
     51     public static boolean ENABLE_LINKER_TESTS = true;
     52 #else
     53     public static boolean ENABLE_LINKER_TESTS = false;
     54 #endif
     55 
     56     // This is the list of native libraries to be loaded (in the correct order)
     57     // by LibraryLoader.java.  The content java library is compiled with no
     58     // array defined, and then the build system creates a version of the file
     59     // with the real list of libraries required (which changes based upon which
     60     // .apk is being built).
     61     // TODO(cjhopman): This is public since it is referenced by ChromeNativeTestActivity.java
     62     // directly. The two ways of library loading should be refactored into one.
     63     public static final String[] LIBRARIES
     64 #include <native_libraries_array.h>
     65       ;
     66     // This is the expected version of the 'main' native library, which is the one that
     67     // implements the initial set of content JNI functions including
     68     // content::nativeGetVersionName()
     69     // Note(aberent): This is logically final, but making it final breaks the build, since it
     70     // lets other Java components read its value at compile time rather than at run time, hence
     71     // reading it from the wrong class file.
     72     static String VERSION_NUMBER
     73 #include <native_libraries_version.h>
     74       ;
     75 }
     76