1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
/* Error message processing */
#ifdef _MSC_VER
# ifndef _CRT_SECURE_NO_DEPRECATE
# define _CRT_SECURE_NO_DEPRECATE
# endif
# ifndef _CRT_NONSTDC_NO_DEPRECATE
# define _CRT_NONSTDC_NO_DEPRECATE
# endif
#endif
#ifndef ACCEPT_USE_OF_DEPRECATED_PROJ_API_H
#define ACCEPT_USE_OF_DEPRECATED_PROJ_API_H
#endif
#include <errno.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "proj_internal.h"
#include "proj_config.h"
#define EMESS_ROUTINE
#include "emess.h"
void
emess(int code, const char *fmt, ...) {
va_list args;
va_start(args, fmt);
/* prefix program name, if given */
if (emess_dat.Prog_name != nullptr)
(void)fprintf(stderr,"%s\n<%s>: ",pj_get_release(),
emess_dat.Prog_name);
/* print file name and line, if given */
if (emess_dat.File_name != nullptr && *emess_dat.File_name) {
(void)fprintf(stderr,"while processing file: %s", emess_dat.File_name);
if (emess_dat.File_line > 0)
(void)fprintf(stderr,", line %d\n", emess_dat.File_line);
else
(void)fputc('\n', stderr);
} else
putc('\n', stderr);
/* if |code|==2, print errno code data */
if (code == 2 || code == -2)
{
int my_errno = errno;
#ifdef HAVE_STRERROR
const char* my_strerror = strerror(my_errno);
#endif
#ifndef HAVE_STRERROR
const char* my_strerror = "<system mess. texts unavail.>";
#endif
(void)fprintf(stderr, "Sys errno: %d: %s\n",
my_errno, my_strerror);
}
/* post remainder of call data */
(void)vfprintf(stderr,fmt,args);
va_end(args);
/* die if code positive */
if (code > 0) {
(void)fputs("\nprogram abnormally terminated\n", stderr);
exit(code);
}
else
putc('\n', stderr);
}
|