aboutsummaryrefslogtreecommitdiff
path: root/make/gmsl.mk
blob: e988d2c3e82c9735c24400f5d4d33d78c2b1c278 (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
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
112
113
114
115
#
# mal (Make Lisp) trimmed and namespaced GMSL functions/definitions
# 	- derived from the GMSL 1.1.3
#

ifndef __mal_gmsl_included
__mal_gmsl_included := true

# ----------------------------------------------------------------------------
#
# GNU Make Standard Library (GMSL)
#
# A library of functions to be used with GNU Make's $(call) that
# provides functionality not available in standard GNU Make.
#
# Copyright (c) 2005-2013 John Graham-Cumming
#
# This file is part of GMSL
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
#
# Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# 
# Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# Neither the name of the John Graham-Cumming nor the names of its
# contributors may be used to endorse or promote products derived from
# this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
#
# ----------------------------------------------------------------------------


# Numbers
__gmsl_sixteen := x x x x x x x x x x x x x x x x
__gmsl_input_int := $(foreach a,$(__gmsl_sixteen),         \
                        $(foreach b,$(__gmsl_sixteen),     \
                            $(foreach c,$(__gmsl_sixteen), \
                                $(__gmsl_sixteen)))))

int_decode = $(words $1)
int_encode = $(wordlist 1,$1,$(__gmsl_input_int))

__gmsl_int_wrap = $(call int_decode,$(call $1,$(call int_encode,$2),$(call int_encode,$3)))

int_plus = $(strip $1 $2)
int_subtract = $(strip $(if $(call int_gte,$1,$2), \
                $(filter-out xx,$(join $1,$2)),    \
                $(warning Subtraction underflow)))
int_multiply = $(strip $(foreach a,$1,$2))
# _error function must be provided to report/catch division by zero
int_divide = $(strip $(if $2,                                              \
                 $(if $(call int_gte,$1,$2),                               \
                     x $(call int_divide,$(call int_subtract,$1,$2),$2),), \
                 $(call _error,Division by zero)))

int_max = $(subst xx,x,$(join $1,$2))
int_min = $(subst xx,x,$(filter xx,$(join $1,$2)))
int_gt = $(strip $(filter-out $(words $2),$(words $(call int_max,$1,$2))))
int_gte = $(strip $(call int_gt,$1,$2)$(call int_eq,$1,$2))
int_lt = $(strip $(filter-out $(words $1),$(words $(call int_max,$1,$2))))
int_lte = $(strip $(call int_lt,$1,$2)$(call int_eq,$1,$2))
int_eq = $(strip $(filter $(words $1),$(words $2)))
int_ne = $(strip $(filter-out $(words $1),$(words $2)))

gmsl_plus = $(call __gmsl_int_wrap,int_plus,$1,$2)
gmsl_subtract = $(call __gmsl_int_wrap,int_subtract,$1,$2)
gmsl_multiply = $(call __gmsl_int_wrap,int_multiply,$1,$2)
gmsl_divide = $(call __gmsl_int_wrap,int_divide,$1,$2)


# Strings

__gmsl_characters := A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
__gmsl_characters += a b c d e f g h i j k l m n o p q r s t u v w x y z
__gmsl_characters += 0 1 2 3 4 5 6 7 8 9
__gmsl_characters += ` ~ ! @ \# $$ % ^ & * ( ) - _ = +
__gmsl_characters += { } [ ] \ : ; ' " < > , . / ? |
__syntax_highlight_protect = #"'`


__gmsl_space := 
__gmsl_space +=

gmsl_strlen = $(strip $(eval __temp := $(subst $(__gmsl_space),x,$1)) \
                $(foreach a,$(__gmsl_characters),$(eval __temp := $$(subst $$a,x,$(__temp)))) \
                $(eval __temp := $(subst x,x ,$(__temp))) \
                $(words $(__temp)))

gmsl_merge = $(strip $(if $2, \
               $(if $(call _EQ,1,$(words $2)), \
                  $2,$(firstword $2)$1$(call gmsl_merge,$1,$(wordlist 2,$(words $2),$2)))))

gmsl_pairmap = $(strip \
                 $(if $2$3,$(call $1,$(word 1,$2),$(word 1,$3))     \
                           $(call gmsl_pairmap,$1,$(wordlist 2,$(words $2),$2),$(wordlist 2,$(words $3),$3))))

endif