summaryrefslogtreecommitdiff
path: root/tools/hiddenapi/merge_csv.py
diff options
context:
space:
mode:
authorMathew Inwood <mathewi@google.com>2018-10-17 09:20:04 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2018-10-17 09:20:04 +0000
commit5037a7eb93ec73c152da5f0f19f0ff04e9c3a02c (patch)
tree08f784442741cc842cbc70c5e8fb1c79f92a7f65 /tools/hiddenapi/merge_csv.py
parent23ccecc4ca9f58139baa72bd4783451b780b1eb5 (diff)
parentea14c0c36f2ff5c18c2e62c71f50f01cef47f077 (diff)
Merge "Merge hidden API metadata into a single CSV file."
Diffstat (limited to 'tools/hiddenapi/merge_csv.py')
-rwxr-xr-xtools/hiddenapi/merge_csv.py40
1 files changed, 40 insertions, 0 deletions
diff --git a/tools/hiddenapi/merge_csv.py b/tools/hiddenapi/merge_csv.py
new file mode 100755
index 000000000000..48c07553ffef
--- /dev/null
+++ b/tools/hiddenapi/merge_csv.py
@@ -0,0 +1,40 @@
+#!/usr/bin/env python
+#
+# Copyright (C) 2018 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.
+"""
+Merge mutliple CSV files, possibly with different columns, writing to stdout.
+"""
+
+import csv
+import sys
+
+csv_readers = [
+ csv.DictReader(open(csv_file, 'rb'), delimiter=',', quotechar='|')
+ for csv_file in sys.argv[1:]
+]
+
+# Build union of all columns from source files:
+headers = set()
+for reader in csv_readers:
+ headers = headers.union(reader.fieldnames)
+
+# Concatenate all files to output:
+out = csv.DictWriter(sys.stdout, delimiter=',', quotechar='|', fieldnames = sorted(headers))
+out.writeheader()
+for reader in csv_readers:
+ for row in reader:
+ out.writerow(row)
+
+