summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
author Cole Faust <colefaust@google.com> 2024-12-05 00:44:20 +0000
committer Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> 2024-12-05 00:44:20 +0000
commit5605d267dedb9b0c45317462c95a394525e3fccb (patch)
treeb38fa6e88272fc5639b9a24668e3743487690c5f /scripts
parent2067660fdd64ca53cb5852e5871091ad4f8a63da (diff)
parent8759130e8748bac58be78217c3f5f5224ce1eb32 (diff)
Merge "Fixes for avb flags in soong-generated partitions" into main am: 8759130e87
Original change: https://android-review.googlesource.com/c/platform/build/soong/+/3390960 Change-Id: I72f8eb592fdd0126e0ca43d491d1020009edecd0 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/text_file_processor.py46
1 files changed, 46 insertions, 0 deletions
diff --git a/scripts/text_file_processor.py b/scripts/text_file_processor.py
new file mode 100755
index 000000000..10186ce5b
--- /dev/null
+++ b/scripts/text_file_processor.py
@@ -0,0 +1,46 @@
+#!/usr/bin/env python
+#
+# Copyright (C) 2024 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.
+
+import argparse
+import re
+
+def main():
+ parser = argparse.ArgumentParser(description='This script looks for '
+ '`{CONTENTS_OF:path/to/file}` markers in the input file and replaces them with the actual '
+ 'contents of that file, with leading/trailing whitespace stripped. The idea is that this '
+ 'script could be extended to support more types of markers in the future.')
+ parser.add_argument('input')
+ parser.add_argument('output')
+ args = parser.parse_args()
+
+ with open(args.input, 'r') as f:
+ contents = f.read()
+
+ i = 0
+ replacedContents = ''
+ for m in re.finditer(r'{CONTENTS_OF:([a-zA-Z0-9 _/.-]+)}', contents):
+ replacedContents += contents[i:m.start()]
+ with open(m.group(1), 'r') as f:
+ replacedContents += f.read().strip()
+ i = m.end()
+ replacedContents += contents[i:]
+
+ with open(args.output, 'w') as f:
+ f.write(replacedContents)
+
+
+if __name__ == '__main__':
+ main()