Browse Source

microRTPS: generate_microRTPS_bridge: run fastrtsgen only once for all files

Reducing the generation time to a 4th of the time (!!)
master
TSC21 4 years ago committed by Nuno Marques
parent
commit
ffa70ac0fd
  1. 13
      msg/tools/generate_microRTPS_bridge.py

13
msg/tools/generate_microRTPS_bridge.py

@ -357,15 +357,18 @@ def generate_agent(out_dir):
if ros2_distro and ros2_distro in ['dashing', 'eloquent', 'foxy', 'galactic', 'rolling'] and fastrtpsgen_version >= version.Version("1.0.4"): if ros2_distro and ros2_distro in ['dashing', 'eloquent', 'foxy', 'galactic', 'rolling'] and fastrtpsgen_version >= version.Version("1.0.4"):
gen_ros2_typename = "-typeros2 " gen_ros2_typename = "-typeros2 "
idl_files = []
for idl_file in glob.glob(os.path.join(idl_dir, "*.idl")): for idl_file in glob.glob(os.path.join(idl_dir, "*.idl")):
# Only run the generator for the topics that are actually marked to be # Only run the generator for the topics that are actually marked to be
# used by the bridge # used by the bridge
if os.path.splitext(os.path.basename(idl_file))[0] in classifier.msg_id_map: if os.path.splitext(os.path.basename(idl_file))[0] in classifier.msg_id_map:
try: idl_files.append(idl_file)
ret = subprocess.check_call(fastrtpsgen_path + " -d " + out_dir +
"/fastrtpsgen -example x64Linux2.6gcc " + gen_ros2_typename + fastrtpsgen_include + idl_file, shell=True) try:
except OSError: ret = subprocess.check_call(fastrtpsgen_path + " -d " + out_dir +
raise "/fastrtpsgen -example x64Linux2.6gcc " + gen_ros2_typename + fastrtpsgen_include + " ".join(str(idl_file) for idl_file in idl_files), shell=True)
except OSError:
raise
rm_wildcard(os.path.join(out_dir, "fastrtpsgen/*PubSubMain*")) rm_wildcard(os.path.join(out_dir, "fastrtpsgen/*PubSubMain*"))
rm_wildcard(os.path.join(out_dir, "fastrtpsgen/makefile*")) rm_wildcard(os.path.join(out_dir, "fastrtpsgen/makefile*"))

Loading…
Cancel
Save