// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef BASE_ANDROID_BUNDLE_UTILS_H_
#define BASE_ANDROID_BUNDLE_UTILS_H_
#include <string>
#include "base/base_export.h"
namespace base {
namespace android {
// Utils to help working with android app bundles.
class BASE_EXPORT BundleUtils {
public:
// Returns true if the current build is a bundle.
static bool IsBundle();
// Helper function asking Java to resolve a library path. This is required for
// resolving a module library made available via SplitCompat, rather than in
// its eventual fully-installed state.
static std::string ResolveLibraryPath(const std::string& library_name,
const std::string& split_name);
// dlopen wrapper that works for partitioned native libraries in dynamic
// feature modules. This routine looks up the partition's address space in a
// table of main library symbols, and uses it when loading the feature
// library. It requires |library_name| (eg. chrome_foo) to resolve the file
// path (which may be in an interesting location due to SplitCompat) and
// |partition_name| to look up the load parameters in the main library. These
// two values may be identical, but since the partition name is set at compile
// time, and the code is linked into multiple libraries (eg. Chrome vs
// Monochrome), they may not be.
static void* DlOpenModuleLibraryPartition(const std::string& library_name,
const std::string& partition,
const std::string& split_name);
};
} // namespace android
} // namespace base
#endif // BASE_ANDROID_BUNDLE_UTILS_H_