Set versionCode in the AndroidManifest.xml so each artifact has a unique
version code. This will allow the play store to serve up the correct
APKs.
The versionCode is determined by taking the versionCode from the input
APK and adding the configured version to that. If an artifact does not
have a version, the next version is used based on the order in the
configuration file. If the firs artifact does not have a version, it
starts at 1, so that all artifacts have a different version code to the
base APK.
Bug: 64972562
Test: unit tests
Test: manually optimized an APK into multiple APKs and confirmed versions:
aapt dump badging ${apk} | grep versionCode
Change-Id: Ie12b3e42bbd8ce9a2819712c2c56b24c0a901e6b
68 lines
2.1 KiB
C++
68 lines
2.1 KiB
C++
/*
|
|
* Copyright (C) 2017 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef AAPT2_APKSPLITTER_H
|
|
#define AAPT2_APKSPLITTER_H
|
|
|
|
#include "Diagnostics.h"
|
|
#include "LoadedApk.h"
|
|
#include "configuration/ConfigurationParser.h"
|
|
|
|
namespace aapt {
|
|
|
|
struct MultiApkGeneratorOptions {
|
|
std::string out_dir;
|
|
configuration::PostProcessingConfiguration config;
|
|
TableFlattenerOptions table_flattener_options;
|
|
};
|
|
|
|
/**
|
|
* Generates a set of APKs that are a subset of the original base APKs. Each of the new APKs contain
|
|
* only the resources and assets for an artifact in the configuration file.
|
|
*/
|
|
class MultiApkGenerator {
|
|
public:
|
|
MultiApkGenerator(LoadedApk* apk, IAaptContext* context);
|
|
|
|
/**
|
|
* Writes a set of APKs to the provided output directory. Each APK is a subset fo the base APK and
|
|
* represents an artifact in the post processing configuration.
|
|
*/
|
|
bool FromBaseApk(const MultiApkGeneratorOptions& options);
|
|
|
|
protected:
|
|
virtual std::unique_ptr<ResourceTable> FilterTable(
|
|
const configuration::Artifact& artifact,
|
|
const configuration::PostProcessingConfiguration& config, const ResourceTable& old_table,
|
|
FilterChain* chain);
|
|
|
|
private:
|
|
IDiagnostics* GetDiagnostics() {
|
|
return context_->GetDiagnostics();
|
|
}
|
|
|
|
bool UpdateManifest(const configuration::Artifact& artifact,
|
|
const configuration::PostProcessingConfiguration& config,
|
|
std::unique_ptr<xml::XmlResource>* updated_manifest, IDiagnostics* diag);
|
|
|
|
LoadedApk* apk_;
|
|
IAaptContext* context_;
|
|
};
|
|
|
|
} // namespace aapt
|
|
|
|
#endif // AAPT2_APKSPLITTER_H
|