1
0
mirror of https://github.com/KarolS/millfork.git synced 2025-01-26 20:33:02 +00:00
millfork/docs/stdlib/string.md

54 lines
2.1 KiB
Markdown
Raw Normal View History

2019-07-15 14:21:50 +02:00
[< back to index](../doc_index.md)
2018-12-19 19:01:53 +01:00
## string
The `string` module automatically imports the `err` module.
2019-09-04 01:22:40 +02:00
All the functions are designed to work for the strings in the default encoding.
If passed a string in an encoding that has a different null terminator,
then the results are undefined and the program will most likely crash or freeze.
2018-12-19 19:01:53 +01:00
#### `byte strzlen(pointer str)`
Calculates the length of a null-terminated string.
If the string is longer than 255 bytes, then the behaviour is undefined (might even crash).
#### `sbyte strzcmp(pointer str1, pointer str2)`
2019-06-05 11:46:06 +02:00
Compares two null-terminated strings. Returns 0 if equal, non-0 if not equal.
2018-12-19 19:01:53 +01:00
If any of the strings is longer than 255 bytes, then the behaviour is undefined (might even crash).
#### `void strzcopy(pointer dest, pointer src)`
2019-11-04 02:29:16 +01:00
Copies the source null-terminated string into the destination buffer, including the string terminator.
If the source string is longer than 255 bytes, then the behaviour is undefined (might even crash).
#### `void strzpaste(pointer dest, pointer src)`
Copies the source null-terminated string into the destination buffer, excluding the string terminator.
2018-12-19 19:01:53 +01:00
If the source string is longer than 255 bytes, then the behaviour is undefined (might even crash).
#### `word strz2word(pointer str)`
Converts a null-terminated string to a number.
Sets `errno`.
2019-01-05 01:19:14 +01:00
#### `void strzappend(pointer buffer, pointer str)`
#### `void strzappendchar(pointer buffer, byte char)`
2019-06-05 11:46:06 +02:00
Modifies the given null-terminated buffer by appending a null-terminated string or a single character respectively.
2019-10-31 17:29:05 +01:00
## scrstring
The `scrstring` module automatically imports the `string` and `err` modules.
It contains functions for handling strings in the screen encoding with the same semantics as the functions from the string module.
#### `byte scrstrzlen(pointer str)`
#### `sbyte scrstrzcmp(pointer str1, pointer str2)`
#### `void scrstrzcopy(pointer dest, pointer src)`
2019-11-04 02:29:16 +01:00
#### `void scrstrzpaste(pointer dest, pointer src)`
2019-10-31 17:29:05 +01:00
#### `word scrstrz2word(pointer str)`
#### `void scrstrzappend(pointer buffer, pointer str)`
#### `void scrstrzappendchar(pointer buffer, byte char)`