Skip to main content

How to Write Makefile

Assume there are more number of source files to be compiled using a set of commands everytime is a tedious process. So there is a facility to compile everything at a stretch is by the use of a Makefile.
The makefile can be named as either “Makefile” or “makefile”.
Let me define four files for my simple application, create a new directory and store all the files given below
  • main.c  (which contains the main program)
  • sum.c (summing function is defined)
  • hello.c (print hello world)
  • function.h (function prototypes are declared)
//function.h
int sum(int,int);
void print_hello();
//hello.c
#include
#include “function.h”
void print_hello()
{
printf(“Hello World \n”);
}
//sum.c
#include “function.h”
int sum(int a, int b)
{
int c;
c=a+b;
return c;
}
//main.c
#include
#include “function.h”
int main()
{
int a=10,b=20,c;
print_hello();
c=sum(a,b);
printf(“The sum of two numbers is %d “,c);
return 0;
}
There are different methods of compiling this file
Method 1: (gcc command based)
gcc main.c sum.c hello.c –o pradeep
once you execute the above command, an executable named pradeep is created and you can see the output by typing./pradeep
Method 2: using Makefile

The basic makefile is composed of:
This syntax applied to example would look like:
target: dependencies
[tab] system command
all:
gcc main.c sum.c hello.c –o pradeep
to run this make file(the file name should be Makefile or makefile), execute the command
make
Method 3: using Makefile with dependencies
There may be a chance of using different targets in your makefile, this is because if you modify a single file in your project, you don’t have to recompile everything, only what you modified.
Here is an example
all: pradeep
hello: main.o sum.o hello.o
gcc main.o sum.o hello.o -o hello

main.o: main.c
gcc –c main.c

sum.o: sum.c
gcc –c sum.c

hello.o: hello.c
gcc –c hello.c


Method 4: using variables
CC=gcc
CFLAGS=-c -Wall

all: hello
hello: main.o sum.o hello.o
$(CC) main.o sum.o hello.o -o hello

main.o: main.c
$(CC) $(CFLAGS) main.c

sum.o: sum.c
$(CC) $(CFLAGS) sum.c

hello.o: hello.c
$(CC) $(CFLAGS) hello.c

Method 5:
With this brief introduction to Makefiles, you can create some very sophisticated mechanism for compiling your projects.
CC=gcc
CFLAGS=-c -Wall
LDFLAGS=
SOURCES=main.c hello.c sum.c
OBJECTS=$(SOURCES:.cpp=.o)
EXECUTABLE=hello

all: $(SOURCES) $(EXECUTABLE)
$(EXECUTABLE): $(OBJECTS)
$(CC) $(LDFLAGS) $(OBJECTS) -o $@

.c.o:
$(CC) $(CFLAGS) $< -o $@

If you understand this last example, you could adapt it to your own personal projects changing only 2 lines, no matter how many additional files you have !!!.
The above examples is tested only on linux and Windows also supports make utility (through nmake utility), the readers are advised to work on their own in Windows. the following link will show you the way to nmake utility












































Comments

Popular posts from this blog

Routing in VANETs using ns3

Part 1
WAVE - Wireless Access for Vehicular environments. vanet-routing-compare.cc It might take more than an hour. The readers are requested to be patient. SUMO, VANETs, routing comparison 1. Explain the full source code (1550 lines of code) 2. Creating a real scenario using osm (Open Street Map Web Wizard) 3. Performance analysis for various vanet protocols. https://www.nsnam.com Location of the source code /home/pradeepkumar/ns-allinone-3.27/ns-3.27/src/wave/examples
Move this file to the scratch/ for inclusion of all modules. Step 1: Explanation of source code. Copy the file to scratch folder. This is just Part 1 of the VANET comparison

Part 2 Please watch the First Part before watching this video   https://www.youtube.com/watch?v=IJYeIpUqjQI&t=850s
Part 2 - Analysis of the results.
Please go through the first video (Part 1) and then watch this video (PArt 2)
#VANETs #NS3 #Routing
1. SUMO for web traffic (osmWebWizard.py) 2. Convert this into mobility.tcl file and t…

ns3 installation in Ubuntu 16.04

This post serves the installation instructions of ns3 in ubuntu 16.04 version. Some of my students are working in ns3, this post will benefit them in installing ns3.

OS Used: Ubuntu 16.04.4
ns3 version: ns3 version 3.27

The same procedure will be applied for OS like Debian, Linux Mint.

Fresh installation of Ubuntu 16.04 Let you try the fresh installation of ubuntu in your hard disk along with windows.
Installation of ns3 dependencies ns3 needs so many dependencies, developmental libraries, drivers, etc. so install all those
$] sudo apt update  $] sudo apt upgrade
$] sudo apt-get install build-essential autoconf automake libxmu-dev python-pygoocanvas python-pygraphviz cvs mercurial bzr git cmake p7zip-full python-matplotlib python-tk python-dev python-kiwi python-gnome2 python-gnome2-desktop-dev python-rsvg qt4-dev-tools qt4-qmake qt4-qmake qt4-default gnuplot-x11 wireshark
The above command make take some time to download, compile and install it, Be Patient. 
Installing ns3 Download the…

TORA Protocol in NS-2.35 (NS2)

This post tells you how to enable the TORA (Temporally ordered routing Algorithm) protocol in Network Simulator 2 (ns-2.35)

TORA is a protocol in wireless adhoc networks that works with timing parameters. NS-2.35 comes with the TORA protocol by default but it has to be tweaked manually to make it run.
This post will help you to do that.

You can watch this video for detailed instructions:


Step 1: Generate a Scenario for TORA protoco using NS2 Scenario Generator NSG Software.
We have created a tcl file using NSG2.1.jar

$] java -jar NSG2.1.jar

Three files have to be modified
~ns-2.35/tora/tora.cc~ns-2.35/tora/tora.h~ns-2.35/imep/imep.cc There are various websites that tells you how to configure TORA by making changes to the above three files.  Change 1: tora.h In the tora.h file, go to the end of the File before the agent completes, include these two lines

#include <classifier/classifier-port.h>
protected: PortClassifier *dmux_;

Change 2: tora.cc Open the tora.cc and include the follow…