1 |
edhill |
1.1 |
/************************************************* -*- mode: C -*- |
2 |
edhill |
1.2 |
* $Header: /u/gcmpack/MITgcm/pkg/mnc/mnc_create_dir.c,v 1.1 2004/03/22 05:10:10 edhill Exp $ |
3 |
edhill |
1.1 |
* $Name: $ |
4 |
|
|
*/ |
5 |
|
|
|
6 |
|
|
/* Here, we get the definition of the FC_NAMEMANGLE() macro. */ |
7 |
|
|
#include "FC_NAMEMANGLE.h" |
8 |
|
|
|
9 |
|
|
#include <time.h> |
10 |
|
|
#include <stdio.h> |
11 |
|
|
#include <stdlib.h> |
12 |
|
|
#include <unistd.h> |
13 |
|
|
#include <assert.h> |
14 |
|
|
#include <sys/stat.h> |
15 |
|
|
#include <sys/types.h> |
16 |
|
|
#include <sys/time.h> |
17 |
edhill |
1.2 |
void FC_NAMEMANGLE(mnccdir) ( int *nienc, int *ienc, int *idate ) |
18 |
edhill |
1.1 |
{ |
19 |
edhill |
1.2 |
char name[512], dname[512]; |
20 |
edhill |
1.1 |
struct tm * tmp; |
21 |
|
|
time_t tt; |
22 |
edhill |
1.2 |
int i, j, n, ntot, iyyyymmdd; |
23 |
edhill |
1.1 |
mode_t mode = 0x0; |
24 |
edhill |
1.2 |
char * cenc = |
25 |
|
|
{"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_.,+-=/~\0"}; |
26 |
|
|
int ncenc = 70; |
27 |
edhill |
1.1 |
|
28 |
edhill |
1.2 |
n = ((*nienc) > 100) ? 100 : (*nienc); |
29 |
edhill |
1.1 |
tt = time(&tt); |
30 |
|
|
tmp = localtime(&tt); |
31 |
edhill |
1.2 |
iyyyymmdd = tmp->tm_mday |
32 |
|
|
+ 100*(tmp->tm_mon + 1 + 100*(1900+tmp->tm_year)); |
33 |
|
|
for (i=0; i<n; i++) { |
34 |
|
|
/* printf("ienc = %d, %c\n", ienc[i], cenc[ienc[i] - 1]); */ |
35 |
|
|
name[i] = cenc[ienc[i] - 1]; |
36 |
|
|
} |
37 |
|
|
name[n] = '\0'; |
38 |
|
|
/* printf("name = \"%s\", n = %d\n", name, n); */ |
39 |
edhill |
1.1 |
for (i=1; i<10000; i++) { |
40 |
edhill |
1.2 |
if (*idate == 1) |
41 |
|
|
snprintf(dname, 100, "%s%08d_%04d\0", name, iyyyymmdd, i); |
42 |
|
|
else |
43 |
|
|
snprintf(dname, 100, "%s%04d\0", name, i); |
44 |
edhill |
1.1 |
mode = S_IRWXU | S_IRWXG | S_IROTH | S_IXOTH; |
45 |
edhill |
1.2 |
if (mkdir(dname, mode) == 0) { |
46 |
edhill |
1.1 |
break; |
47 |
|
|
} |
48 |
|
|
} |
49 |
edhill |
1.2 |
n = (int)(strlen(dname)); |
50 |
|
|
/* printf("dname = \"%s\", n = %d\n", dname, n); */ |
51 |
|
|
ntot = 0; |
52 |
|
|
for (i=0; i<n; i++) { |
53 |
|
|
for (j=0; j<ncenc; j++) { |
54 |
|
|
if (cenc[j] == dname[i]) { |
55 |
|
|
ienc[ntot] = j + 1; |
56 |
|
|
ntot++; |
57 |
|
|
break; |
58 |
|
|
} |
59 |
|
|
} |
60 |
|
|
} |
61 |
|
|
*nienc = ntot; |
62 |
edhill |
1.1 |
} |
63 |
|
|
|
64 |
|
|
|