SlideShare ist ein Scribd-Unternehmen logo
1 von 23
Introduction To Makefile
Makefile Tutorial
EL KTAOUI ZAKARIA
Email: : elktaoui@outlook.com
Faecbook: https://www.facebook.com/Elktaoui.zakaria
Linkedin: ma.linkedin.com/in/elktaoui/
Table of Content
 Introduction
 Why Makefile ?
 How does it work ?
 How to Make a simple Makefile ?
 Makefile Rules
Sudo has a Make 
Introduction
The utility simply known as make is one of the
most enduring features of both Unix and other
operating systems.
First invented in the 1970s, make still turns up
to this day as the central engine in
most programming projects; it even builds
the Linux kernel.
In this presentation you will learn why this
utility continues to hold its top position
in project build software, despite many
younger competitors.
Makefile Why ?
 Make checks timestamps to see what has changed and rebuilds just
what you need, without wasting time rebuilding other files.
 Manage Several source files and compile them quickly with a single
Command Line.
 Make layers a rich collection of options that lets you manipulate
multiple directories, build different versions of programs for different
platforms, and customize your builds in other ways.
Make Utility

If you run
make

This will cause the make program to read the makefile and build the first
target it finds there

.

If you have several makefiles, then you can
execute them with the command:
make -f mymakefile
For more options use : $ man make
How does it work ?
Typically the default goal in most makefiles is to build
a program. This usually involves many steps:
1. Generate the source code using some utilities like Flex &
Bison.
2. Compile the source code into binary file (.o files c/c++/java
etc ..
3. bound the Object files together using a linker( gcc/g++) to
form an executable program(.exe)
How does it work ?
Makefile contains a set of rules used to build
an application.
The first rule (default rule) seen by make
consists of three parts:
 The Target.
 The Dependencies.
 The Command to be performed.
Target and Dependencies
Now let’s see the Make Process :
 Make is asked to evaluate a rule, it begins by finding the files
indicated by the dependencies and target.
 If any of the dependencies has an associated rule, make attempts to
update those first. Next, the target file is considered.

 If any dependency is newer than the target, the target is
remade by executing the commands.
 If any dependency is newer than the target, the target is
remade by executing the commands.
How to Make a Simple Makefile
Exec: projet.o test.o
gcc –o exec projet.o test.o
projet.o: projet.c
gcc –o projet.o –c projet.c –Wall
Test.o: test.c
gcc –o main.o –c test.c -Wall
How to Make a Simple Makefile
 The target file Exec appears before the colon.

 The dependencies project.c and test.o appear after the colon.
 The command Line usually appears on the following lines and
is preceded by a tab character.
How to Make a Simple Makefile
When this makefile is executed for the first time, we see:
$ make
gcc –o projet.o –c projet.c –Wall
gcc –o test.o –c test.c-Wall
gcc –o exec projet.o test.o
As you look at the makefile and sample execution, you may notice
the order in which commands are executed by make are nearly the
opposite to the order they occur in the Makefile..

Now we have an executable program 
How to Make a Simple Makefile
But How He did that  :
1. First make notices that the command line contains no targets so it decides to make
the default goal, Exec(Our Executable) .
2. It checks for dependencies and sees three: project.o main.o now considers how to
build projetc.o and main.o and sees a rule for it

3. Again, it checks the dependencies, notices that project.c has no rule but (that file
exists), so make executes the commands to transform project.c into project.o by
executing the command ! gcc –o projet.o –c projet.c –Wall
Makefile Rules
In the last section, we wrote some rules to compile and link our program.
Each of those rules defines a target, that is, a file to be updated. Each
target file depends on a set of dependencies, which are also files.
Since rules are so important in make, there are a number of different kinds
of rules. Explicit rules (This is the most common type of rule you will be
writing), and Implicit rules.
Makefile Rules
A makefile often contains long lists of files. To simplify this process make supports
wildcards (also known as globbing).

Wildcards can be very useful for creating more adaptable makefiles. For instance,
instead of listing all the files in a program explicitly, you can use wildcards define a
rule that applies to all files ending in the %.o and %.c suffix.
Automatic variables are set by make after a rule is matched. They provide access
to elements from the target and dependency (so you don’t have to explicitly
specify any filenames)
Variables (Constants) : some can be set by the user to control make’s behavior
while others are set by make to communicate with the user’s makefile.
Makefile Rules
Use WildCard:
%.o: %.c
gcc –o $@ –c $< –Wall
Explanation :
1.
2.
3.
4.

The .o files depends on the .c files.
To generate the .o file, we needs to compile the .c file.
$@ define the filename of the target.
$< define the filename of the first dependency.
Makefile Rules
Define Variables :
CC=gcc
WFLAGS=-Wall
OBJ=projet.o test.o
Exec: $(OBJ)
$(CC) –o $@ $^ $(WFLAGS)
%.o: %.c
$(CC) –o $@ –c $< $(WFLAGS)

Explanation :
 In this exemple we defined some variables CC,WFLAGS,OBJ.
 Variable name must be surrounded by $() or ${}.
 A single character variable name does not require the parentheses.
Makefile Rules
Automatic Variables:
 They provide access to elements from the target and prerequisite lists so
you don’t have to explicitly specify any filenames.
 They are very useful for avoiding code duplication.
Exec: $(OBJ)
$(CC) –o $@ $^ $(WFLAGS)
%.o: %.c
$(CC) –o $@ –c $< $(WFLAGS)

$@ The filename representing the target.
$< The filename of the first dependency.
$^ The filenames of all the dependencies.
Conclusion
Phony Target :
Simple Target to run Command line, Dont create files,most
phony targets do not have prerequisites.
Standard Phony Target :
 Make clean
 Make all
 Make install
.PHONY: clean
clean:
rm –f *.o
Conclusion
Remarks:
 Don’t forget about the TAB Before the
Command.
 Read Tutorials and practice with simple
Example.
 Send Message on Social Media  feel free to
Ask.
Introduction to Makefile
Introduction to Makefile

Weitere ähnliche Inhalte

Was ist angesagt?

Was ist angesagt? (20)

An Introduction to CMake
An Introduction to CMakeAn Introduction to CMake
An Introduction to CMake
 
Shell scripting
Shell scriptingShell scripting
Shell scripting
 
GCC compiler
GCC compilerGCC compiler
GCC compiler
 
XPDDS18: A dive into kbuild - Cao jin, Fujitsu
XPDDS18: A dive into kbuild - Cao jin, FujitsuXPDDS18: A dive into kbuild - Cao jin, Fujitsu
XPDDS18: A dive into kbuild - Cao jin, Fujitsu
 
CMake - Introduction and best practices
CMake - Introduction and best practicesCMake - Introduction and best practices
CMake - Introduction and best practices
 
How A Compiler Works: GNU Toolchain
How A Compiler Works: GNU ToolchainHow A Compiler Works: GNU Toolchain
How A Compiler Works: GNU Toolchain
 
Shell scripting
Shell scriptingShell scripting
Shell scripting
 
Valgrind
ValgrindValgrind
Valgrind
 
CMake best practices
CMake best practicesCMake best practices
CMake best practices
 
Introduction to gdb
Introduction to gdbIntroduction to gdb
Introduction to gdb
 
Linux System Monitoring
Linux System Monitoring Linux System Monitoring
Linux System Monitoring
 
Conan.io - The C/C++ package manager for Developers
Conan.io - The C/C++ package manager for DevelopersConan.io - The C/C++ package manager for Developers
Conan.io - The C/C++ package manager for Developers
 
GDB Rocks!
GDB Rocks!GDB Rocks!
GDB Rocks!
 
Shell Scripting
Shell ScriptingShell Scripting
Shell Scripting
 
Unix shell scripting basics
Unix shell scripting basicsUnix shell scripting basics
Unix shell scripting basics
 
Shellscripting
ShellscriptingShellscripting
Shellscripting
 
Bash Shell Scripting
Bash Shell ScriptingBash Shell Scripting
Bash Shell Scripting
 
Embedded Android : System Development - Part IV
Embedded Android : System Development - Part IVEmbedded Android : System Development - Part IV
Embedded Android : System Development - Part IV
 
The Internals of "Hello World" Program
The Internals of "Hello World" ProgramThe Internals of "Hello World" Program
The Internals of "Hello World" Program
 
Java Basics
Java BasicsJava Basics
Java Basics
 

Ähnlich wie Introduction to Makefile

Makefile
MakefileMakefile
MakefileIonela
 
Carmen En
Carmen EnCarmen En
Carmen EnCarmen
 
LOSS_C11- Programming Linux 20221006.pdf
LOSS_C11- Programming Linux 20221006.pdfLOSS_C11- Programming Linux 20221006.pdf
LOSS_C11- Programming Linux 20221006.pdfThninh2
 
Software Build processes and Git
Software Build processes and GitSoftware Build processes and Git
Software Build processes and GitAlec Clews
 
CS8251_QB_answers.pdf
CS8251_QB_answers.pdfCS8251_QB_answers.pdf
CS8251_QB_answers.pdfvino108206
 
ASP.NET Core and Docker
ASP.NET Core and DockerASP.NET Core and Docker
ASP.NET Core and DockerChuck Megivern
 
Makefile for python projects
Makefile for python projectsMakefile for python projects
Makefile for python projectsMpho Mphego
 
Leiningen2 - humane build management for clojure
Leiningen2 - humane build management for clojureLeiningen2 - humane build management for clojure
Leiningen2 - humane build management for clojureJohn Stevenson
 
.NET,ASP .NET, Angular Js,LinQ
.NET,ASP .NET, Angular Js,LinQ.NET,ASP .NET, Angular Js,LinQ
.NET,ASP .NET, Angular Js,LinQAvijit Shaw
 
Handling Database Deployments
Handling Database DeploymentsHandling Database Deployments
Handling Database DeploymentsMike Willbanks
 
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development team
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development teamMoving from CruiseControl.NET to Jenkins in the PVS-Studio development team
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development teamPVS-Studio
 
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development team
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development teamMoving from CruiseControl.NET to Jenkins in the PVS-Studio development team
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development teamSofia Fateeva
 
Lightning web components
Lightning web components Lightning web components
Lightning web components Cloud Analogy
 
Autoconf&Automake
Autoconf&AutomakeAutoconf&Automake
Autoconf&Automakeniurui
 
(1) c sharp introduction_basics_dot_net
(1) c sharp introduction_basics_dot_net(1) c sharp introduction_basics_dot_net
(1) c sharp introduction_basics_dot_netNico Ludwig
 
Introduction to node.js
Introduction to node.jsIntroduction to node.js
Introduction to node.jsSu Zin Kyaw
 

Ähnlich wie Introduction to Makefile (20)

Makefile
MakefileMakefile
Makefile
 
Carmen En
Carmen EnCarmen En
Carmen En
 
Basic Make
Basic MakeBasic Make
Basic Make
 
LOSS_C11- Programming Linux 20221006.pdf
LOSS_C11- Programming Linux 20221006.pdfLOSS_C11- Programming Linux 20221006.pdf
LOSS_C11- Programming Linux 20221006.pdf
 
Linux intro 5 extra: makefiles
Linux intro 5 extra: makefilesLinux intro 5 extra: makefiles
Linux intro 5 extra: makefiles
 
Software Build processes and Git
Software Build processes and GitSoftware Build processes and Git
Software Build processes and Git
 
A05
A05A05
A05
 
CS8251_QB_answers.pdf
CS8251_QB_answers.pdfCS8251_QB_answers.pdf
CS8251_QB_answers.pdf
 
ASP.NET Core and Docker
ASP.NET Core and DockerASP.NET Core and Docker
ASP.NET Core and Docker
 
Makefile for python projects
Makefile for python projectsMakefile for python projects
Makefile for python projects
 
Leiningen2 - humane build management for clojure
Leiningen2 - humane build management for clojureLeiningen2 - humane build management for clojure
Leiningen2 - humane build management for clojure
 
.NET,ASP .NET, Angular Js,LinQ
.NET,ASP .NET, Angular Js,LinQ.NET,ASP .NET, Angular Js,LinQ
.NET,ASP .NET, Angular Js,LinQ
 
Linkers
LinkersLinkers
Linkers
 
Handling Database Deployments
Handling Database DeploymentsHandling Database Deployments
Handling Database Deployments
 
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development team
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development teamMoving from CruiseControl.NET to Jenkins in the PVS-Studio development team
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development team
 
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development team
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development teamMoving from CruiseControl.NET to Jenkins in the PVS-Studio development team
Moving from CruiseControl.NET to Jenkins in the PVS-Studio development team
 
Lightning web components
Lightning web components Lightning web components
Lightning web components
 
Autoconf&Automake
Autoconf&AutomakeAutoconf&Automake
Autoconf&Automake
 
(1) c sharp introduction_basics_dot_net
(1) c sharp introduction_basics_dot_net(1) c sharp introduction_basics_dot_net
(1) c sharp introduction_basics_dot_net
 
Introduction to node.js
Introduction to node.jsIntroduction to node.js
Introduction to node.js
 

Kürzlich hochgeladen

TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxRustici Software
 
Ransomware_Q4_2023. The report. [EN].pdf
Ransomware_Q4_2023. The report. [EN].pdfRansomware_Q4_2023. The report. [EN].pdf
Ransomware_Q4_2023. The report. [EN].pdfOverkill Security
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...apidays
 
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Zilliz
 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAndrey Devyatkin
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodJuan lago vázquez
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerThousandEyes
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfsudhanshuwaghmare1
 
Real Time Object Detection Using Open CV
Real Time Object Detection Using Open CVReal Time Object Detection Using Open CV
Real Time Object Detection Using Open CVKhem
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...apidays
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonAnna Loughnan Colquhoun
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyKhushali Kathiriya
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Jeffrey Haguewood
 
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot ModelNavi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot ModelDeepika Singh
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProduct Anonymous
 
MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsNanddeep Nachan
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Miguel Araújo
 
Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024The Digital Insurer
 

Kürzlich hochgeladen (20)

TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptx
 
Ransomware_Q4_2023. The report. [EN].pdf
Ransomware_Q4_2023. The report. [EN].pdfRansomware_Q4_2023. The report. [EN].pdf
Ransomware_Q4_2023. The report. [EN].pdf
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of Terraform
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
Real Time Object Detection Using Open CV
Real Time Object Detection Using Open CVReal Time Object Detection Using Open CV
Real Time Object Detection Using Open CV
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : Uncertainty
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot ModelNavi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Navi Mumbai Call Girls 🥰 8617370543 Service Offer VIP Hot Model
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectors
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
 
Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024
 

Introduction to Makefile

  • 1. Introduction To Makefile Makefile Tutorial EL KTAOUI ZAKARIA Email: : elktaoui@outlook.com Faecbook: https://www.facebook.com/Elktaoui.zakaria Linkedin: ma.linkedin.com/in/elktaoui/
  • 2. Table of Content  Introduction  Why Makefile ?  How does it work ?  How to Make a simple Makefile ?  Makefile Rules
  • 3. Sudo has a Make 
  • 4. Introduction The utility simply known as make is one of the most enduring features of both Unix and other operating systems. First invented in the 1970s, make still turns up to this day as the central engine in most programming projects; it even builds the Linux kernel.
  • 5. In this presentation you will learn why this utility continues to hold its top position in project build software, despite many younger competitors.
  • 6. Makefile Why ?  Make checks timestamps to see what has changed and rebuilds just what you need, without wasting time rebuilding other files.  Manage Several source files and compile them quickly with a single Command Line.  Make layers a rich collection of options that lets you manipulate multiple directories, build different versions of programs for different platforms, and customize your builds in other ways.
  • 7. Make Utility If you run make This will cause the make program to read the makefile and build the first target it finds there . If you have several makefiles, then you can execute them with the command: make -f mymakefile For more options use : $ man make
  • 8. How does it work ? Typically the default goal in most makefiles is to build a program. This usually involves many steps: 1. Generate the source code using some utilities like Flex & Bison. 2. Compile the source code into binary file (.o files c/c++/java etc .. 3. bound the Object files together using a linker( gcc/g++) to form an executable program(.exe)
  • 9. How does it work ? Makefile contains a set of rules used to build an application. The first rule (default rule) seen by make consists of three parts:  The Target.  The Dependencies.  The Command to be performed.
  • 10. Target and Dependencies Now let’s see the Make Process :  Make is asked to evaluate a rule, it begins by finding the files indicated by the dependencies and target.  If any of the dependencies has an associated rule, make attempts to update those first. Next, the target file is considered.  If any dependency is newer than the target, the target is remade by executing the commands.  If any dependency is newer than the target, the target is remade by executing the commands.
  • 11. How to Make a Simple Makefile Exec: projet.o test.o gcc –o exec projet.o test.o projet.o: projet.c gcc –o projet.o –c projet.c –Wall Test.o: test.c gcc –o main.o –c test.c -Wall
  • 12. How to Make a Simple Makefile  The target file Exec appears before the colon.  The dependencies project.c and test.o appear after the colon.  The command Line usually appears on the following lines and is preceded by a tab character.
  • 13. How to Make a Simple Makefile When this makefile is executed for the first time, we see: $ make gcc –o projet.o –c projet.c –Wall gcc –o test.o –c test.c-Wall gcc –o exec projet.o test.o As you look at the makefile and sample execution, you may notice the order in which commands are executed by make are nearly the opposite to the order they occur in the Makefile.. Now we have an executable program 
  • 14. How to Make a Simple Makefile But How He did that  : 1. First make notices that the command line contains no targets so it decides to make the default goal, Exec(Our Executable) . 2. It checks for dependencies and sees three: project.o main.o now considers how to build projetc.o and main.o and sees a rule for it 3. Again, it checks the dependencies, notices that project.c has no rule but (that file exists), so make executes the commands to transform project.c into project.o by executing the command ! gcc –o projet.o –c projet.c –Wall
  • 15. Makefile Rules In the last section, we wrote some rules to compile and link our program. Each of those rules defines a target, that is, a file to be updated. Each target file depends on a set of dependencies, which are also files. Since rules are so important in make, there are a number of different kinds of rules. Explicit rules (This is the most common type of rule you will be writing), and Implicit rules.
  • 16. Makefile Rules A makefile often contains long lists of files. To simplify this process make supports wildcards (also known as globbing). Wildcards can be very useful for creating more adaptable makefiles. For instance, instead of listing all the files in a program explicitly, you can use wildcards define a rule that applies to all files ending in the %.o and %.c suffix. Automatic variables are set by make after a rule is matched. They provide access to elements from the target and dependency (so you don’t have to explicitly specify any filenames) Variables (Constants) : some can be set by the user to control make’s behavior while others are set by make to communicate with the user’s makefile.
  • 17. Makefile Rules Use WildCard: %.o: %.c gcc –o $@ –c $< –Wall Explanation : 1. 2. 3. 4. The .o files depends on the .c files. To generate the .o file, we needs to compile the .c file. $@ define the filename of the target. $< define the filename of the first dependency.
  • 18. Makefile Rules Define Variables : CC=gcc WFLAGS=-Wall OBJ=projet.o test.o Exec: $(OBJ) $(CC) –o $@ $^ $(WFLAGS) %.o: %.c $(CC) –o $@ –c $< $(WFLAGS) Explanation :  In this exemple we defined some variables CC,WFLAGS,OBJ.  Variable name must be surrounded by $() or ${}.  A single character variable name does not require the parentheses.
  • 19. Makefile Rules Automatic Variables:  They provide access to elements from the target and prerequisite lists so you don’t have to explicitly specify any filenames.  They are very useful for avoiding code duplication. Exec: $(OBJ) $(CC) –o $@ $^ $(WFLAGS) %.o: %.c $(CC) –o $@ –c $< $(WFLAGS) $@ The filename representing the target. $< The filename of the first dependency. $^ The filenames of all the dependencies.
  • 20. Conclusion Phony Target : Simple Target to run Command line, Dont create files,most phony targets do not have prerequisites. Standard Phony Target :  Make clean  Make all  Make install .PHONY: clean clean: rm –f *.o
  • 21. Conclusion Remarks:  Don’t forget about the TAB Before the Command.  Read Tutorials and practice with simple Example.  Send Message on Social Media  feel free to Ask.