2014-02-16 19:25:30 -04:00
|
|
|
#!/usr/bin/env python
|
|
|
|
############################################################################
|
|
|
|
#
|
2018-11-20 09:34:05 -04:00
|
|
|
# Copyright (C) 2014-2018 PX4 Development Team. All rights reserved.
|
2014-02-16 19:25:30 -04:00
|
|
|
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions
|
|
|
|
# are met:
|
|
|
|
#
|
|
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
|
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer in
|
|
|
|
# the documentation and/or other materials provided with the
|
|
|
|
# distribution.
|
|
|
|
# 3. Neither the name PX4 nor the names of its contributors may be
|
|
|
|
# used to endorse or promote products derived from this software
|
|
|
|
# without specific prior written permission.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
|
|
# OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
|
|
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
#
|
|
|
|
############################################################################
|
|
|
|
|
|
|
|
|
|
|
|
"""
|
|
|
|
px_romfs_pruner.py:
|
2018-11-20 09:34:05 -04:00
|
|
|
Try to keep size of the ROMFS minimal.
|
2016-06-02 11:11:43 -03:00
|
|
|
|
|
|
|
This script goes through the temporarily copied ROMFS data and deletes all
|
2018-11-20 09:34:05 -04:00
|
|
|
comments, empty lines and unnecessary whitespace.
|
2016-06-02 11:11:43 -03:00
|
|
|
It also deletes hidden files such as auto-saved backups that a text editor
|
|
|
|
might have left in the tree.
|
2016-01-19 03:41:35 -04:00
|
|
|
|
|
|
|
@author: Julian Oes <julian@oes.ch>
|
2014-02-16 19:25:30 -04:00
|
|
|
"""
|
|
|
|
|
|
|
|
from __future__ import print_function
|
2016-01-19 03:41:35 -04:00
|
|
|
import argparse
|
|
|
|
import re
|
2014-02-16 19:25:30 -04:00
|
|
|
import os
|
2018-11-20 09:27:44 -04:00
|
|
|
import io
|
2014-02-16 19:25:30 -04:00
|
|
|
|
2014-05-02 08:23:47 -03:00
|
|
|
|
2014-02-16 19:25:30 -04:00
|
|
|
def main():
|
2016-01-19 03:41:35 -04:00
|
|
|
# Parse commandline arguments
|
|
|
|
parser = argparse.ArgumentParser(description="ROMFS pruner.")
|
|
|
|
parser.add_argument('--folder', action="store",
|
|
|
|
help="ROMFS scratch folder.")
|
2016-12-20 13:16:34 -04:00
|
|
|
parser.add_argument('--board', action="store",
|
|
|
|
help="Board architecture for this run")
|
2016-01-19 03:41:35 -04:00
|
|
|
args = parser.parse_args()
|
2014-05-02 08:23:47 -03:00
|
|
|
|
2021-03-12 19:22:39 -04:00
|
|
|
err_count = 0
|
|
|
|
|
2016-06-02 11:11:43 -03:00
|
|
|
# go through temp folder
|
2016-01-19 03:41:35 -04:00
|
|
|
for (root, dirs, files) in os.walk(args.folder):
|
|
|
|
for file in files:
|
2016-06-02 11:11:43 -03:00
|
|
|
file_path = os.path.join(root, file)
|
|
|
|
|
|
|
|
# delete hidden files
|
|
|
|
if file.startswith("."):
|
|
|
|
os.remove(file_path)
|
|
|
|
continue
|
|
|
|
|
2016-07-01 13:03:38 -03:00
|
|
|
# delete documentation
|
|
|
|
if file.startswith("README"):
|
|
|
|
os.remove(file_path)
|
|
|
|
continue
|
|
|
|
|
2018-03-26 12:19:00 -03:00
|
|
|
# delete CMakeLists
|
|
|
|
if file.startswith("CMakeLists"):
|
|
|
|
os.remove(file_path)
|
|
|
|
continue
|
|
|
|
|
2016-01-19 03:41:35 -04:00
|
|
|
# only prune text files
|
|
|
|
if ".zip" in file or ".bin" in file or ".swp" in file \
|
2020-12-04 03:40:03 -04:00
|
|
|
or ".gz" in file or ".xz" in file or ".bz2" in file \
|
2016-06-02 11:11:43 -03:00
|
|
|
or ".data" in file or ".DS_Store" in file:
|
2016-01-19 03:41:35 -04:00
|
|
|
continue
|
2014-05-02 08:23:47 -03:00
|
|
|
|
2016-01-24 04:45:30 -04:00
|
|
|
# read file line by line
|
|
|
|
pruned_content = ""
|
2016-12-20 13:16:34 -04:00
|
|
|
board_excluded = False
|
2021-03-12 19:22:39 -04:00
|
|
|
|
2018-11-20 09:27:44 -04:00
|
|
|
with io.open(file_path, "r", newline=None) as f:
|
2016-01-24 04:45:30 -04:00
|
|
|
for line in f:
|
2021-03-12 19:22:39 -04:00
|
|
|
# abort if spurious tabs are found
|
|
|
|
if re.search(r"[a-zA-Z0-9]+\t.+", line):
|
|
|
|
file_local = re.sub(args.folder, '', file_path)
|
|
|
|
print("ERROR: Spurious TAB character in file " + file_local)
|
|
|
|
print("Line: " + line)
|
|
|
|
err_count += 1
|
|
|
|
|
|
|
|
# find excluded boards
|
2018-11-20 09:34:05 -04:00
|
|
|
if re.search(r'\b{0} exclude\b'.format(args.board), line):
|
|
|
|
board_excluded = True
|
2022-08-24 15:44:17 -03:00
|
|
|
|
|
|
|
if not line.isspace() \
|
|
|
|
and not line.strip().startswith("#"):
|
|
|
|
pruned_content += line.strip() + "\n"
|
2016-12-20 13:16:34 -04:00
|
|
|
# delete the file if it doesn't contain the architecture
|
|
|
|
# write out the pruned content else
|
|
|
|
if not board_excluded:
|
|
|
|
# overwrite old scratch file
|
|
|
|
with open(file_path, "wb") as f:
|
|
|
|
pruned_content = re.sub("\r\n", "\n", pruned_content)
|
|
|
|
f.write(pruned_content.encode("ascii", errors='strict'))
|
|
|
|
else:
|
|
|
|
os.remove(file_path)
|
2014-05-02 08:23:47 -03:00
|
|
|
|
2021-03-12 19:22:39 -04:00
|
|
|
if (err_count > 0):
|
|
|
|
exit(1)
|
|
|
|
|
2014-05-02 08:23:47 -03:00
|
|
|
|
2014-02-16 19:25:30 -04:00
|
|
|
if __name__ == '__main__':
|
2016-01-19 03:41:35 -04:00
|
|
|
main()
|