From ff759e6a6ef6dd741b174e58a0f01cb87accc897 Mon Sep 17 00:00:00 2001 From: Pierre Lecesne Date: Wed, 1 Feb 2017 00:29:25 +0000 Subject: Moving the LoadedApk class to its own file. Test: Unit tests pass. Change-Id: Id706f9ad1f3406bb73a60a33139a04745d5d72c0 --- tools/aapt2/diff/Diff.cpp | 63 +++-------------------------------------------- 1 file changed, 3 insertions(+), 60 deletions(-) (limited to 'tools/aapt2/diff/Diff.cpp') diff --git a/tools/aapt2/diff/Diff.cpp b/tools/aapt2/diff/Diff.cpp index de0fe404b867..acebedafe43d 100644 --- a/tools/aapt2/diff/Diff.cpp +++ b/tools/aapt2/diff/Diff.cpp @@ -17,12 +17,10 @@ #include "android-base/macros.h" #include "Flags.h" -#include "ResourceTable.h" +#include "LoadedApk.h" #include "ValueVisitor.h" -#include "io/ZipArchive.h" #include "process/IResourceTableConsumer.h" #include "process/SymbolTable.h" -#include "unflatten/BinaryResourceParser.h" using android::StringPiece; @@ -51,61 +49,6 @@ class DiffContext : public IAaptContext { SymbolTable symbol_table_; }; -class LoadedApk { - public: - LoadedApk(const Source& source, std::unique_ptr apk, - std::unique_ptr table) - : source_(source), apk_(std::move(apk)), table_(std::move(table)) {} - - io::IFileCollection* GetFileCollection() { return apk_.get(); } - - ResourceTable* GetResourceTable() { return table_.get(); } - - const Source& GetSource() { return source_; } - - private: - Source source_; - std::unique_ptr apk_; - std::unique_ptr table_; - - DISALLOW_COPY_AND_ASSIGN(LoadedApk); -}; - -static std::unique_ptr LoadApkFromPath(IAaptContext* context, - const StringPiece& path) { - Source source(path); - std::string error; - std::unique_ptr apk = - io::ZipFileCollection::Create(path, &error); - if (!apk) { - context->GetDiagnostics()->Error(DiagMessage(source) << error); - return {}; - } - - io::IFile* file = apk->FindFile("resources.arsc"); - if (!file) { - context->GetDiagnostics()->Error(DiagMessage(source) - << "no resources.arsc found"); - return {}; - } - - std::unique_ptr data = file->OpenAsData(); - if (!data) { - context->GetDiagnostics()->Error(DiagMessage(source) - << "could not open resources.arsc"); - return {}; - } - - std::unique_ptr table = util::make_unique(); - BinaryResourceParser parser(context, table.get(), source, data->data(), - data->size()); - if (!parser.Parse()) { - return {}; - } - - return util::make_unique(source, std::move(apk), std::move(table)); -} - static void EmitDiffLine(const Source& source, const StringPiece& message) { std::cerr << source << ": " << message << "\n"; } @@ -413,9 +356,9 @@ int Diff(const std::vector& args) { } std::unique_ptr apk_a = - LoadApkFromPath(&context, flags.GetArgs()[0]); + LoadedApk::LoadApkFromPath(&context, flags.GetArgs()[0]); std::unique_ptr apk_b = - LoadApkFromPath(&context, flags.GetArgs()[1]); + LoadedApk::LoadApkFromPath(&context, flags.GetArgs()[1]); if (!apk_a || !apk_b) { return 1; } -- cgit v1.2.3