TPCCLIB
Loading...
Searching...
No Matches
libtpcli.c
1/******************************************************************************
2 * This file is not compiled into the library, but it contains main()
3 * which is compiled to an executable, used to test the library functions.
4 *****************************************************************************/
5
6/*****************************************************************************/
7#include "tpcclibConfig.h"
8/*****************************************************************************/
9#include <stdio.h>
10#include <stdlib.h>
11#include <math.h>
12#include <time.h>
13#include <string.h>
14#include <ctype.h>
15#include <unistd.h>
16/*****************************************************************************/
17#include "tpcextensions.h"
18/*****************************************************************************/
19#include "tpcli.h"
20#include "test_tpcli.h"
21/*****************************************************************************/
22
23/*****************************************************************************/
24static char *info[] = {
25 "Usage: @P [options]",
26 " ",
27 "Options:",
28 " -stdoptions", // List standard options like --help, -v, etc
29 " -t, --test",
30 " Run all tests for library functions.",
31 0};
32/*****************************************************************************/
33
34/*****************************************************************************/
39int main(
41 int argc,
43 char *argv[ ]
44) {
45 int i, help=0, version=0, verbose=1, error=0, test=0;
46 int ret;
47 char *cptr;
48
49 if(argc==1) {tpcPrintUsage(argv[0], info, stdout); return(0);}
50 for(i=1; i<argc; i++) {
51 if(tpcProcessStdOptions(argv[i], &help, &version, &verbose)==0) continue;
52 cptr=argv[i]; if(*cptr=='-') cptr++; if(*cptr=='-') cptr++;
53 if(strncasecmp(cptr, "TEST", 1)==0) {
54 test=1; continue;
55 } else {
56 error++; break;
57 }
58 }
59 if(error>0) {
60 fprintf(stderr, "Error: specify --help for usage.\n");
61 return(1);
62 }
63 /* Print help or version? */
64 if(help) {tpcPrintUsage(argv[0], info, stdout); return(0);}
65 if(version) {tpcPrintBuild(argv[0], stdout); return(0);}
66
67 if(test==0) return(0);
68
69 if(verbose>0) printf("running tests for library functions...\n");
70 TPCSTATUS status; statusInit(&status); status.verbose=verbose;
71 statusSet(&status, __func__, __FILE__, __LINE__, 0);
72 i=10;
73 /* interpolate */
74 i++; if((ret=test_liFirstStepSize(&status))!=0) {
75 fprintf(stderr, "failed (%d).\n", ret);
76 statusPrint(stderr, &status); statusFree(&status);
77 return(i);
78 }
79 i++; if((ret=test_simSamples(&status))!=0) {
80 fprintf(stderr, "failed (%d).\n", ret);
81 statusPrint(stderr, &status); statusFree(&status);
82 return(i);
83 }
84 i++; if((ret=test_liInterpolate(&status))!=0) {
85 fprintf(stderr, "failed (%d).\n", ret);
86 statusPrint(stderr, &status); statusFree(&status);
87 return(i);
88 }
89 i++; if((ret=test_liInterpolateForPET(&status))!=0) {
90 fprintf(stderr, "failed (%d).\n", ret);
91 statusPrint(stderr, &status); statusFree(&status);
92 return(i);
93 }
94/*i++; if((ret=test_liFrameMidValue(&status))!=0) {
95 fprintf(stderr, "failed (%d).\n", ret);
96 statusPrint(stderr, &status); statusFree(&status);
97 return(i);
98 }*/
99 /* integrate */
100 i++; if((ret=test_liIntegrate(&status))!=0) {
101 fprintf(stderr, "failed (%d).\n", ret);
102 statusPrint(stderr, &status); statusFree(&status);
103 return(i);
104 }
105 i++; if((ret=test_liIntegratePET(&status))!=0) {
106 fprintf(stderr, "failed (%d).\n", ret);
107 statusPrint(stderr, &status); statusFree(&status);
108 return(i);
109 }
110 i++; if((ret=test_liIntegrateFE(&status))!=0) {
111 fprintf(stderr, "failed (%d).\n", ret);
112 statusPrint(stderr, &status); statusFree(&status);
113 return(i);
114 }
115 i++; if((ret=test_liIntegrateHalfFrame(&status))!=0) {
116 fprintf(stderr, "failed (%d).\n", ret);
117 statusPrint(stderr, &status); statusFree(&status);
118 return(i);
119 }
120 i++; if((ret=test_liDerivate(&status))!=0) {
121 fprintf(stderr, "failed (%d).\n", ret);
122 statusPrint(stderr, &status); statusFree(&status);
123 return(i);
124 }
125 i++; if((ret=test_liDerivate3(&status))!=0) {
126 fprintf(stderr, "failed (%d).\n", ret);
127 statusPrint(stderr, &status); statusFree(&status);
128 return(i);
129 }
130
131 if(verbose>0) printf("\nAll tests passed.\n\n");
132 statusFree(&status);
133 return(0);
134}
135/*****************************************************************************/
136
137/*****************************************************************************/
int tpcProcessStdOptions(const char *s, int *print_usage, int *print_version, int *verbose_level)
Definition proginfo.c:47
void tpcPrintBuild(const char *program, FILE *fp)
Definition proginfo.c:339
void tpcPrintUsage(const char *program, char *text[], FILE *fp)
Definition proginfo.c:114
void statusPrint(FILE *fp, TPCSTATUS *s)
Definition statusmsg.c:82
void statusInit(TPCSTATUS *s)
Definition statusmsg.c:104
void statusSet(TPCSTATUS *s, const char *func, const char *srcfile, int srcline, tpcerror error)
Definition statusmsg.c:142
void statusFree(TPCSTATUS *s)
Definition statusmsg.c:126
int verbose
Verbose level, used by statusPrint() etc.
Header file for library libtpcextensions.
Header file for libtpcli.