2023-07-12 11:45:30 -07:00
|
|
|
# input
|
2022-03-30 17:02:36 -07:00
|
|
|
|
|
|
|
I/O module to assist with consuming data from files
|
|
|
|
|
|
|
|
## Functions
|
|
|
|
|
2023-05-03 14:26:58 -07:00
|
|
|
### get_binary
|
|
|
|
|
2023-05-03 14:46:38 -07:00
|
|
|
Reads a file at `path` and returns the contents as a char* buffer. The `fsz` parameter stores the length of the
|
|
|
|
returned array. The buffer is allocated inside the function, so the user is responsible for freeing it when finished.
|
2023-05-03 14:26:58 -07:00
|
|
|
|
|
|
|
```c
|
2023-05-03 14:46:38 -07:00
|
|
|
char *get_binary(const char *path, size_t *fsz);
|
2023-05-03 14:26:58 -07:00
|
|
|
|
|
|
|
/* Usage */
|
2023-05-03 14:46:38 -07:00
|
|
|
size_t fsz = 0;
|
|
|
|
char *buf = get_binary("/home/evan/binfile", &fsz);
|
2023-05-03 14:26:58 -07:00
|
|
|
free(buf);
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2022-03-30 17:02:36 -07:00
|
|
|
### get_input
|
|
|
|
|
|
|
|
Reads a file at `path` and returns the contents as a single string. The string is allocated inside the function and
|
|
|
|
the user is responsible for freeing it when finished.
|
|
|
|
|
|
|
|
```c
|
2023-12-15 13:08:22 -08:00
|
|
|
unsigned char *get_input(const char *path);
|
2022-03-30 17:02:36 -07:00
|
|
|
|
|
|
|
/* Usage */
|
|
|
|
char *str = get_input("/home/evan/textfile");
|
|
|
|
free(str);
|
|
|
|
```
|
|
|
|
|
|
|
|
### get_lines
|
|
|
|
|
|
|
|
Reads a file at `path` and returns the contents as an array of strings. The newline character `\n` is used as the
|
|
|
|
delimiter to determine where the file is split. The user is responsible for cleaning up the memory using `del_lines()`.
|
|
|
|
`lsz` is set to the number of lines in the array.
|
|
|
|
|
|
|
|
```c
|
|
|
|
char **get_lines(const char *path, size_t *lsz);
|
|
|
|
|
|
|
|
/* Usage */
|
|
|
|
size_t sz = 0;
|
|
|
|
char **lines = get_lines("/home/evan/textfile", &sz);
|
|
|
|
for (size_t i = 0; i < sz; i++) {
|
|
|
|
printf("%s\n", lines[i]);
|
|
|
|
}
|
|
|
|
del_lines(lines);
|
|
|
|
```
|
|
|
|
|
|
|
|
### del_lines
|
|
|
|
|
|
|
|
Frees all memory used by `get_lines()`
|
|
|
|
|
|
|
|
```c
|
|
|
|
void del_lines(char **lines);
|
|
|
|
```
|
|
|
|
|
|
|
|
### get_ints
|
|
|
|
Reads a file at `path` and returns the contents as an array of integers. The file is assumed to be a newline seperated
|
|
|
|
list of integers and nothing else.
|
|
|
|
|
|
|
|
The newline character `\n` is used as the delimiter to determine where the file is split. The user is responsible for
|
|
|
|
cleaning up the memory using `free()`. `lsz` is set to the number of lines in the array.
|
|
|
|
|
|
|
|
```c
|
|
|
|
int *get_ints(const char *path, size_t *lsz);
|
|
|
|
|
|
|
|
/* Usage */
|
|
|
|
int *nums = get_ints("/home/evan/intfile");
|
|
|
|
for (size_t i = 0; i < sz; i++) {
|
|
|
|
printf("%d\n", nums[i]);
|
|
|
|
}
|
|
|
|
free(nums);
|
|
|
|
```
|
|
|
|
|
|
|
|
### split
|
|
|
|
|
|
|
|
Takes a string `s` and splits it into an array of strings based on the delimiter. `s` is left unchanged. The user is
|
|
|
|
responsible for cleaning up the memory of the split using `del_split()`. `sp_sz` is set to the size of the split.
|
|
|
|
|
|
|
|
```c
|
|
|
|
char **split(char *s, size_t *lsz, const char *delim)
|
|
|
|
|
|
|
|
/* Usage */
|
|
|
|
size_t sp_sz = 0;
|
|
|
|
char **sp = split("Split on whitespace", &sp_sz, " ");
|
|
|
|
printf("%s\n", sp[0]); // Prints "Split"
|
|
|
|
```
|
|
|
|
|
|
|
|
### del_split
|
|
|
|
|
2024-07-09 21:03:23 +00:00
|
|
|
Frees all memory used by `split()`. Just like `split`, it does not touch the original string.
|
|
|
|
|
2022-03-30 17:02:36 -07:00
|
|
|
```c
|
|
|
|
void del_split(char **sp);
|
|
|
|
|
|
|
|
/* Usage */
|
|
|
|
size_t sp_sz = 0;
|
|
|
|
char **sp = split("Delete Me!", &sp_sz, " ");
|
2022-04-11 14:33:57 -07:00
|
|
|
void del_split(sp);
|
2022-03-30 17:02:36 -07:00
|
|
|
```
|
2024-07-09 21:03:23 +00:00
|
|
|
|
|
|
|
### capture_system
|
|
|
|
|
|
|
|
Runs a command on the system shell and returns stdout as a string. `buffsize` is the size of
|
|
|
|
the returned buffer that holds `stdout`. Passing `0` to `buffsize` will use the default buffer size of `1024`.
|
|
|
|
|
|
|
|
User is responsible for freeing the returned string.
|
|
|
|
|
|
|
|
```c
|
|
|
|
const char *capture_system(const char *cmd, int buffsize);
|
|
|
|
|
|
|
|
/* Usage */
|
|
|
|
const char *cap = capture_system("ls $HOME", 0);
|
|
|
|
printf("%s\n", cap);
|
|
|
|
free(cap);
|
|
|
|
```
|