| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- /*
- __ __ _
- ___\ \/ /_ __ __ _| |_
- / _ \\ /| '_ \ / _` | __|
- | __// \| |_) | (_| | |_
- \___/_/\_\ .__/ \__,_|\__|
- |_| XML parser
- Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
- Copyright (c) 2000-2017 Expat development team
- Licensed under the MIT license:
- Permission is hereby granted, free of charge, to any person obtaining
- a copy of this software and associated documentation files (the
- "Software"), to deal in the Software without restriction, including
- without limitation the rights to use, copy, modify, merge, publish,
- distribute, sublicense, and/or sell copies of the Software, and to permit
- persons to whom the Software is furnished to do so, subject to the
- following conditions:
- The above copyright notice and this permission notice shall be included
- in all copies or substantial portions of the Software.
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
- NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
- DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
- OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
- USE OR OTHER DEALINGS IN THE SOFTWARE.
- */
- #include <sys/types.h>
- #include <sys/stat.h>
- #include <fcntl.h>
- #include <stdlib.h>
- #include <stdio.h>
- /* Functions close(2) and read(2) */
- #if !defined(_WIN32) && !defined(_WIN64)
- # include <unistd.h>
- #endif
- #ifndef S_ISREG
- #ifndef S_IFREG
- #define S_IFREG _S_IFREG
- #endif
- #ifndef S_IFMT
- #define S_IFMT _S_IFMT
- #endif
- #define S_ISREG(m) (((m) & S_IFMT) == S_IFREG)
- #endif /* not S_ISREG */
- #ifndef O_BINARY
- #ifdef _O_BINARY
- #define O_BINARY _O_BINARY
- #else
- #define O_BINARY 0
- #endif
- #endif
- #include "filemap.h"
- int
- filemap(const char *name,
- void (*processor)(const void *, size_t, const char *, void *arg),
- void *arg)
- {
- size_t nbytes;
- int fd;
- ssize_t n;
- struct stat sb;
- void *p;
- fd = open(name, O_RDONLY|O_BINARY);
- if (fd < 0) {
- perror(name);
- return 0;
- }
- if (fstat(fd, &sb) < 0) {
- perror(name);
- close(fd);
- return 0;
- }
- if (!S_ISREG(sb.st_mode)) {
- fprintf(stderr, "%s: not a regular file\n", name);
- close(fd);
- return 0;
- }
- if (sb.st_size > XML_MAX_CHUNK_LEN) {
- close(fd);
- return 2; /* Cannot be passed to XML_Parse in one go */
- }
- nbytes = sb.st_size;
- /* malloc will return NULL with nbytes == 0, handle files with size 0 */
- if (nbytes == 0) {
- static const char c = '\0';
- processor(&c, 0, name, arg);
- close(fd);
- return 1;
- }
- p = malloc(nbytes);
- if (!p) {
- fprintf(stderr, "%s: out of memory\n", name);
- close(fd);
- return 0;
- }
- n = read(fd, p, nbytes);
- if (n < 0) {
- perror(name);
- free(p);
- close(fd);
- return 0;
- }
- if (n != (ssize_t)nbytes) {
- fprintf(stderr, "%s: read unexpected number of bytes\n", name);
- free(p);
- close(fd);
- return 0;
- }
- processor(p, nbytes, name, arg);
- free(p);
- close(fd);
- return 1;
- }
|