Skip to content

Commit

Permalink
feat(ns3): improve ns3 installer + minor fixes (#413)
Browse files Browse the repository at this point in the history
* feat: fail hard when running ns3 on windows
* fix: do not download if the file already exists
* fix: remove assumption that glob resolves to only one file
* fix: rewrite so that protobuf genereration can be skipped
* fix: require protobuf-compiler
* fix: improve error message
  • Loading branch information
hoelger authored and schwepmo committed Dec 2, 2024
1 parent ac5feee commit 0c6c7f0
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 32 deletions.
60 changes: 34 additions & 26 deletions bundle/src/assembly/resources/fed/ns3/ns3_installer.sh
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,8 @@ arg_federate_file=""
arg_integration_testing=false
arg_make_parallel=""

required_programs=( python3 gcc unzip tar )
required_programs_display=( python3 gcc unzip tar protobuf-compiler )
required_programs_test=( python3 gcc unzip tar protoc )
required_libraries=( "libprotobuf-dev >= 3.7.0" "libxml2-dev" "libsqlite3-dev" )

####### configurable parameters ##########
Expand Down Expand Up @@ -73,7 +74,7 @@ ns3_federate_url="https://github.com/mosaic-addons/ns3-federate/archive/refs/tag
ns3_url="https://www.nsnam.org/releases/$ns3_version_affix.tar.bz2"

###### more automatic parameters #########
ns3_federate_filename="$(basename "$ns3_federate_url")"
ns3_federate_filename="ns3-federate-$(basename "$ns3_federate_url")"
ns3_filename="$(basename "$ns3_url")"

temporary_files=""
Expand Down Expand Up @@ -111,8 +112,8 @@ get_arguments() {
-d|--no-deploy)
arg_deploy=false
;;
-p|--gen-protobuf)
arg_regen_protobuf=true
-p|--skip-gen-protobuf)
arg_regen_protobuf=false
;;
-f|--federate)
arg_federate_file="$2"
Expand Down Expand Up @@ -243,7 +244,7 @@ ask_dependencies()
log "${bold}${cyan} $lib ${restore}"
done
log "\n${bold}Programs:${restore}"
for prog in "${required_programs[@]}"; do
for prog in "${required_programs_display[@]}"; do
log "${bold}${cyan} $prog ${restore}"
done
printf "\n[y/n] "
Expand All @@ -261,19 +262,28 @@ ask_dependencies()
################### Downloading and installing ##########

download() {
if [ ! -f "$(basename "$1")" ]; then
basen=$(basename "$1")
if [ "$#" -eq 1 ]; then
# basename of url and downloaded file have to be identical
filename=$(basename "$1")
url=$1
fi
if [ "$#" -eq 2 ]; then
filename=$(basename "$1")
url=$2
fi

if [ ! -f "$filename" ]; then
if has wget; then
wget --no-check-certificate -q "$1" || fail "The download URL seems to have changed. File not found: "$1"";
temporary_files="$temporary_files $basen"
wget --no-check-certificate -q "$url" || fail "The server is not reachable or the download URL has changed. File not found: "$url"";
temporary_files="$temporary_files $filename"
elif has curl; then
curl -s -O "$1" || fail "The download URL seems to have changed. File not found: "$1"";
temporary_files="$temporary_files $basen"
curl -s -O "$url" || fail "The server is not reachable or the download URL has changed. File not found: "$url"";
temporary_files="$temporary_files $filename"
else
fail "Can't download "$1".";
fail "Can't download "$url".";
fi
else
warn "File $(basename "$1") already exists. Skipping download."
warn "File $filename already exists. Skipping download."
fi
}

Expand Down Expand Up @@ -316,18 +326,16 @@ extract_ns3()

extract_ns3_federate()
{
arg1="$1"

if [ -d "./federate" ]; then
fail "Directory federate in "." already exists.";
fi

temporary_files="$temporary_files federate"

unzip --qq -o "$arg1"
unzip --qq -o "$(basename "$ns3_federate_url")"
# The archive should have contained the folder "ns3-federate-xxx".
# Rename it to "federate":
mv ns3-federate-* federate
mv $(basename -s .zip $ns3_federate_filename) federate
}

extract_premake() {
Expand Down Expand Up @@ -367,18 +375,18 @@ build_ns3()
cd ${current_dir}/federate
mv src/ClientServerChannel.h .
mv src/ClientServerChannel.cc .
if [ -f src/ClientServerChannelMessages.pb.h ]; then
rm src/ClientServerChannelMessages.pb.h
fi
if [ -f src/ClientServerChannelMessages.pb.cc ]; then
rm src/ClientServerChannelMessages.pb.cc
fi

# adjust build instruction to cover scrambled files
sed -i -e "s|/usr/local|.|" premake5.lua
sed -i -e "s|\"/usr/include\"|\"../ns-allinone-${ns3_version}/ns-${ns3_version}/build/include\"|" premake5.lua
sed -i -e "s|\"/usr/lib\"|\"../ns-allinone-${ns3_version}/ns-${ns3_version}/build/lib\"|" premake5.lua
if [ "${arg_regen_protobuf}" == "true" ]; then
if [ -f src/ClientServerChannelMessages.pb.h ]; then
rm src/ClientServerChannelMessages.pb.h
fi
if [ -f src/ClientServerChannelMessages.pb.cc ]; then
rm src/ClientServerChannelMessages.pb.cc
fi
./premake5 gmake --generate-protobuf --install
else
./premake5 gmake --install
Expand Down Expand Up @@ -473,7 +481,7 @@ print_info
ask_dependencies

log "Preparing installation..."
check_required_programs "${required_programs[*]}"
check_required_programs "${required_programs_test[*]}"
check_directory

download_ns3
Expand All @@ -485,8 +493,8 @@ download_premake5
log "Extracting "$ns3_filename"..."
extract_ns3 "$ns3_filename" .

log "Extracting "$ns3_federate_filename"..."
extract_ns3_federate "$ns3_federate_filename"
log "Extracting "$(basename "$ns3_federate_url")"..."
extract_ns3_federate

extract_premake

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,10 +54,9 @@ public FederateExecutor createFederateExecutor(String host, int port, OperatingS
case WINDOWS:
case UNKNOWN:
default:
log.error("Operating system not supported");
break;
log.error("Operating system not supported by ns3");
throw new RuntimeException("Operating system not supported by ns3");
}
return new NopFederateExecutor();
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -59,10 +59,9 @@ public FederateExecutor createFederateExecutor(String host, int port, OperatingS
case WINDOWS:
case UNKNOWN:
default:
log.error("Operating system not supported");
break;
log.error("Operating system not supported by omnetpp");
throw new RuntimeException("Operating system not supported by omnetpp");
}
return new NopFederateExecutor();
}

@Override
Expand Down

0 comments on commit 0c6c7f0

Please sign in to comment.