Skip to content

Commit

Permalink
Merge pull request #47 from gabor-mezei-arm/9140_stderr_for_c_build
Browse files Browse the repository at this point in the history
Validated by #9292 (dev) and #9709 (3.6) CI.
  • Loading branch information
ronald-cron-arm authored Oct 21, 2024
2 parents 3eafac1 + d1d2e3c commit d68446c
Show file tree
Hide file tree
Showing 2 changed files with 62 additions and 1 deletion.
17 changes: 16 additions & 1 deletion scripts/mbedtls_framework/c_build_helper.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,15 @@
import sys
import tempfile

class CompileError(Exception):
"""Exception to represent an error during the compilation."""

def __init__(self, message):
"""Save the error massage"""

super().__init__()
self.message = message

def remove_file_if_exists(filename):
"""Remove the specified file, ignoring errors."""
if not filename:
Expand Down Expand Up @@ -107,7 +116,13 @@ def compile_c_file(c_filename, exe_filename, include_dirs):
else:
cmd += ['-o' + exe_filename]

subprocess.check_call(cmd + [c_filename])
try:
subprocess.check_output(cmd + [c_filename],
stderr=subprocess.PIPE,
universal_newlines=True)

except subprocess.CalledProcessError as e:
raise CompileError(e.stderr) from e

def get_c_expression_values(
cast_to, printf_format,
Expand Down
46 changes: 46 additions & 0 deletions scripts/mbedtls_framework/config_common.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
import argparse
import os
import re
import shutil
import sys

from abc import ABCMeta
Expand Down Expand Up @@ -204,6 +205,18 @@ def filename(self, name=None):

return self._get_configfile(name).filename

def backup(self, suffix='.bak'):
"""Back up the configuration file."""

for configfile in self.configfiles:
configfile.backup(suffix)

def restore(self):
"""Restore the configuration file."""

for configfile in self.configfiles:
configfile.restore()


class ConfigFile(metaclass=ABCMeta):
"""Representation of a configuration file."""
Expand All @@ -224,6 +237,8 @@ def __init__(self, default_path, name, filename=None):
self.current_section = None
self.inclusion_guard = None
self.modified = False
self._backupname = None
self._own_backup = False

_define_line_regexp = (r'(?P<indentation>\s*)' +
r'(?P<commented_out>(//\s*)?)' +
Expand Down Expand Up @@ -334,6 +349,37 @@ def write(self, settings, filename=None):
with open(filename, 'w', encoding='utf-8') as output:
self.write_to_stream(settings, output)

def backup(self, suffix='.bak'):
"""Back up the configuration file.
If the backup file already exists, it is presumed to be the desired backup,
so don't make another backup.
"""
if self._backupname:
return

self._backupname = self.filename + suffix
if os.path.exists(self._backupname):
self._own_backup = False
else:
self._own_backup = True
shutil.copy(self.filename, self._backupname)

def restore(self):
"""Restore the configuration file.
Only delete the backup file if it was created earlier.
"""
if not self._backupname:
return

if self._own_backup:
shutil.move(self._backupname, self.filename)
else:
shutil.copy(self._backupname, self.filename)

self._backupname = None


class ConfigTool(metaclass=ABCMeta):
"""Command line config manipulation tool.
Expand Down

0 comments on commit d68446c

Please sign in to comment.