From f2505e4acc48aeaf6bf60b731257e7eadd6580a8 Mon Sep 17 00:00:00 2001 From: corysmith Date: Tue, 31 Jul 2018 08:06:59 -0700 Subject: Add profiling data to the resources zip. RELNOTES:None PiperOrigin-RevId: 206762523 --- .../android/Aapt2ResourcePackagingAction.java | 2 +- .../devtools/build/android/InMemoryProfiler.java | 73 ++++++++++++++++++++++ .../devtools/build/android/ResourcesZip.java | 12 ++-- 3 files changed, 79 insertions(+), 8 deletions(-) create mode 100644 src/tools/android/java/com/google/devtools/build/android/InMemoryProfiler.java (limited to 'src/tools') diff --git a/src/tools/android/java/com/google/devtools/build/android/Aapt2ResourcePackagingAction.java b/src/tools/android/java/com/google/devtools/build/android/Aapt2ResourcePackagingAction.java index 9179a77fe9..6fc5e76419 100644 --- a/src/tools/android/java/com/google/devtools/build/android/Aapt2ResourcePackagingAction.java +++ b/src/tools/android/java/com/google/devtools/build/android/Aapt2ResourcePackagingAction.java @@ -60,7 +60,7 @@ public class Aapt2ResourcePackagingAction { private static Options options; public static void main(String[] args) throws Exception { - Profiler profiler = LoggingProfiler.createAndStart("setup"); + InMemoryProfiler profiler = InMemoryProfiler.createAndStart("setup"); OptionsParser optionsParser = OptionsParser.newOptionsParser(Options.class, Aapt2ConfigOptions.class); optionsParser.enableParamsFileSupport( diff --git a/src/tools/android/java/com/google/devtools/build/android/InMemoryProfiler.java b/src/tools/android/java/com/google/devtools/build/android/InMemoryProfiler.java new file mode 100644 index 0000000000..3032280430 --- /dev/null +++ b/src/tools/android/java/com/google/devtools/build/android/InMemoryProfiler.java @@ -0,0 +1,73 @@ +// Copyright 2017 The Bazel Authors. All rights reserved. +// +// 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. + +package com.google.devtools.build.android; + +import static java.util.stream.Collectors.joining; + +import com.google.common.base.Preconditions; +import com.google.common.base.Stopwatch; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** Logs timing data to an in memory list that can be dumped. */ +public class InMemoryProfiler implements Profiler { + + private final Map tasks = new HashMap<>(); + private final List report = new ArrayList<>(); + + private InMemoryProfiler() {} + + public static InMemoryProfiler createAndStart(String taskName) { + final InMemoryProfiler profiler = new InMemoryProfiler(); + return profiler.startTask(taskName); + } + + @Override + public InMemoryProfiler startTask(String taskName) { + Preconditions.checkArgument(!tasks.containsKey(taskName)); + tasks.put(taskName, Stopwatch.createStarted()); + return this; + } + + @Override + public InMemoryProfiler recordEndOf(String taskName) { + Preconditions.checkArgument(tasks.containsKey(taskName)); + final Stopwatch task = tasks.remove(taskName); + report.add(new Timing(taskName, task.elapsed().toMillis() / 1000f)); + return this; + } + + public String asTimingReport() { + return report.stream().map(Timing::toString).collect(joining("\n")); + } + + static final class Timing { + + private final String taskName; + private final float seconds; + + Timing(String taskName, float seconds) { + this.taskName = taskName; + this.seconds = seconds; + } + + @Override + public String toString() { + return String.format("%s in %,.2fs", taskName, seconds); + } + } +} diff --git a/src/tools/android/java/com/google/devtools/build/android/ResourcesZip.java b/src/tools/android/java/com/google/devtools/build/android/ResourcesZip.java index 80ed2dc8ca..dd3cb099f3 100644 --- a/src/tools/android/java/com/google/devtools/build/android/ResourcesZip.java +++ b/src/tools/android/java/com/google/devtools/build/android/ResourcesZip.java @@ -77,8 +77,7 @@ public class ResourcesZip { * @param apkWithAssets The apk containing assets. * @param resourceIds Optional path to a file containing the resource ids. */ - public static ResourcesZip fromApk( - Path resourcesRoot, Path apkWithAssets, @Nullable Path resourceIds) { + public static ResourcesZip fromApk(Path resourcesRoot, Path apkWithAssets, Path resourceIds) { return new ResourcesZip( resourcesRoot, /* assetsRoot= */ null, @@ -157,13 +156,12 @@ public class ResourcesZip { Files.walkFileTree(assetsRoot, visitor); visitor.writeEntries(); } - - if (ids != null) { - try { + try { + if (ids != null) { zip.addEntry("ids.txt", Files.readAllBytes(ids), ZipEntry.STORED); - } catch (IOException e) { - throw new RuntimeException(e); } + } catch (IOException e) { + throw new RuntimeException(e); } } } -- cgit v1.2.3