zephyr/scripts/utils/migrate_sys_init.py
Gerard Marull-Paretas a01d40f604 scripts: utils: migrate_sys_init: handle empty line after ARG_UNUSED
The script left empty lines below ARG_UNUSED. After this patch,

```c
static int f(const struct device *dev)
{
	ARG_UNUSED(dev);

	/* code */
	...
}
```

will become:

```c
static int f(void)
{
	/* code */
	...
}
```

instead of:

```c
static int f(void)
{

	/* code */
	...
}
```

Fixes #56954

Signed-off-by: Gerard Marull-Paretas <gerard.marull@nordicsemi.no>
2023-04-25 19:57:00 +02:00

91 lines
2.6 KiB
Python

"""
Utility script to migrate SYS_INIT() calls from the old signature
``int (*init_fn)(const struct device *dev)`` to ``int (*init_fn)(void)``.
.. warning::
Review the output carefully! This script may not cover all cases!
Usage::
python $ZEPHYR_BASE/scripts/utils/migrate_sys_init.py \
-p path/to/zephyr-based-project
Copyright (c) 2022 Nordic Semiconductor ASA
SPDX-License-Identifier: Apache-2.0
"""
import argparse
from pathlib import Path
import re
def update_sys_init(project, dry_run):
for p in project.glob("**/*"):
if not p.is_file() or not p.suffix or p.suffix[1:] not in ("c", "cpp"):
continue
with open(p) as f:
lines = f.readlines()
sys_inits = []
for line in lines:
m = re.match(r"^SYS_INIT\(([A-Za-z0-9_]+),.*", line)
if m:
sys_inits.append(m.group(1))
continue
m = re.match(r"^SYS_INIT_NAMED\([A-Za-z0-9_]+,\s?([A-Za-z0-9_]+).*", line)
if m:
sys_inits.append(m.group(1))
continue
if not sys_inits:
continue
arg = None
content = ""
update = False
unused = False
for line in lines:
m = re.match(
r"(.*)int ("
+ "|".join(sys_inits)
+ r")\(const\s+struct\s+device\s+\*\s?(.*)\)(.*)",
line,
)
if m:
b, sys_init, arg, e = m.groups()
content += f"{b}int {sys_init}(void){e}\n"
update = True
elif arg:
m = re.match(r"^\s?ARG_UNUSED\(" + arg + r"\);.*$", line)
if m:
arg = None
unused = True
else:
content += line
elif unused:
m = re.match(r"^\s?\n$", line)
if not m:
content += line
unused = False
else:
content += line
if update:
print(f"Updating {p}{' (dry run)' if dry_run else ''}")
if not dry_run:
with open(p, "w") as f:
f.write(content)
if __name__ == "__main__":
parser = argparse.ArgumentParser(allow_abbrev=False)
parser.add_argument(
"-p", "--project", type=Path, required=True, help="Zephyr-based project path"
)
parser.add_argument("--dry-run", action="store_true", help="Dry run")
args = parser.parse_args()
update_sys_init(args.project, args.dry_run)