Strict conformance to IEEE Std 1003.1-2001
This commit is contained in:
		@@ -16,9 +16,9 @@
 | 
				
			|||||||
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
					 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define _POSIX_C_SOURCE 200112L /* for setenv(3) */
 | 
					#define _POSIX_C_SOURCE 200112L
 | 
				
			||||||
#include <stdlib.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <stdlib.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include <unistd.h>
 | 
					#include <unistd.h>
 | 
				
			||||||
#include <sys/wait.h>
 | 
					#include <sys/wait.h>
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								image.c
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								image.c
									
									
									
									
									
								
							@@ -16,6 +16,8 @@
 | 
				
			|||||||
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
					 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define _POSIX_C_SOURCE 200112L
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include <unistd.h>
 | 
					#include <unistd.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										9
									
								
								main.c
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								main.c
									
									
									
									
									
								
							@@ -16,6 +16,8 @@
 | 
				
			|||||||
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
					 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define _POSIX_C_SOURCE 200112L
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <stdlib.h>
 | 
					#include <stdlib.h>
 | 
				
			||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
@@ -430,8 +432,9 @@ int fncmp(const void *a, const void *b) {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int main(int argc, char **argv) {
 | 
					int main(int argc, char **argv) {
 | 
				
			||||||
	int i, len, start;
 | 
						int i, start;
 | 
				
			||||||
	size_t n;
 | 
						size_t n;
 | 
				
			||||||
 | 
						ssize_t len;
 | 
				
			||||||
	char *filename;
 | 
						char *filename;
 | 
				
			||||||
	struct stat fstats;
 | 
						struct stat fstats;
 | 
				
			||||||
	r_dir_t dir;
 | 
						r_dir_t dir;
 | 
				
			||||||
@@ -460,11 +463,13 @@ int main(int argc, char **argv) {
 | 
				
			|||||||
	/* build file list: */
 | 
						/* build file list: */
 | 
				
			||||||
	if (options->from_stdin) {
 | 
						if (options->from_stdin) {
 | 
				
			||||||
		filename = NULL;
 | 
							filename = NULL;
 | 
				
			||||||
		while ((len = getline(&filename, &n, stdin)) > 0) {
 | 
							while ((len = get_line(&filename, &n, stdin)) > 0) {
 | 
				
			||||||
			if (filename[len-1] == '\n')
 | 
								if (filename[len-1] == '\n')
 | 
				
			||||||
				filename[len-1] = '\0';
 | 
									filename[len-1] = '\0';
 | 
				
			||||||
			check_add_file(filename);
 | 
								check_add_file(filename);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
							if (filename)
 | 
				
			||||||
 | 
								free(filename);
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		for (i = 0; i < options->filecnt; i++) {
 | 
							for (i = 0; i < options->filecnt; i++) {
 | 
				
			||||||
			filename = options->filenames[i];
 | 
								filename = options->filenames[i];
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,12 +16,12 @@
 | 
				
			|||||||
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
					 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define _POSIX_C_SOURCE 2 /* for getopt(3) */
 | 
					#define _POSIX_C_SOURCE 200112L
 | 
				
			||||||
#include <unistd.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <stdlib.h>
 | 
					#include <stdlib.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
 | 
					#include <unistd.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "options.h"
 | 
					#include "options.h"
 | 
				
			||||||
#include "util.h"
 | 
					#include "util.h"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										28
									
								
								thumbs.c
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								thumbs.c
									
									
									
									
									
								
							@@ -16,12 +16,14 @@
 | 
				
			|||||||
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
					 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define _POSIX_C_SOURCE 200112L
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <stdlib.h>
 | 
					#include <stdlib.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include <sys/time.h>
 | 
					 | 
				
			||||||
#include <sys/types.h>
 | 
					#include <sys/types.h>
 | 
				
			||||||
#include <sys/stat.h>
 | 
					#include <sys/stat.h>
 | 
				
			||||||
#include <unistd.h>
 | 
					#include <unistd.h>
 | 
				
			||||||
 | 
					#include <utime.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "thumbs.h"
 | 
					#include "thumbs.h"
 | 
				
			||||||
#include "util.h"
 | 
					#include "util.h"
 | 
				
			||||||
@@ -29,11 +31,6 @@
 | 
				
			|||||||
#define _THUMBS_CONFIG
 | 
					#define _THUMBS_CONFIG
 | 
				
			||||||
#include "config.h"
 | 
					#include "config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef __NetBSD__
 | 
					 | 
				
			||||||
#define st_mtim st_mtimespec
 | 
					 | 
				
			||||||
#define st_atim st_atimespec
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef EXIF_SUPPORT
 | 
					#ifdef EXIF_SUPPORT
 | 
				
			||||||
void exif_auto_orientate(const fileinfo_t*);
 | 
					void exif_auto_orientate(const fileinfo_t*);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
@@ -76,12 +73,8 @@ Imlib_Image* tns_cache_load(const char *filepath) {
 | 
				
			|||||||
		return NULL;
 | 
							return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((cfile = tns_cache_filepath(filepath))) {
 | 
						if ((cfile = tns_cache_filepath(filepath))) {
 | 
				
			||||||
		if (!stat(cfile, &cstats) &&
 | 
							if (!stat(cfile, &cstats) && cstats.st_mtime == fstats.st_mtime)
 | 
				
			||||||
		    cstats.st_mtim.tv_sec == fstats.st_mtim.tv_sec &&
 | 
					 | 
				
			||||||
		    cstats.st_mtim.tv_nsec / 1000 == fstats.st_mtim.tv_nsec / 1000)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
			im = imlib_load_image(cfile);
 | 
								im = imlib_load_image(cfile);
 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
		free(cfile);
 | 
							free(cfile);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -91,7 +84,7 @@ Imlib_Image* tns_cache_load(const char *filepath) {
 | 
				
			|||||||
void tns_cache_write(thumb_t *t, Bool force) {
 | 
					void tns_cache_write(thumb_t *t, Bool force) {
 | 
				
			||||||
	char *cfile, *dirend;
 | 
						char *cfile, *dirend;
 | 
				
			||||||
	struct stat cstats, fstats;
 | 
						struct stat cstats, fstats;
 | 
				
			||||||
	struct timeval times[2];
 | 
						struct utimbuf times;
 | 
				
			||||||
	Imlib_Load_Error err = 0;
 | 
						Imlib_Load_Error err = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!t || !t->im || !t->file || !t->file->name || !t->file->path)
 | 
						if (!t || !t->im || !t->file || !t->file->name || !t->file->path)
 | 
				
			||||||
@@ -101,10 +94,7 @@ void tns_cache_write(thumb_t *t, Bool force) {
 | 
				
			|||||||
		return;
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((cfile = tns_cache_filepath(t->file->path))) {
 | 
						if ((cfile = tns_cache_filepath(t->file->path))) {
 | 
				
			||||||
		if (force || stat(cfile, &cstats) ||
 | 
							if (force || stat(cfile, &cstats) || cstats.st_mtime != fstats.st_mtime) {
 | 
				
			||||||
		    cstats.st_mtim.tv_sec != fstats.st_mtim.tv_sec ||
 | 
					 | 
				
			||||||
		    cstats.st_mtim.tv_nsec / 1000 != fstats.st_mtim.tv_nsec / 1000)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
			if ((dirend = strrchr(cfile, '/'))) {
 | 
								if ((dirend = strrchr(cfile, '/'))) {
 | 
				
			||||||
				*dirend = '\0';
 | 
									*dirend = '\0';
 | 
				
			||||||
				err = r_mkdir(cfile);
 | 
									err = r_mkdir(cfile);
 | 
				
			||||||
@@ -120,9 +110,9 @@ void tns_cache_write(thumb_t *t, Bool force) {
 | 
				
			|||||||
			if (err) {
 | 
								if (err) {
 | 
				
			||||||
				warn("could not cache thumbnail: %s", t->file->name);
 | 
									warn("could not cache thumbnail: %s", t->file->name);
 | 
				
			||||||
			} else {
 | 
								} else {
 | 
				
			||||||
				TIMESPEC_TO_TIMEVAL(×[0], &fstats.st_atim);
 | 
									times.actime = fstats.st_atime;
 | 
				
			||||||
				TIMESPEC_TO_TIMEVAL(×[1], &fstats.st_mtim);
 | 
									times.modtime = fstats.st_mtime;
 | 
				
			||||||
				utimes(cfile, times);
 | 
									utime(cfile, ×);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		free(cfile);
 | 
							free(cfile);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										44
									
								
								util.c
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								util.c
									
									
									
									
									
								
							@@ -16,6 +16,8 @@
 | 
				
			|||||||
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
					 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define _POSIX_C_SOURCE 200112L
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <stdlib.h>
 | 
					#include <stdlib.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include <sys/types.h>
 | 
					#include <sys/types.h>
 | 
				
			||||||
@@ -27,6 +29,7 @@
 | 
				
			|||||||
#include "util.h"
 | 
					#include "util.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
enum {
 | 
					enum {
 | 
				
			||||||
 | 
						BUF_SIZE  = 1024,
 | 
				
			||||||
	DNAME_CNT = 512,
 | 
						DNAME_CNT = 512,
 | 
				
			||||||
	FNAME_LEN = 1024
 | 
						FNAME_LEN = 1024
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
@@ -87,6 +90,39 @@ void die(const char* fmt, ...) {
 | 
				
			|||||||
	exit(1);
 | 
						exit(1);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ssize_t get_line(char **buf, size_t *n, FILE *stream) {
 | 
				
			||||||
 | 
						size_t len;
 | 
				
			||||||
 | 
						char *s;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!stream || feof(stream) || ferror(stream))
 | 
				
			||||||
 | 
							return -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!*buf || !*n) {
 | 
				
			||||||
 | 
							*n = BUF_SIZE;
 | 
				
			||||||
 | 
							*buf = (char*) s_malloc(*n);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						s = *buf;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						while (1) {
 | 
				
			||||||
 | 
							if (!fgets(s, *n - (s - *buf), stream))
 | 
				
			||||||
 | 
								return -1;
 | 
				
			||||||
 | 
							len = strlen(s);
 | 
				
			||||||
 | 
							if (feof(stream))
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							if (len > 0 && s[len-1] == '\n')
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
							if (len + 1 == *n - (s - *buf)) {
 | 
				
			||||||
 | 
								*buf = (char*) s_realloc(*buf, 2 * *n);
 | 
				
			||||||
 | 
								s = *buf + *n - 1;
 | 
				
			||||||
 | 
								*n *= 2;
 | 
				
			||||||
 | 
							} else {
 | 
				
			||||||
 | 
								s += len;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return s - *buf + len;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void size_readable(float *size, const char **unit) {
 | 
					void size_readable(float *size, const char **unit) {
 | 
				
			||||||
	const char *units[] = { "", "K", "M", "G" };
 | 
						const char *units[] = { "", "K", "M", "G" };
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
@@ -98,13 +134,9 @@ void size_readable(float *size, const char **unit) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
char* absolute_path(const char *filename) {
 | 
					char* absolute_path(const char *filename) {
 | 
				
			||||||
	size_t len;
 | 
						size_t len;
 | 
				
			||||||
	char *path = NULL;
 | 
					 | 
				
			||||||
	const char *basename;
 | 
						const char *basename;
 | 
				
			||||||
	char *dirname = NULL;
 | 
						char *dir, *dirname = NULL, *path = NULL, *s;
 | 
				
			||||||
	char *cwd = NULL;
 | 
						char *cwd = NULL, *twd = NULL;
 | 
				
			||||||
	char *twd = NULL;
 | 
					 | 
				
			||||||
	char *dir;
 | 
					 | 
				
			||||||
	char *s;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!filename || *filename == '\0' || *filename == '/')
 | 
						if (!filename || *filename == '\0' || *filename == '/')
 | 
				
			||||||
		return NULL;
 | 
							return NULL;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										9
									
								
								util.h
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								util.h
									
									
									
									
									
								
							@@ -45,13 +45,6 @@
 | 
				
			|||||||
  (tv)->tv_usec += (t) % 1000 * 1000;   \
 | 
					  (tv)->tv_usec += (t) % 1000 * 1000;   \
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef TIMESPEC_TO_TIMEVAL
 | 
					 | 
				
			||||||
#define TIMESPEC_TO_TIMEVAL(tv,ts) {    \
 | 
					 | 
				
			||||||
  (tv)->tv_sec = (ts)->tv_sec;          \
 | 
					 | 
				
			||||||
  (tv)->tv_usec = (ts)->tv_nsec / 1000; \
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
typedef struct {
 | 
					typedef struct {
 | 
				
			||||||
	DIR *dir;
 | 
						DIR *dir;
 | 
				
			||||||
	char *name;
 | 
						char *name;
 | 
				
			||||||
@@ -69,6 +62,8 @@ char* s_strdup(char*);
 | 
				
			|||||||
void warn(const char*, ...);
 | 
					void warn(const char*, ...);
 | 
				
			||||||
void die(const char*, ...);
 | 
					void die(const char*, ...);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ssize_t get_line(char**, size_t*, FILE*);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void size_readable(float*, const char**);
 | 
					void size_readable(float*, const char**);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
char* absolute_path(const char*);
 | 
					char* absolute_path(const char*);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								window.c
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								window.c
									
									
									
									
									
								
							@@ -16,6 +16,8 @@
 | 
				
			|||||||
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
					 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define _POSIX_C_SOURCE 200112L
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include <X11/Xutil.h>
 | 
					#include <X11/Xutil.h>
 | 
				
			||||||
#include <X11/cursorfont.h>
 | 
					#include <X11/cursorfont.h>
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user