summaryrefslogtreecommitdiff
path: root/dev-haskell/language-haskell-extract/metadata.xml
blob: cfb283864121db2e51e68984db44e5bb2af55f4e (plain)
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
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
<pkgmetadata>
	<herd>haskell</herd>
	<longdescription>
		@language-haskell-extract@ contains some useful helper functions on top of Template Haskell.
		
		@functionExtractor@ extracts all functions after a regexp-pattern.
		
		&gt; foo = "test"
		&gt; boo = "testing"
		&gt; bar = $(functionExtractor "oo$")
		
		will automagically extract the functions ending with @oo@ such as
		
		&gt; bar = [("foo",foo), ("boo",boo)]
		
		This can be useful if you wish to extract all functions beginning with test (for a test-framework)
		or all functions beginning with wc (for a web service).
		
		@functionExtractorMap@ works like @functionsExtractor@ but applies a function over all function-pairs.
		
		This functions is useful if the common return type of the functions is a type class.
		
		Example:
		
		&gt; secondTypeclassTest =
		&gt;   do let expected = ["45", "88.8", "\"hej\""]
		&gt;          actual = $(functionExtractorMap "^tc" [|\n f -&gt; show f|] )
		&gt;      expected @=? actual
		&gt;
		&gt; tcInt :: Integer
		&gt; tcInt = 45
		&gt;
		&gt; tcDouble :: Double
		&gt; tcDouble = 88.8
		&gt;
		&gt; tcString :: String
		&gt; tcString = "hej"
	</longdescription>
	<upstream>
		<remote-id type="github">finnsson/template-helper</remote-id>
	</upstream>
</pkgmetadata>