-
Notifications
You must be signed in to change notification settings - Fork 30
/
Makefile
111 lines (73 loc) · 3.03 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# libeom
#
# Makefile for libeom - provides options for creating a static library out of all or part of libeom
#
# 2021-02-12
# Eric Meehan
###############################################################################
# MARK: ALL
###############################################################################
# Create top level static library and all sub-libraries
all: Main DataStructures Networking Systems
###############################################################################
# MARK: MAIN
###############################################################################
# Creates just the top level static library
Main: DataStructuresSub NetworkingSub SystemsSub
ar rcs libeom.a Node.o LinkedList.o Queue.o BinarySearchTree.o Entry.o Dictionary.o Client.o Server.o HTTPServer.o HTTPRequest.o ThreadPool.o PeerToPeer.o Files.o
###############################################################################
# MARK: DATA STRUCTURES
###############################################################################
# Creates the data structures library
DataStructures: DataStructuresSub
ar rcs DataStructures/DataStructures.a Node.o LinkedList.o Queue.o BinarySearchTree.o Entry.o Dictionary.o
# Sub components of the data structures library
DataStructuresSub: Node LinkedList Queue BinarySearchTree Entry Dictionary
Node:
gcc -c DataStructures/Common/Node.c
LinkedList:
gcc -c DataStructures/Lists/LinkedList.c
Queue:
gcc -c DataStructures/Lists/Queue.c
BinarySearchTree:
gcc -c DataStructures/Trees/BinarySearchTree.c
Entry:
gcc -c DataStructures/Dictionary/Entry.c
Dictionary:
gcc -c DataStructures/Dictionary/Dictionary.c
###############################################################################
# MARK: NETWORKING
###############################################################################
# Creates the networking library
Networking: NetworkingSub
ar rcs Networking/Networking.a Server.o HTTPRequest.o HTTPServer.o Node.o LinkedList.o Queue.o BinarySearchTree.o Entry.o Client.o Dictionary.o ThreadPool.o PeerToPeer.o
# Sub components of the networking library
NetworkingSub: DataStructuresSub SystemsSub Server Client HTTPRequest HTTPServer PeerToPeer
Server:
gcc -c Networking/Nodes/Server.c
Client:
gcc -c Networking/Nodes/Client.c
PeerToPeer:
gcc -c Networking/Nodes/PeerToPeer.c
HTTPServer:
gcc -c Networking/Nodes/HTTPServer.c
HTTPRequest:
gcc -c Networking/Protocols/HTTPRequest.c
###############################################################################
# MARK: Systems
###############################################################################
# Creates the systems library
Systems: SystemsSub
ar rcs Systems/System.a ThreadPool.o Files.o
# Sub components of the systems library
SystemsSub: ThreadPool Files
ThreadPool:
gcc -c Systems/ThreadPool.c
Files:
gcc -c Systems/Files.c
###############################################################################
# MARK: CLEAN
###############################################################################
# Remove all .o files
clean:
rm *.o