This repository was archived by the owner on Aug 31, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 227
Expand file tree
/
Copy pathbyte.lcb
More file actions
508 lines (370 loc) · 18.1 KB
/
byte.lcb
File metadata and controls
508 lines (370 loc) · 18.1 KB
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
/* Copyright (C) 2003-2015 LiveCode Ltd.
This file is part of LiveCode.
LiveCode is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License v3 as published by the Free
Software Foundation.
LiveCode is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
for more details.
You should have received a copy of the GNU General Public License
along with LiveCode. If not see <http://www.gnu.org/licenses/>. */
/**
This library consists of the operations on bytes included in the standard library of LiveCode Builder.
*/
module com.livecode.byte
use com.livecode.foreign
public foreign handler MCByteEvalNumberOfBytesIn(in Target as Data, out Count as LCUIndex) returns nothing binds to "<builtin>"
public foreign handler MCByteEvalOffsetOfBytes(in IsLast as CBool, in Needle as Data, in Target as Data, out Offset as LCUIndex) returns nothing binds to "<builtin>"
public foreign handler MCByteEvalOffsetOfBytesBefore(in IsLast as CBool, in Needle as Data, in Before as LCIndex, in Target as Data, out Offset as LCUIndex) returns nothing binds to "<builtin>"
public foreign handler MCByteEvalOffsetOfBytesAfter(in IsLast as CBool, in Needle as Data, in After as LCIndex, in Target as Data, out Offset as LCUIndex) returns nothing binds to "<builtin>"
// public foreign handler MCByteEvalIsAmongTheBytesOf(in Needle as Data, in Target as Data, out Value as CBool) returns nothing binds to "<builtin>"
public foreign handler MCByteEvalContainsBytes(in Target as Data, in Needle as Data, out Value as CBool) returns nothing binds to "<builtin>"
public foreign handler MCByteEvalBeginsWithBytes(in Target as Data, in Needle as Data, out Value as CBool) returns nothing binds to "<builtin>"
public foreign handler MCByteEvalEndsWithBytes(in Target as Data, in Needle as Data, out Value as CBool) returns nothing binds to "<builtin>"
/* No implementation
public foreign handler MCByteEvalIsInBytes(in Needle as Data, in Target as Data, out Value as CBool) returns nothing binds to "<builtin>"
*/
public foreign handler MCByteFetchByteOf(in Index as LCIndex, in Target as Data, out Value as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteStoreByteOf(in Value as Data, in Index as LCIndex, inout Target as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteFetchByteRangeOf(in Start as LCIndex, in Finish as LCIndex, in Target as Data, out Value as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteStoreByteRangeOf(in Value as Data, in Start as LCIndex, in Finish as LCIndex, inout Target as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteRepeatForEachByte(inout Iterator as optional Pointer, out Iterand as Data, in Container as Data) returns CBool binds to "<builtin>"
public foreign handler MCByteFetchFirstByteOf(in Target as Data, out Value as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteStoreFirstByteOf(in Value as Data, inout Target as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteFetchLastByteOf(in Target as Data, out Value as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteStoreLastByteOf(in Value as Data, inout Target as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteExecDeleteByteOf(in Index as LCIndex, inout Target as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteExecDeleteByteRangeOf(in Start as LCIndex, in Finish as LCIndex, inout Target as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteExecDeleteLastByteOf(inout Target as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteExecDeleteFirstByteOf(inout Target as Data) returns nothing binds to "<builtin>"
public foreign handler MCDataExecRandomBytes(in Count as LCUIndex, out Value as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteEvalByteWithCode(in Value as LCUInt, out Result as Data) returns nothing binds to "<builtin>"
public foreign handler MCByteEvalCodeOfByte(in Target as Data, out Result as LCUInt) returns nothing binds to "<builtin>"
--
/**
Summary: Counts the number of bytes in <Target>.
Target: An expression which evaluates to binary data.
Returns: The number of bytes in <Target>
Description:
Tags: Binary
*/
syntax CountBytesOf is prefix operator with property precedence
"the" "number" "of" "bytes" "in" <Target: Expression>
begin
MCByteEvalNumberOfBytesIn(Target, output)
end syntax
--
/**
Summary: Finds the first or last occurrence of <Needle> within <Target>
Needle: An expression which evaluates to binary data.
Target: An expression which evaluates to binary data.
Returns: Returns the offset of <Needle> in <Target>.
Description:
The first (respectively last) offset of <Needle> in <Target> is number of bytes between the first byte of <Target> and the first (respectively last) occurrence of <Needle>. If neither first or last is specified, then the first offset is found. If <Needle> does not occur in <Target>, then the output is 0.
Tags: Binary
*/
syntax ByteOffset is prefix operator with function chunk precedence
"the" ( "first" <IsLast=false> | "last" <IsLast=true> | <IsLast=false> ) "offset" "of" <Needle: Expression> "in" <Target: Expression>
begin
MCByteEvalOffsetOfBytes(IsLast, Needle, Target, output)
end syntax
syntax ByteIndex is prefix operator with function chunk precedence
"the" ( "first" <IsLast=false> | "last" <IsLast=true> | <IsLast=false> ) "index" "of" <Needle: Expression> "in" <Target: Expression>
begin
MCByteEvalOffsetOfBytes(IsLast, Needle, Target, output)
end syntax
/**
Summary: Finds the first or last occurrence of <Needle> after a specified index in <Target>
Needle: An expression which evaluates to binary data.
Target: An expression which evaluates to binary data.
After: An expression which evaluates to a valid integer index of Target.
Returns: Returns the offset of <Needle> after index <After> in <Target>.
Description:
The first (respectively last) offset of <Needle> in <Target> is number of bytes between byte <After> of <Target> and the first (respectively last) occurrence of <Needle> after <After>. If neither first or last is specified, then the first offset is found. If <Needle> does not occur after <After> in <Target>, then the output is 0.
Tags: Binary
*/
syntax ByteOffsetAfter is prefix operator with function chunk precedence
"the" ( "first" <IsLast=false> | "last" <IsLast=true> | <IsLast=false> ) "offset" "of" <Needle: Expression> "after" <After: Expression> "in" <Target: Expression>
begin
MCByteEvalOffsetOfBytesAfter(IsLast, Needle, After, Target, output)
end syntax
syntax ByteIndexAfter is prefix operator with function chunk precedence
"the" ( "first" <IsLast=false> | "last" <IsLast=true> | <IsLast=false> ) "index" "of" <Needle: Expression> "after" <After: Expression> "in" <Target: Expression>
begin
MCByteEvalOffsetOfBytesAfter(IsLast, Needle, After, Target, output)
end syntax
/**
Summary: Finds the first or last occurrence of <Needle> before a specified index in <Target>.
Needle: An expression which evaluates to binary data.
Target: An expression which evaluates to binary data.
Before: An expression which evaluates to a valid integer index of Target.
Returns: Returns the offset of <Needle> before index <Before> in <Target>.
Description:
The first (respectively last) offset of <Needle> in <Target> is number of bytes between the first byte of <Target> and the first (respectively last) occurrence of <Needle> before <Before>. If neither first or last is specified, then the last offset is found. If <Needle> does not occur before <Before> in <Target>, then the output is 0.
Tags: Binary
*/
syntax ByteOffsetBefore is prefix operator with function chunk precedence
"the" ( "first" <IsFirst=true> | "last" <IsFirst=false> | <IsFirst=false> ) "offset" "of" <Needle: Expression> "before" <Before: Expression> "in" <Target: Expression>
begin
MCByteEvalOffsetOfBytesBefore(IsFirst, Needle, Before, Target, output)
end syntax
syntax ByteIndexBefore is prefix operator with function chunk precedence
"the" ( "first" <IsFirst=true> | "last" <IsFirst=false> | <IsFirst=false> ) "index" "of" <Needle: Expression> "before" <Before: Expression> "in" <Target: Expression>
begin
MCByteEvalOffsetOfBytesBefore(IsFirst, Needle, Before, Target, output)
end syntax
/**
Summary: Determines whether <Needle> is in <Target>.
Needle: An expression which evaluates to a single byte of binary data.
Target: An expression which evaluates to binary data.
Returns: True if <Needle> is among the bytes of <Target>, and false otherwise.
Description:
>*Note:* It is an error if <Needle> evaluates to data consisting of more than one byte.
Tags: Binary
*/
/* No implementation
syntax ByteIsInData is neutral binary operator with comparison precedence
<Needle: Expression> "is" "in" <Target: Expression>
begin
MCByteEvalIsInBytes(Needle, Target, output)
end syntax
*/
--
/**
Summary: Determines whether <Needle> contains <Target>.
Needle: An expression which evaluates to binary data.
Target: An expression which evaluates to binary data.
Returns: True if the bytes of <Needle> occur as a subsequence of the bytes of <Target>, and false otherwise.
Description:
>*Note:* Since the empty data is a subsequence of every sequence of bytes, every sequence of bytes contains the empty data.
Tags: Binary
*/
syntax ContainsBytes is neutral binary operator with comparison precedence
<Target: Expression> "contains" <Needle: Expression>
begin
MCByteEvalContainsBytes(Target, Needle, output)
end syntax
/**
Summary: Determines whether <Target> begins with <Needle>.
Needle: An expression which evaluates to binary data.
Target: An expression which evaluates to binary data.
Returns: True if the bytes of <Needle> occur as an initial subsequence of the bytes of <Target>, and false otherwise.
Description:
>*Note:* Since the empty data is an initial subsequence of every sequence of bytes, every sequence of bytes begins with the empty data.
Tags: Binary
*/
syntax BeginsWithBytes is neutral binary operator with comparison precedence
<Target: Expression> "begins" "with" <Needle: Expression>
begin
MCByteEvalBeginsWithBytes(Target, Needle, output)
end syntax
/**
Summary: Determines whether <Target> ends with <Needle>.
Needle: An expression which evaluates to binary data.
Target: An expression which evaluates to binary data.
Returns: True if the bytes of <Needle> occur as a final subsequence of the bytes of <Target>, and false otherwise.
Description:
>*Note:* Since the empty data is a final subsequence of every sequence of bytes, every sequence of bytes ends with the empty data.
Tags: Binary
*/
syntax EndsWithBytes is neutral binary operator with comparison precedence
<Target: Expression> "ends" "with" <Needle: Expression>
begin
MCByteEvalEndsWithBytes(Target, Needle, output)
end syntax
--
/**
Summary: Designates the byte of data at index <Index> in <Target>.
Index: An expression which evaluates to a valid integer index of <Target>.
Target: An expression which evaluates to binary data.
Description:
Either locates the byte at the given index for use as the target container of another operation, or evaluates the byte at the given index as the source of another operation.
>*Note:* It is an error if <Index> is out of range.
Tags: Binary
*/
syntax SingletonByteOf is prefix operator with subscript chunk precedence
"byte" <Index: Expression> "of" <Target: Expression>
begin
MCByteFetchByteOf(Index, Target, output)
MCByteStoreByteOf(input, Index, Target)
end syntax
/**
Summary: Designates the bytes of data between indices <Start> and <Finish> in <Target>.
Start: An expression which evaluates to a valid integer index of <Target>.
Finish: An expression which evaluates to a valid integer index of <Target>.
Target: An expression which evaluates to binary data.
Description:
Either locates the bytes between the given indices for use as the target container of another operation, or evaluates the bytes at the given indices as the source of another operation.
>*Note:* It is an error if either <Start> or <Finish> are out of range.
Tags: Binary
*/
syntax RangeByteOf is prefix operator with subscript chunk precedence
"byte" <Start: Expression> "to" <Finish: Expression> "of" <Target: Expression>
begin
MCByteFetchByteRangeOf(Start, Finish, Target, output)
MCByteStoreByteRangeOf(input, Start, Finish, Target)
end syntax
/**
Summary: Designates the first byte of data in <Target>.
Target: An expression which evaluates to binary data.
Description:
Either locates the first byte for use as the target container of another operation, or evaluates the first byte as the source of another operation.
>*Note:* It is an error if <Target> is empty.
Tags: Binary
*/
syntax FirstByteOf is prefix operator with subscript chunk precedence
"the" "first" "byte" "of" <Target: Expression>
begin
MCByteFetchFirstByteOf(Target, output)
MCByteStoreFirstByteOf(input, Target)
end syntax
/**
Summary: Designates the first byte of data in <Target>.
Target: An expression which evaluates to binary data.
Description:
Either locates the first byte for use as the target container of another operation, or evaluates the first byte as the source of another operation.
>*Note:* It is an error if <Target> is empty.
Tags: Binary
*/
syntax LastByteOf is prefix operator with subscript chunk precedence
"the" "last" "byte" "of" <Target: Expression>
begin
MCByteFetchLastByteOf(Target, output)
MCByteStoreLastByteOf(input, Target)
end syntax
--
/**
Summary: Deletes the byte of data at index <Index> in <Target>.
Index: An expression which evaluates to a valid integer index of <Target>.
Target: A container of binary data.
Description:
Replaces the byte at the given index with the empty data.
>*Note:* It is an error if <Index> is out of range.
Tags: Binary
*/
syntax DeleteSingletonByteOf is statement
"delete" "byte" <Index: Expression> "of" <Target: Expression>
begin
MCByteExecDeleteByteOf(Index, Target)
end syntax
/**
Summary: Deletes the bytes of data between indices <Start> and <Finish> in <Target>.
Start: An expression which evaluates to a valid integer index of <Target>.
Finish: An expression which evaluates to a valid integer index of <Target>.
Target: A container of binary data.
Description:
Replaces the bytes between the given indices with the empty data.
>*Note:* It is an error if either <Start> or <Finish> are out of range.
Tags: Binary
*/
syntax DeleteRangeByteOf is statement
"delete" "byte" <Start: Expression> "to" <Finish: Expression> "of" <Target: Expression>
begin
MCByteExecDeleteByteRangeOf(Start, Finish, Target)
end syntax
/**
Summary: Deletes the first byte in <Target>.
Target: A binary data container.
Description:
Replaces the first byte in <Target> with the empty data.
>*Note:* It is an error if <Target> is the empty data.
Tags: Binary
*/
syntax DeleteFirstByteOf is statement
"delete" "the" "first" "byte" "of" <Target: Expression>
begin
MCByteExecDeleteFirstByteOf(Target)
end syntax
/**
Summary: Deletes the last byte in <Target>.
Target: A binary data container.
Description:
Replaces the last byte in <Target> with the empty data.
>*Note:* It is an error if <Target> is the empty data.
Tags: Binary
*/
syntax DeleteLastByteOf is statement
"delete" "the" "last" "byte" "of" <Target: Expression>
begin
MCByteExecDeleteLastByteOf(Target)
end syntax
--
/**
Summary: Repeat over the bytes of some data
Iterand: A container of binary data.
Description:
Use repeat for each to perform an operation on each byte of some data. On each iteration, the <Iterand> will contain the next char of the string being iterated over.
Tags: Binary, Control structures
*/
syntax RepeatForEachByte is iterator
"byte" <Iterand: Expression>
begin
MCByteRepeatForEachByte(iterator, Iterand, container)
end syntax
--
/**
Summary: Generate random data
Count: Expression evaluating to the number of bytes to generate
Description:
Generates the requested number of bytes of cryptographic-quality
random data.
Tags: Binary, Random
*/
syntax RandomBytes is postfix operator with constructor precedence
<Count : Expression> "random" "bytes"
begin
MCDataExecRandomBytes(Count, output)
end syntax
--
public foreign handler MCDataExecReverseBytesOf(inout Target as Data) \
returns nothing binds to "<builtin>"
/**
Summary: Reverse binary data
Target: A binary data string
Example:
variable tForward
put 5 random bytes into tForward
variable tReversed
put tForward into tReversed
reverse tReversed
expect that the first byte of tForward is the last byte of tReversed
expect that the last byte of tForward is the first byte of tReversed
Description:
Reverses the order of bytes in the <Target>.
Tags: Binary
*/
syntax ReverseBytesOf is statement
"reverse" <Target: Expression>
begin
MCDataExecReverseBytesOf(Target)
end syntax
----------------------------------------------------------------
-- Conversion between bytes and numbers
----------------------------------------------------------------
/**
Summary: Create a 1-byte data value from a number
Value: The value for the new data value
Description:
Returns a byte of binary data, created using the given value. The
<Value> must be between 0 and 255 (inclusive).
Tags: Binary
*/
syntax ByteWithCode is prefix operator with function chunk precedence
"the" "byte" "with" "code" <Value: Expression>
begin
MCByteEvalByteWithCode(Value, output)
end syntax
/**
Summary: Get the numeric value of a single byte.
Target: A 1-byte binary data value.
Description:
Returns the numeric representation of a single byte of binary data.
Tags: Binary
*/
syntax CodeOfByte is prefix operator with function chunk precedence
"the" "code" "of" <Target: Expression>
begin
MCByteEvalCodeOfByte(Target, output)
end syntax
end module