123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- /*
- * isync - mbsync wrapper: IMAP4 to maildir mailbox synchronizer
- * Copyright (C) 2000-2002 Michael R. Elkins <me@mutt.org>
- * Copyright (C) 2002-2004 Oswald Buddenhagen <ossi@users.sf.net>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
- */
- #include "isync.h"
- #include <stdio.h>
- #include <stdlib.h>
- #include <unistd.h>
- #include <string.h>
- #include <pwd.h>
- #include <ctype.h>
- void
- sys_error( const char *msg, ... )
- {
- va_list va;
- char buf[1024];
- va_start( va, msg );
- if ((unsigned)vsnprintf( buf, sizeof(buf), msg, va ) >= sizeof(buf))
- oob();
- va_end( va );
- perror( buf );
- }
- char *
- next_arg( char **s )
- {
- char *ret;
- if (!s || !*s)
- return 0;
- while (isspace( (unsigned char) **s ))
- (*s)++;
- if (!**s) {
- *s = 0;
- return 0;
- }
- if (**s == '"') {
- ++*s;
- ret = *s;
- *s = strchr( *s, '"' );
- } else {
- ret = *s;
- while (**s && !isspace( (unsigned char) **s ))
- (*s)++;
- }
- if (*s) {
- if (**s)
- *(*s)++ = 0;
- if (!**s)
- *s = 0;
- }
- return ret;
- }
- #ifndef HAVE_VASPRINTF
- static int
- vasprintf( char **strp, const char *fmt, va_list ap )
- {
- int len;
- char tmp[1024];
- if ((len = vsnprintf( tmp, sizeof(tmp), fmt, ap )) < 0 || !(*strp = malloc( len + 1 )))
- return -1;
- if (len >= (int)sizeof(tmp))
- vsprintf( *strp, fmt, ap );
- else
- memcpy( *strp, tmp, len + 1 );
- return len;
- }
- #endif
- #ifndef HAVE_MEMRCHR
- void *
- memrchr( const void *s, int c, size_t n )
- {
- u_char *b = (u_char *)s, *e = b + n;
- while (--e >= b)
- if (*e == c)
- return (void *)e;
- return 0;
- }
- #endif
- #ifndef HAVE_STRNLEN
- int
- strnlen( const char *str, size_t maxlen )
- {
- size_t len;
- /* It's tempting to use memchr(), but it's allowed to read past the end of the actual string. */
- for (len = 0; len < maxlen && str[len]; len++) {}
- return len;
- }
- #endif
- int
- starts_with( const char *str, int strl, const char *cmp, int cmpl )
- {
- if (strl < 0)
- strl = strnlen( str, cmpl + 1 );
- return (strl >= cmpl) && !memcmp( str, cmp, cmpl );
- }
- int
- equals( const char *str, int strl, const char *cmp, int cmpl )
- {
- if (strl < 0)
- strl = strnlen( str, cmpl + 1 );
- return (strl == cmpl) && !memcmp( str, cmp, cmpl );
- }
- void
- oob( void )
- {
- fputs( "Fatal: buffer too small. Please report a bug.\n", stderr );
- abort();
- }
- int
- nfsnprintf( char *buf, int blen, const char *fmt, ... )
- {
- int ret;
- va_list va;
- va_start( va, fmt );
- if (blen <= 0 || (unsigned)(ret = vsnprintf( buf, blen, fmt, va )) >= (unsigned)blen)
- oob();
- va_end( va );
- return ret;
- }
- static void ATTR_NORETURN
- oom( void )
- {
- fputs( "Fatal: Out of memory\n", stderr );
- abort();
- }
- void *
- nfmalloc( size_t sz )
- {
- void *ret;
- if (!(ret = malloc( sz )))
- oom();
- return ret;
- }
- void *
- nfrealloc( void *mem, size_t sz )
- {
- char *ret;
- if (!(ret = realloc( mem, sz )) && sz)
- oom();
- return ret;
- }
- char *
- nfstrdup( const char *str )
- {
- char *ret;
- if (!(ret = strdup( str )))
- oom();
- return ret;
- }
- int
- nfvasprintf( char **str, const char *fmt, va_list va )
- {
- int ret = vasprintf( str, fmt, va );
- if (ret < 0)
- oom();
- return ret;
- }
- int
- nfasprintf( char **str, const char *fmt, ... )
- {
- int ret;
- va_list va;
- va_start( va, fmt );
- ret = nfvasprintf( str, fmt, va );
- va_end( va );
- return ret;
- }
|