]> gitweb.michael.orlitzky.com - hath.git/blob - hath.cabal
hath.cabal: simplify GHC flags used in the shelltest suite.
[hath.git] / hath.cabal
1 name: hath
2 version: 0.4.2
3 cabal-version: >= 1.8
4 author: Michael Orlitzky
5 maintainer: Michael Orlitzky <michael@orlitzky.com>
6 homepage: http://michael.orlitzky.com/code/hath.xhtml
7 category: Utils
8 license: AGPL-3
9 license-file: doc/LICENSE
10 build-type: Simple
11 extra-source-files:
12 doc/man1/hath.1
13 test/shell/*.test
14 synopsis:
15 Hath manipulates network blocks in CIDR notation.
16 description:
17 Hath is a Haskell program for working with network blocks in CIDR
18 notation. When dealing with blocks of network addresses, there are a
19 few things that one usually wants to do with them:
20 .
21 * Create a regular expression matching the CIDR block(s). This is
22 because grep will throw up if you feed it CIDR.
23 .
24 * Combine small blocks into larger ones. For example, if you have two
25 consecutive \/24s, they might combine into a larger \/23.
26 .
27 * View the result of block combination in a useful way.
28 .
29 * List them.
30 .
31 Hath has several modes to perform these functions:
32 .
33 [@Regexed@]
34 This computes a (Perl-compatible) regular expression matching
35 the input CIDR blocks. It's the default mode of operation.
36 .
37 [@Reduced@]
38 This combines small blocks into larger ones where possible, and
39 eliminates redundant blocks. The output should be equivalent to
40 the input, though.
41 .
42 [@Duped@]
43 Shows only the blocks that would be removed by reduce; that is, it
44 shows the ones that would get combined into larger blocks or are
45 simply redundant.
46 .
47 [@Diffed@]
48 Shows what would change if you used reduce. Uses diff-like
49 notation.
50 .
51 [@Listed@]
52 List the IP addresses contained within the given CIDRs.
53 .
54 /Examples/:
55 .
56 Compute a (Perl-compatible) regular expression matching
57 the input CIDR blocks. It's the default mode of operation.
58 .
59 @
60 $ echo \"10.0.0.0\/29 10.0.0.8\/29\" | hath
61 ((10)\.(0)\.(0)\.(15|14|13|12|11|10|9|8|7|6|5|4|3|2|1|0))
62 @
63 .
64 Combine two \/24s into a \/23:
65 .
66 @
67 $ echo \"10.0.0.0\/24 10.0.1.0\/24\" | hath reduced
68 10.0.0.0/23
69 @
70 .
71 List the addresses in 192.168.0.240\/29:
72 .
73 @
74 $ echo 192.168.0.240\/29 | hath listed
75 192.168.0.240
76 192.168.0.241
77 192.168.0.242
78 192.168.0.243
79 192.168.0.244
80 192.168.0.245
81 192.168.0.246
82 192.168.0.247
83 @
84 .
85 The command-line syntax and complete set of options are documented in
86 the man page.
87
88
89 executable hath
90
91 main-is:
92 Main.hs
93
94 hs-source-dirs:
95 src/
96
97 other-modules:
98 Bit
99 Cidr
100 CommandLine
101 ExitCodes
102 IPv4Address
103 Maskable
104 Maskbits
105 Octet
106 Paths_hath
107
108 build-depends:
109 base >= 4.9 && < 5,
110 cmdargs >= 0.10,
111 split >= 0.2,
112 tasty >= 0.8,
113 tasty-hunit >= 0.8,
114 tasty-quickcheck >= 0.8.1
115
116 ghc-options:
117 -Weverything
118 -Wno-implicit-prelude
119 -Wno-safe
120 -Wno-unsafe
121 -Wno-all-missed-specialisations
122 -rtsopts
123 -threaded
124 -optc-O3
125 -optc-march=native
126 -O2
127
128
129 test-suite testsuite
130 type: exitcode-stdio-1.0
131 hs-source-dirs: src test
132 main-is: TestSuite.hs
133
134 other-modules:
135 Bit
136 Cidr
137 IPv4Address
138 Maskable
139 Maskbits
140 Octet
141
142 build-depends:
143 base == 4.*,
144 cmdargs >= 0.10,
145 split >= 0.2,
146 tasty >= 0.8,
147 tasty-hunit >= 0.8,
148 tasty-quickcheck >= 0.8.1
149
150
151 -- It's not entirely clear to me why I have to reproduce all of this.
152 ghc-options:
153 -Weverything
154 -Wno-implicit-prelude
155 -Wno-safe
156 -Wno-unsafe
157 -Wno-all-missed-specialisations
158 -rtsopts
159 -threaded
160 -optc-O3
161 -optc-march=native
162 -O2
163
164
165 -- These won't work without shelltestrunner installed in your
166 -- $PATH. Maybe there is some way to tell Cabal that.
167 test-suite shelltests
168 type: exitcode-stdio-1.0
169 hs-source-dirs: test
170 main-is: ShellTests.hs
171
172 build-depends:
173 base == 4.*,
174 process >= 1.1
175
176 -- It's not entirely clear to me why I have to reproduce all of this.
177 ghc-options:
178 -Weverything
179 -Wno-implicit-prelude
180 -Wno-safe
181 -Wno-unsafe
182 -Wno-all-missed-specialisations
183 -rtsopts
184 -threaded
185 -optc-O3
186 -optc-march=native
187 -O2
188
189 source-repository head
190 type: git
191 location: http://gitweb.michael.orlitzky.com/hath.git
192 branch: master