• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

sile-typesetter / sile / 10621606353

29 Aug 2024 07:43PM UTC coverage: 66.23% (+3.6%) from 62.644%
10621606353

push

github

alerque
Merge tag 'v0.15.5' into develop

13 of 289 new or added lines in 17 files covered. (4.5%)

403 existing lines in 59 files now uncovered.

11585 of 17492 relevant lines covered (66.23%)

5713.06 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

92.73
/types/length.lua
1
--- SILE length type.
2
-- Lengths are composed of 3 `measurement`s: a length, a stretch, and a shrink. Each part internally is just
3
-- a measurement, but combined describe a flexible length that is allowed to grow up to the amount defined by stretch or
4
-- compress up to the amount defined by shrink.
5
-- @types length
6

7
local function _error_if_not_number (a)
8
   if type(a) ~= "number" then
1,568✔
UNCOV
9
      SU.error("We tried to do impossible arithmetic on a " .. SU.type(a) .. ". (That's a bug)", true)
×
10
   end
11
end
12

13
--- @type length
14
local length = pl.class()
119✔
15
length.type = "length"
119✔
16

17
length.length = nil
119✔
18
length.stretch = nil
119✔
19
length.shrink = nil
119✔
20

21
--- Constructor.
22
-- @tparam measurement spec A measurement or value that can be cast to a measurement.
23
-- @tparam[opt=0] measurement stretch A measurement describing how much the length is allowed to grow.
24
-- @tparam[opt=0] measurement shrink A measurement describing how much the length is allowed to grow.
25
-- @treturn length
26
-- @usage
27
-- SILE.types.length("6em", "4pt", "2pt")
28
-- SILE.types.length("6em plus 4pt minus 2pt")
29
-- SILE.types.length(30, 4, 2)
30
function length:_init (spec, stretch, shrink)
119✔
31
   if stretch or shrink then
202,943✔
32
      self.length = SILE.types.measurement(spec or 0)
79,382✔
33
      self.stretch = SILE.types.measurement(stretch or 0)
79,382✔
34
      self.shrink = SILE.types.measurement(shrink or 0)
79,382✔
35
   elseif type(spec) == "number" then
163,252✔
36
      self.length = SILE.types.measurement(spec)
128,352✔
37
   elseif SU.type(spec) == "measurement" then
198,152✔
38
      self.length = spec
2,470✔
39
   elseif SU.type(spec) == "glue" then
193,212✔
UNCOV
40
      self.length = SILE.types.measurement(spec.width.length or 0)
×
41
      self.stretch = SILE.types.measurement(spec.width.stretch or 0)
×
42
      self.shrink = SILE.types.measurement(spec.width.shrink or 0)
×
43
   elseif type(spec) == "table" then
96,606✔
44
      self.length = SILE.types.measurement(spec.length or 0)
61,532✔
45
      self.stretch = SILE.types.measurement(spec.stretch or 0)
61,532✔
46
      self.shrink = SILE.types.measurement(spec.shrink or 0)
61,532✔
47
   elseif type(spec) == "string" then
65,840✔
48
      local amount = tonumber(spec)
1,512✔
49
      if type(amount) == "number" then
1,512✔
50
         self:_init(amount)
6✔
51
      else
52
         local parsed = SILE.parserBits.length:match(spec)
1,509✔
53
         if not parsed then
1,509✔
UNCOV
54
            SU.error("Could not parse length '" .. spec .. "'")
×
55
         end
56
         self:_init(parsed)
1,509✔
57
      end
58
   end
59
   if not self.length then
202,943✔
60
      self.length = SILE.types.measurement()
128,656✔
61
   end
62
   if not self.stretch then
202,943✔
63
      self.stretch = SILE.types.measurement()
261,948✔
64
   end
65
   if not self.shrink then
202,943✔
66
      self.shrink = SILE.types.measurement()
261,948✔
67
   end
68
end
69

70
function length:absolute ()
119✔
71
   return SILE.types.length(self.length:tonumber(), self.stretch:tonumber(), self.shrink:tonumber())
70,052✔
72
end
73

74
function length:negate ()
119✔
UNCOV
75
   return self:__unm()
×
76
end
77

78
function length:tostring ()
119✔
UNCOV
79
   return self:__tostring()
×
80
end
81

82
function length:tonumber ()
119✔
83
   return self.length:tonumber()
138,516✔
84
end
85

86
function length:__tostring ()
119✔
87
   local str = tostring(self.length)
7✔
88
   if self.stretch.amount ~= 0 then
7✔
89
      str = str .. " plus " .. tostring(self.stretch)
2✔
90
   end
91
   if self.shrink.amount ~= 0 then
7✔
UNCOV
92
      str = str .. " minus " .. tostring(self.shrink)
×
93
   end
94
   return str
7✔
95
end
96

97
function length:__add (other)
119✔
98
   if type(self) == "number" then
18,679✔
99
      self, other = other, self
7,784✔
100
   end
101
   other = SU.cast("length", other)
37,358✔
102
   return SILE.types.length(self.length + other.length, self.stretch + other.stretch, self.shrink + other.shrink)
74,716✔
103
end
104

105
-- See usage comments on SILE.types.measurement:___add()
106
function length:___add (other)
119✔
107
   if SU.type(other) ~= "length" then
116,814✔
108
      self.length:___add(other)
6,212✔
109
   else
110
      self.length:___add(other.length)
55,301✔
111
      self.stretch:___add(other.stretch)
55,301✔
112
      self.shrink:___add(other.shrink)
55,301✔
113
   end
114
   return nil
58,407✔
115
end
116

117
function length:__sub (other)
119✔
118
   local result = SILE.types.length(self)
18,610✔
119
   other = SU.cast("length", other)
37,220✔
120
   result.length = result.length - other.length
37,220✔
121
   result.stretch = result.stretch - other.stretch
37,220✔
122
   result.shrink = result.shrink - other.shrink
37,220✔
123
   return result
18,610✔
124
end
125

126
-- See usage comments on SILE.types.measurement:___add()
127
function length:___sub (other)
119✔
128
   self.length:___sub(other.length)
3,462✔
129
   self.stretch:___sub(other.stretch)
3,462✔
130
   self.shrink:___sub(other.shrink)
3,462✔
131
   return nil
3,462✔
132
end
133

134
function length:__mul (other)
119✔
135
   if type(self) == "number" then
1,393✔
136
      self, other = other, self
6✔
137
   end
138
   _error_if_not_number(other)
1,393✔
139
   local result = SILE.types.length(self)
1,393✔
140
   result.length = result.length * other
2,786✔
141
   result.stretch = result.stretch * other
2,786✔
142
   result.shrink = result.shrink * other
2,786✔
143
   return result
1,393✔
144
end
145

146
function length:__div (other)
119✔
147
   local result = SILE.types.length(self)
175✔
148
   _error_if_not_number(other)
175✔
149
   result.length = result.length / other
350✔
150
   result.stretch = result.stretch / other
350✔
151
   result.shrink = result.shrink / other
350✔
152
   return result
175✔
153
end
154

155
function length:__unm ()
119✔
156
   local result = SILE.types.length(self)
30✔
157
   result.length = result.length:__unm()
60✔
158
   return result
30✔
159
end
160

161
function length:__lt (other)
119✔
162
   local a = SU.cast("number", self)
42,366✔
163
   local b = SU.cast("number", other)
42,366✔
164
   return a - b < 0
42,366✔
165
end
166

167
function length:__le (other)
119✔
168
   local a = SU.cast("number", self)
24✔
169
   local b = SU.cast("number", other)
24✔
170
   return a - b <= 0
24✔
171
end
172

173
function length:__eq (other)
119✔
174
   local a = SU.cast("length", self)
6✔
175
   local b = SU.cast("length", other)
6✔
176
   return a.length == b.length and a.stretch == b.stretch and a.shrink == b.shrink
24✔
177
end
178

179
return length
119✔
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc