X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=test%2Fapp_test%2FMakefile;h=822447761b556ce1bcb131a91f7fcdff7f28aa2c;hb=refs%2Fchanges%2F25%2F5925%2F2;hp=cd6933ec4eeabcc0586b772718758f36004336ec;hpb=e8a5b2c912d4be9cc93bc52ad7a460b57321c5fd;p=ric-plt%2Flib%2Frmr.git diff --git a/test/app_test/Makefile b/test/app_test/Makefile index cd6933e..8224477 100644 --- a/test/app_test/Makefile +++ b/test/app_test/Makefile @@ -1,6 +1,7 @@ -#================================================================================== -# Copyright (c) 2019 Nokia -# Copyright (c) 2018-2019 AT&T Intellectual Property. +# +#================================================================================= +# Copyright (c) 2019-2021 Nokia +# Copyright (c) 2018-2021 AT&T Intellectual Property. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -16,42 +17,58 @@ #================================================================================== # -# NOTE: this makefile assumes that RMr has been built using the directory .build +# NOTE: this makefile assumes that RMR has been built using the directory .build # at the top most repo directory (e.g. ../../.build). It can be changed # if you need to by adding "build_path=" to the make command line. +# To use this makefile to build on a system where RMR is already installed +# try: make build_path=/usr/local/lib +# +# By default we prefer the Korn shell (it's just better). If you really need +# to build with a dfferent shell add "SHELL=path" to the command line: +# make SHELL=/bin/bash +# .EXPORT_ALL_VARIABLES: .ONESHELL: -.SHELLFLAGS = -e -SHELL = /bin/ksh +#.SHELLFLAGS = -e # hosed on some flavours so keep it off +SHELL ?= /bin/ksh + +ex_cflags = $(shell echo $$EX_CFLAGS ) build_path ?= ../../.build -header_path := $(shell find ../../.build -name 'rmr.h' |head -1 | sed 's!/rmr/.*!!' ) +header_path := $(shell find $(build_path) -name 'rmr.h' 2>/dev/null |head -1 | sed 's!/rmr/.*!!' ) -C_INCLUDE_PATH := $(header_path) -LD_LIBRARY_PATH=$(build_path):$(build_path)/lib +# use from environment if there so as to allow build to reference installed base +C_INCLUDE_PATH ?= $(header_path) +LD_LIBRARY_PATH ?= $(build_path):$(build_path)/lib LIBRARY_PATH = $(LD_LIBRARY_PATH) # These programmes are designed to test some basic application level functions -# from the perspective of two communicating processes. +# from the perspective of two, or more, communicating processes. + +.PHONY: all all_si +all: sender receiver caller mt_receiver v_sender ex_rts_receiver -.PHONY: all -all: sender receiver sender_nano receiver_nano +all_si: sender_si receiver_si -receiver_nano: receiver.c - gcc -I $${C_INCLUDE_PATH:-.} $< -g -o $@ -lrmr -lnanomsg -lpthread -lm -receiver: receiver.c - gcc -I $${C_INCLUDE_PATH:-.} $< -g -o $@ -lrmr_nng -lnng -lpthread -lm +# ------ all builds are si95 now --------------------------------------------------- -sender_nano: sender.c - gcc -I $${C_INCLUDE_PATH:-.} $< -g -o $@ -lrmr -lnanomsg -lpthread -lm +%:%.c + gcc -I $${C_INCLUDE_PATH:-.} $< -g -o $@ -lrmr_si -lpthread -lm -sender: sender.c - gcc -I $${C_INCLUDE_PATH:-.} $< -g -o $@ -lrmr_nng -lnng -lpthread -lm +# special build rule as it reuses an existing source module with a sepcial define +mt_receiver: receiver.c + gcc -I $${C_INCLUDE_PATH:-.} -DMTC $< -g -o $@ -lrmr_si -lpthread -lm -.PHONY: clean +# --------- housekeeping ----------------------------------------------------------- + +# clean removes intermediates; nuke removes everything that can be built +.PHONY: clean nuke clean: - rm -f sender sender_nano receiver receiver_nano *.o + rm -f *.o + +nuke: clean + rm -f sender receiver caller mt_receiver