initial commit
This commit is contained in:
4
Dockerfile
Normal file
4
Dockerfile
Normal file
@@ -0,0 +1,4 @@
|
||||
FROM ns3-base AS sim
|
||||
COPY ./scratch /ns3/latest/scratch
|
||||
COPY ./contrib /ns3/latest/contrib
|
||||
ENV PATH="/ns3/latest:$PATH"
|
||||
74
Dockerfile.base
Normal file
74
Dockerfile.base
Normal file
@@ -0,0 +1,74 @@
|
||||
FROM debian:trixie-slim AS base
|
||||
|
||||
LABEL Description="Docker image for NS-3 Network Simulator"
|
||||
|
||||
ARG VERSION=3.41
|
||||
|
||||
# Timezone things?
|
||||
ENV TZ=Europe/Berlin
|
||||
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
|
||||
|
||||
# System packages
|
||||
# Required: build-essetial through wget
|
||||
# Optional for ns3 features: libsqlite3-dev through libgsl-dev
|
||||
#
|
||||
# Optional, but probably useful:
|
||||
# tcpdump: to read pcap files
|
||||
# cccache: to speed up the build
|
||||
# clang-format, clang-tidy: linters
|
||||
# gdb, valgrind: to debug
|
||||
#
|
||||
# Quality of life deps: vim, less, git
|
||||
#
|
||||
# Finally, clean up the cache to save some space
|
||||
RUN apt-get update && apt-get install -y \
|
||||
# build-essential \
|
||||
g++ \
|
||||
python3 \
|
||||
cmake \
|
||||
wget \
|
||||
bzip2 \
|
||||
libsqlite3-dev \
|
||||
libeigen3-dev \
|
||||
libgsl-dev \
|
||||
tcpdump \
|
||||
ccache \
|
||||
# clang-format \
|
||||
# clang-tidy \
|
||||
# gdb \
|
||||
# valgrind \
|
||||
vim \
|
||||
less \
|
||||
# git \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# Create a user
|
||||
RUN mkdir -p /ns3
|
||||
|
||||
WORKDIR /tmp
|
||||
|
||||
# Get sources
|
||||
RUN wget https://www.nsnam.org/releases/ns-allinone-$VERSION.tar.bz2
|
||||
RUN tar xfj ns-allinone-$VERSION.tar.bz2
|
||||
RUN rm ns-allinone-$VERSION.tar.bz2
|
||||
|
||||
# We don't need this anymore
|
||||
RUN apt-get -y purge wget bzip2
|
||||
|
||||
# Move to somewhere nicer
|
||||
RUN mv ./ns-allinone-$VERSION/ns-$VERSION /ns3/$VERSION && ln -s /ns3/$VERSION /ns3/latest
|
||||
WORKDIR /ns3/latest
|
||||
|
||||
# Configure
|
||||
RUN ./ns3 configure
|
||||
#--enable-examples --enable-tests
|
||||
|
||||
# Build
|
||||
RUN ./ns3 build
|
||||
|
||||
ENV PATH="/ns3/latest :${PATH}"
|
||||
|
||||
# Test
|
||||
#RUN ./test.py
|
||||
|
||||
CMD ["bash"]
|
||||
20
compose.dev.yml
Normal file
20
compose.dev.yml
Normal file
@@ -0,0 +1,20 @@
|
||||
version: '3.8'
|
||||
|
||||
services:
|
||||
base:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile.base
|
||||
image: ns3-base
|
||||
|
||||
sim:
|
||||
build:
|
||||
context: .
|
||||
volumes:
|
||||
- ./scratch:/ns3/latest/scratch
|
||||
- ./contrib:/ns3/latest/contrib
|
||||
depends_on:
|
||||
- base
|
||||
image: ns3-sim
|
||||
|
||||
|
||||
17
compose.yml
Normal file
17
compose.yml
Normal file
@@ -0,0 +1,17 @@
|
||||
version: '3.8'
|
||||
|
||||
services:
|
||||
base:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile.base
|
||||
image: ns3-base
|
||||
|
||||
sim:
|
||||
build:
|
||||
context: .
|
||||
depends_on:
|
||||
- base
|
||||
image: ns3-sim
|
||||
|
||||
|
||||
111
scratch/CMakeLists.txt
Normal file
111
scratch/CMakeLists.txt
Normal file
@@ -0,0 +1,111 @@
|
||||
set(target_prefix scratch_)
|
||||
|
||||
function(create_scratch source_files)
|
||||
# Return early if no sources in the subdirectory
|
||||
list(LENGTH source_files number_sources)
|
||||
if(number_sources EQUAL 0)
|
||||
return()
|
||||
endif()
|
||||
|
||||
# If the scratch has more than a source file, we need to find the source with
|
||||
# the main function
|
||||
set(scratch_src)
|
||||
foreach(source_file ${source_files})
|
||||
file(READ ${source_file} source_file_contents)
|
||||
string(REGEX MATCHALL "main[(| (]" main_position "${source_file_contents}")
|
||||
if(CMAKE_MATCH_0)
|
||||
list(APPEND scratch_src ${source_file})
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
list(LENGTH scratch_src scratch_src_len)
|
||||
|
||||
# If there is no main function, raise an error
|
||||
if(${scratch_src_len} EQUAL 0)
|
||||
message(FATAL_ERROR "The following scratch source files do not contain a main function: ${source_files}")
|
||||
endif()
|
||||
|
||||
# If there are multiple main functions, raise an error
|
||||
if(${scratch_src_len} GREATER 1)
|
||||
message(FATAL_ERROR "The following scratch source files contain ${scratch_src_len} files with a main function: ${scratch_src}")
|
||||
endif()
|
||||
|
||||
# If there is a single main function, continue normally
|
||||
|
||||
# Get parent directory name
|
||||
get_filename_component(scratch_dirname ${scratch_src} DIRECTORY)
|
||||
string(REPLACE "${CMAKE_CURRENT_SOURCE_DIR}" "" scratch_dirname
|
||||
"${scratch_dirname}"
|
||||
)
|
||||
string(REPLACE "/" "_" scratch_dirname "${scratch_dirname}")
|
||||
|
||||
# Get source name
|
||||
if(${CMAKE_VERSION} VERSION_GREATER_EQUAL "3.14.0")
|
||||
get_filename_component(scratch_name ${scratch_src} NAME_WLE)
|
||||
else()
|
||||
get_filename_component(scratch_name ${scratch_src} NAME)
|
||||
string(FIND "${scratch_name}" "." ext_position REVERSE)
|
||||
if(${ext_position} EQUAL -1)
|
||||
message(FATAL_ERROR "Source file has no extension: ${scratch_src}")
|
||||
else()
|
||||
string(SUBSTRING "${scratch_name}" 0 ${ext_position} scratch_name)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
set(target_prefix scratch_)
|
||||
if(scratch_dirname)
|
||||
# Join the names together if dirname is not the scratch folder
|
||||
set(target_prefix scratch${scratch_dirname}_)
|
||||
endif()
|
||||
|
||||
# Get source absolute path and transform into relative path
|
||||
get_filename_component(scratch_src ${scratch_src} ABSOLUTE)
|
||||
get_filename_component(scratch_absolute_directory ${scratch_src} DIRECTORY)
|
||||
string(REPLACE "${PROJECT_SOURCE_DIR}" "${CMAKE_OUTPUT_DIRECTORY}"
|
||||
scratch_directory ${scratch_absolute_directory}
|
||||
)
|
||||
build_exec(
|
||||
EXECNAME ${scratch_name}
|
||||
EXECNAME_PREFIX ${target_prefix}
|
||||
SOURCE_FILES "${source_files}"
|
||||
LIBRARIES_TO_LINK "${ns3-libs}" "${ns3-contrib-libs}"
|
||||
EXECUTABLE_DIRECTORY_PATH ${scratch_directory}/
|
||||
)
|
||||
endfunction()
|
||||
|
||||
# Scan *.cc files in ns-3-dev/scratch and build a target for each
|
||||
file(GLOB single_source_file_scratches CONFIGURE_DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/[^.]*.cc)
|
||||
foreach(scratch_src ${single_source_file_scratches})
|
||||
create_scratch(${scratch_src})
|
||||
endforeach()
|
||||
|
||||
# Scan ns-3-dev/scratch subdirectories
|
||||
file(
|
||||
GLOB scratch_subdirectories
|
||||
CONFIGURE_DEPENDS
|
||||
LIST_DIRECTORIES true
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/**
|
||||
)
|
||||
# Filter out files
|
||||
foreach(entry ${scratch_subdirectories})
|
||||
if(NOT (IS_DIRECTORY ${entry}))
|
||||
list(REMOVE_ITEM scratch_subdirectories ${entry})
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
# Build scratches per directory or following CMakeLists.txt instructions
|
||||
foreach(subdir ${scratch_subdirectories})
|
||||
if(EXISTS ${subdir}/CMakeLists.txt)
|
||||
# If the subdirectory contains a CMakeLists.txt file
|
||||
# we let the CMake file manage the source files
|
||||
#
|
||||
# Use this if you want to link to external libraries
|
||||
# without creating a module
|
||||
add_subdirectory(${subdir})
|
||||
else()
|
||||
# Otherwise we pick all the files in the subdirectory
|
||||
# and create a scratch for them automatically
|
||||
file(GLOB scratch_sources CONFIGURE_DEPENDS ${subdir}/[^.]*.cc)
|
||||
create_scratch("${scratch_sources}")
|
||||
endif()
|
||||
endforeach()
|
||||
30
scratch/subdir/scratch-subdir-additional-header.cc
Normal file
30
scratch/subdir/scratch-subdir-additional-header.cc
Normal file
@@ -0,0 +1,30 @@
|
||||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation;
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
// This file contains the implementation of the functions declared in the
|
||||
// corresponding header file.
|
||||
|
||||
#include "scratch-subdir-additional-header.h"
|
||||
|
||||
namespace ns3
|
||||
{
|
||||
|
||||
std::string
|
||||
ScratchSubdirGetMessage()
|
||||
{
|
||||
return "Scratch Subdir";
|
||||
}
|
||||
|
||||
} // namespace ns3
|
||||
32
scratch/subdir/scratch-subdir-additional-header.h
Normal file
32
scratch/subdir/scratch-subdir-additional-header.h
Normal file
@@ -0,0 +1,32 @@
|
||||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation;
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
// This header does not provide much functionality but is meant to demonstrate how,
|
||||
// in a scratch subdirectory, one can create new programs that are implemented
|
||||
// in multiple files and headers.
|
||||
|
||||
#include <string>
|
||||
|
||||
namespace ns3
|
||||
{
|
||||
|
||||
/**
|
||||
* Get a message from the subdir.
|
||||
*
|
||||
* \return The message from the subdir
|
||||
*/
|
||||
std::string ScratchSubdirGetMessage();
|
||||
|
||||
} // namespace ns3
|
||||
50
scratch/subdir/scratch-subdir.cc
Normal file
50
scratch/subdir/scratch-subdir.cc
Normal file
@@ -0,0 +1,50 @@
|
||||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation;
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
// This example shows how to create new simulations that are implemented in
|
||||
// multiple files and headers. The structure of this simulation project
|
||||
// is as follows:
|
||||
//
|
||||
// scratch/
|
||||
// | subdir/
|
||||
// | | - scratch-subdir.cc // Main simulation file
|
||||
// | | - scratch-subdir-additional-header.h // Additional header
|
||||
// | | - scratch-subdir-additional-header.cc // Additional header implementation
|
||||
//
|
||||
// This file contains the main() function, which calls an external function
|
||||
// defined in the "scratch-subdir-additional-header.h" header file and
|
||||
// implemented in "scratch-subdir-additional-header.cc".
|
||||
|
||||
#include "scratch-subdir-additional-header.h"
|
||||
|
||||
#include "ns3/core-module.h"
|
||||
|
||||
#include <string>
|
||||
|
||||
using namespace ns3;
|
||||
|
||||
NS_LOG_COMPONENT_DEFINE("ScratchSubdir");
|
||||
|
||||
int
|
||||
main(int argc, char* argv[])
|
||||
{
|
||||
std::string message = ScratchSubdirGetMessage();
|
||||
NS_LOG_UNCOND(message);
|
||||
|
||||
Simulator::Run();
|
||||
Simulator::Destroy();
|
||||
|
||||
return 0;
|
||||
}
|
||||
Reference in New Issue
Block a user