Mercurial > projects > libpws
comparison compat/getline.c @ 2:97097b4b6bfb
Add pwsdump utility
The pwsdum utility can dump PasswordSafe database files to a plaintext format
and convert this format back into a PasswordSafe database.
author | Guido Berhoerster <guido+libpws@berhoerster.name> |
---|---|
date | Wed, 01 Apr 2015 14:57:57 +0200 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
1:e1309515d111 | 2:97097b4b6bfb |
---|---|
1 /* | |
2 * Copyright (C) 2015 Guido Berhoerster <guido+libpws@berhoerster.name> | |
3 * | |
4 * Permission is hereby granted, free of charge, to any person obtaining | |
5 * a copy of this software and associated documentation files (the | |
6 * "Software"), to deal in the Software without restriction, including | |
7 * without limitation the rights to use, copy, modify, merge, publish, | |
8 * distribute, sublicense, and/or sell copies of the Software, and to | |
9 * permit persons to whom the Software is furnished to do so, subject to | |
10 * the following conditions: | |
11 * | |
12 * The above copyright notice and this permission notice shall be included | |
13 * in all copies or substantial portions of the Software. | |
14 * | |
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
16 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
17 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | |
18 * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY | |
19 * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, | |
20 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | |
21 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | |
22 */ | |
23 | |
24 #include <stdio.h> | |
25 #include <stdlib.h> | |
26 #include <limits.h> | |
27 #include <sys/types.h> | |
28 #include <errno.h> | |
29 | |
30 #include "pws-compat.h" | |
31 | |
32 #define MIN(x, y) (((x) < (y)) ? (x) : (y)) | |
33 | |
34 ssize_t | |
35 getdelim(char **linep, size_t *sizep, int delim, FILE *fp) | |
36 { | |
37 ssize_t len; | |
38 char *line = *linep; | |
39 size_t size = *sizep; | |
40 size_t pos = 0; | |
41 char *line_new; | |
42 int c; | |
43 | |
44 if (*linep == NULL) { | |
45 size = 0; | |
46 } | |
47 | |
48 flockfile(fp); | |
49 | |
50 for (;;) { | |
51 if (size - pos < 2) { | |
52 size = MIN((size_t)SSIZE_MAX + 1, | |
53 (size < BUFSIZ) ? BUFSIZ : size * 1.5); | |
54 if (size - pos < 2) { | |
55 len = -1; | |
56 errno = EOVERFLOW; | |
57 break; | |
58 } | |
59 line_new = realloc(line, size); | |
60 if (line_new == NULL) { | |
61 len = -1; | |
62 break; | |
63 } | |
64 *linep = line = line_new; | |
65 *sizep = size; | |
66 } | |
67 c = fgetc(fp); | |
68 if (c == EOF) { | |
69 len = -1; | |
70 break; | |
71 } | |
72 line[pos] = c; | |
73 pos++; | |
74 len = pos; | |
75 if (c == delim) { | |
76 break; | |
77 } | |
78 } | |
79 | |
80 if (*linep != NULL) { | |
81 (*linep)[pos] = '\0'; | |
82 } | |
83 | |
84 funlockfile(fp); | |
85 | |
86 return (len); | |
87 } | |
88 | |
89 ssize_t | |
90 getline(char **linep, size_t *sizep, FILE *fp) | |
91 { | |
92 return (getdelim(linep, sizep, '\n', fp)); | |
93 } |