xref: /aosp_15_r20/frameworks/base/tools/preload/Compile.java (revision d57664e9bc4670b3ecf6748a746a57c557b6bc9e)
1*d57664e9SAndroid Build Coastguard Worker /*
2*d57664e9SAndroid Build Coastguard Worker  * Copyright (C) 2008 The Android Open Source Project
3*d57664e9SAndroid Build Coastguard Worker  *
4*d57664e9SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*d57664e9SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*d57664e9SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*d57664e9SAndroid Build Coastguard Worker  *
8*d57664e9SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*d57664e9SAndroid Build Coastguard Worker  *
10*d57664e9SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*d57664e9SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*d57664e9SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*d57664e9SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*d57664e9SAndroid Build Coastguard Worker  * limitations under the License.
15*d57664e9SAndroid Build Coastguard Worker  */
16*d57664e9SAndroid Build Coastguard Worker 
17*d57664e9SAndroid Build Coastguard Worker import java.io.BufferedReader;
18*d57664e9SAndroid Build Coastguard Worker import java.io.FileInputStream;
19*d57664e9SAndroid Build Coastguard Worker import java.io.IOException;
20*d57664e9SAndroid Build Coastguard Worker import java.io.InputStreamReader;
21*d57664e9SAndroid Build Coastguard Worker import java.util.ArrayList;
22*d57664e9SAndroid Build Coastguard Worker import java.util.List;
23*d57664e9SAndroid Build Coastguard Worker 
24*d57664e9SAndroid Build Coastguard Worker /**
25*d57664e9SAndroid Build Coastguard Worker  * Parses and analyzes a log, pulling our PRELOAD information. If you have
26*d57664e9SAndroid Build Coastguard Worker  * an emulator or device running in the background, this class will use it
27*d57664e9SAndroid Build Coastguard Worker  * to measure and record the memory usage of each class.
28*d57664e9SAndroid Build Coastguard Worker  *
29*d57664e9SAndroid Build Coastguard Worker  * TODO: Should analyze lines and select substring dynamically (instead of hardcoded 19)
30*d57664e9SAndroid Build Coastguard Worker  */
31*d57664e9SAndroid Build Coastguard Worker public class Compile {
32*d57664e9SAndroid Build Coastguard Worker 
main(String[] args)33*d57664e9SAndroid Build Coastguard Worker     public static void main(String[] args) throws IOException {
34*d57664e9SAndroid Build Coastguard Worker         if (args.length != 2) {
35*d57664e9SAndroid Build Coastguard Worker             System.err.println("Usage: Compile [log file] [output file]");
36*d57664e9SAndroid Build Coastguard Worker             System.exit(0);
37*d57664e9SAndroid Build Coastguard Worker         }
38*d57664e9SAndroid Build Coastguard Worker 
39*d57664e9SAndroid Build Coastguard Worker         Root root = new Root();
40*d57664e9SAndroid Build Coastguard Worker 
41*d57664e9SAndroid Build Coastguard Worker         List<Record> records = new ArrayList<Record>();
42*d57664e9SAndroid Build Coastguard Worker 
43*d57664e9SAndroid Build Coastguard Worker         BufferedReader in = new BufferedReader(new InputStreamReader(
44*d57664e9SAndroid Build Coastguard Worker                 new FileInputStream(args[0])));
45*d57664e9SAndroid Build Coastguard Worker 
46*d57664e9SAndroid Build Coastguard Worker         String line;
47*d57664e9SAndroid Build Coastguard Worker         int lineNumber = 0;
48*d57664e9SAndroid Build Coastguard Worker         while ((line = in.readLine()) != null) {
49*d57664e9SAndroid Build Coastguard Worker             lineNumber++;
50*d57664e9SAndroid Build Coastguard Worker             if (line.startsWith("I/PRELOAD")) {
51*d57664e9SAndroid Build Coastguard Worker                 try {
52*d57664e9SAndroid Build Coastguard Worker                     String clipped = line.substring(19);
53*d57664e9SAndroid Build Coastguard Worker                     records.add(new Record(clipped, lineNumber));
54*d57664e9SAndroid Build Coastguard Worker                 } catch (RuntimeException e) {
55*d57664e9SAndroid Build Coastguard Worker                     throw new RuntimeException(
56*d57664e9SAndroid Build Coastguard Worker                             "Exception while recording line " + lineNumber + ": " + line, e);
57*d57664e9SAndroid Build Coastguard Worker                 }
58*d57664e9SAndroid Build Coastguard Worker             }
59*d57664e9SAndroid Build Coastguard Worker         }
60*d57664e9SAndroid Build Coastguard Worker 
61*d57664e9SAndroid Build Coastguard Worker         for (Record record : records) {
62*d57664e9SAndroid Build Coastguard Worker             root.indexProcess(record);
63*d57664e9SAndroid Build Coastguard Worker         }
64*d57664e9SAndroid Build Coastguard Worker 
65*d57664e9SAndroid Build Coastguard Worker         for (Record record : records) {
66*d57664e9SAndroid Build Coastguard Worker             root.indexClassOperation(record);
67*d57664e9SAndroid Build Coastguard Worker         }
68*d57664e9SAndroid Build Coastguard Worker 
69*d57664e9SAndroid Build Coastguard Worker         in.close();
70*d57664e9SAndroid Build Coastguard Worker 
71*d57664e9SAndroid Build Coastguard Worker         root.toFile(args[1]);
72*d57664e9SAndroid Build Coastguard Worker     }
73*d57664e9SAndroid Build Coastguard Worker }
74