• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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
5package org.chromium.content.app;
6
7public 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