/[cvs]/joko/Uni/BSArch/01/prime.c
ViewVC logotype

Diff of /joko/Uni/BSArch/01/prime.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.8 by joko, Fri May 12 23:38:15 2006 UTC revision 1.10 by joko, Sat May 13 12:06:38 2006 UTC
# Line 3  Line 3 
3  #include <stdio.h>  #include <stdio.h>
4  #include <stdlib.h>  #include <stdlib.h>
5  #include <limits.h>  #include <limits.h>
6    #include <errno.h>
7    
8  #define BOOL int  #define BOOL int
9  #define TRUE 1  #define TRUE 1
# Line 10  Line 11 
11    
12  #define PRINTPRIME(x) if (is_prime(x)) printf("%i\n", x)  #define PRINTPRIME(x) if (is_prime(x)) printf("%i\n", x)
13  #define PRINTERROR(message) fprintf(stderr, "ERROR: %s\n", message)  #define PRINTERROR(message) fprintf(stderr, "ERROR: %s\n", message)
14    #define PRINTWARNING(message) fprintf(stderr, "WARNING: %s\n", message)
15    
16  /* check for prime number */  /* check for prime number */
17  BOOL is_prime(long int number)  BOOL is_prime(long int number)
18  {  {
19          int i;          int i;
20                    
21          /* negative values are never prime numbers */          /* negative values, 0 and 1 are never prime numbers */
22          if (number < 2) return FALSE;          if (number < 2) return FALSE;
23                    
24          /* check all numbers 2..sqrt(number) for being a prime number */          /* check all numbers 2..sqrt(number) for being a prime number */
# Line 29  BOOL is_prime(long int number) Line 31  BOOL is_prime(long int number)
31    
32  /* convert from string to long int, with error checking */  /* convert from string to long int, with error checking */
33  long int convert_number(const char *nptr) {  long int convert_number(const char *nptr) {
34          long int number = strtol(nptr, (char **)NULL, 10);          
35          if (number == LONG_MAX || number == LONG_MIN) {          char * endptr;
36            long int number = strtol(nptr, &endptr, 10);
37    
38            errno = 0;
39            
40            /* invalid characters? */
41            if (*endptr != '\0') {
42                    char message[254];
43                    snprintf(message, 256, "Could not convert '%s' to a valid number.", nptr);
44                    PRINTERROR(message);
45                    exit(EXIT_FAILURE);
46            }
47            
48            /* invalid range? */
49            /* if (number == LONG_MAX || number == LONG_MIN) { */
50            if (errno == ERANGE) {
51                  char message[254];                  char message[254];
52                  snprintf(message, 256, "Number is not in range of 'long int': %s", nptr);                  snprintf(message, 256, "Number is not in range of 'long int': %s", nptr);
53                  PRINTERROR(message);                  PRINTERROR(message);
54                  exit(-1);                  exit(EXIT_FAILURE);
55          }          }
56            
57            return number;
58            
59  }  }
60    
61  int main(int argc, char * argv[])  int main(int argc, char * argv[])
# Line 43  int main(int argc, char * argv[]) Line 63  int main(int argc, char * argv[])
63                    
64          if (argc == 1) {          if (argc == 1) {
65                  PRINTERROR("No arguments given.");                  PRINTERROR("No arguments given.");
66                  exit(-1);                  exit(EXIT_FAILURE);
67          }          }
68                    
69          /* (3) range mode */          /* (3) range mode */
70          if (argc > 2) {          if (argc > 2) {
71                  long int i, j;                  long int i, j;
72                    i = convert_number(argv[1]);
73                  j = convert_number(argv[2]);                  j = convert_number(argv[2]);
74                  for (i = convert_number(argv[1]); i< j; i++) {                  for (i; i< j; i++) {
75                          PRINTPRIME(i);                          PRINTPRIME(i);
76                  }                  }
77                    
# Line 67  int main(int argc, char * argv[]) Line 88  int main(int argc, char * argv[])
88                                    
89                  /* (2) file mode: read numbers from file */                  /* (2) file mode: read numbers from file */
90                  } else {                  } else {
91                          char entry[11];                          char entry[81];
92                          while (fgets(entry, 11, fp)) {                          long int number;
93                                  long int number = convert_number(entry);                          long int lineno = 0;
94                            while (fgets(entry, 81, fp)) {
95                                    
96                                    /* count line number (for warnings) */
97                                    lineno++;
98    
99                                    /* skip empty lines */
100                                    if (strlen(entry) < 2) continue;
101    
102                                    /* line handling: policy = skip exceeding lines */
103                                    
104                                    /* if last char is newline, strip it */
105                                    if (entry[strlen(entry)-1] == '\n') {
106                                            entry[strlen(entry)-1] = '\0';
107                                            
108                                    /* line exceeds max length */
109                                    } else {
110                                            char message[254];
111                                            snprintf(message, 256, "Line too long (max 80 chars) in line number: %i", lineno);
112                                            PRINTWARNING(message);
113                                            
114                                            /* eat all characters until newline */
115                                            while (fgetc(fp) != 10);
116                                            
117                                            /* skip this line from prime calculation */
118                                            continue;
119                                    }
120                                    
121                                    number = convert_number(entry);
122                                  PRINTPRIME(number);                                  PRINTPRIME(number);
123                          }                          }
124                          fclose(fp);                          fclose(fp);

Legend:
Removed from v.1.8  
changed lines
  Added in v.1.10

MailToCvsAdmin">MailToCvsAdmin
ViewVC Help
Powered by ViewVC 1.1.26 RSS 2.0 feed