MUSASHI C source: xtstatistics.c


0001: /*============================================================================*/ 
0002: /* 変更履歴                                                                   */ 
0003: /*----------------------------------------------------------------------------*/ 
0004: /* 1.0 : 新しいAPIに対応 2003/06/20                                           */ 
0005: /*============================================================================*/ 
0006:  
0007: #include <musashi.h
0008: #include <mssAgg.h
0009: #include <stdlib.h> 
0010:  
0011: #include <xtstatisticsHelp.h> 
0012: struct mssComHelp comHelp={ 
0013:   "xtstatistics", /* コマンド名       */ 
0014:   "1.0",          /* バージョン       */ 
0015:   HELPT,          /* コマンドタイトル */ 
0016:   HELPS,          /* 要約             */ 
0017:   HELPE,          /* 利用例           */ 
0018:   HELPR,          /* 参照コマンド     */ 
0019:   HELPA,          /* 作者情報         */ 
0020:   HELPB,          /* バグレポート情報 */ 
0021:   HELPH           /* ホームページ     */ 
0022: }; 
0023:  
0024: extern struct mssGlobalVariables mssGV; 
0025:  
0026: int main(int argc, char *argv[]){ 
0027: /*============================================================================*/ 
0028: /* オプション宣言&定義                                                       */ 
0029: /*============================================================================*/ 
0030: /*----------------------------------------------------------------------------*/ 
0031: /* キー項目                                                                   */ 
0032: /*----------------------------------------------------------------------------*/ 
0033:   MssOptKEY optKEY={ 
0034:     OKEY,   /* オプションタイプ                                             */ 
0035:     "k",    /* キーワード(複数文字は不可)                                   */ 
0036:     0,      /* 0:オプション, 1:必須, 2:XMLtableでのみ必須(txtでは無視)      */ 
0037:     MssFieldMaxCnt, /* 指定可能な最大項目数                                 */ 
0038:     "i",    /* 対象とする入力データのキーワード(GUIで利用)                  */ 
0039:     2,      /* デフォルト(このオプションが指定されなかったときの動作を指定) */ 
0040:             /* 1:全ての行を異るキー値として扱う                             */ 
0041:             /* 2:全ての行を同じキー値として扱う)                            */ 
0042:     KEYT,   /* このオプションのタイトル(Helpで表示)                         */ 
0043:     KEYC    /* このオプションのコメント(Helpで表示)                         */ 
0044:   }; 
0045:  
0046: /*----------------------------------------------------------------------------*/ 
0047: /* 集計項目                                                                   */ 
0048: /*----------------------------------------------------------------------------*/ 
0049:   MssOptFLD optFLD={ 
0050:     OFLD,   /* オプションタイプ                                             */ 
0051:     "f",    /* キーワード(複数文字は不可)                                   */ 
0052:     1,      /* 0:オプション, 1:必須, 2:XMLtableでのみ必須(txtでは無視)      */ 
0053:     MssFieldMaxCnt, /* 指定可能な最大項目数                                         */ 
0054:     "i",    /* 対象とする入力データのキーワード(GUIで利用)                  */ 
0055:     1,      /* 正規表現を許可するかどうか(0:不可,1:可)                      */ 
0056:     1,      /* 新項目名を指定できるかどうか(0:不可,1:可)                    */ 
0057:     NULL,   /* 項目オプション(%以下)で指定可能な文字                        */ 
0058:             /* ex) 指定不可の場合はNULL, "nr": "-f 項目名%rn"の指定可能     */ 
0059:     FLDT,   /* このオプションのタイトル(Helpで表示)                         */ 
0060:     FLDC,   /* このオプションのコメント(Helpで表示)                         */ 
0061:     FLDF    /* フラグについての説明(Helpで表示)複数の場合はカンマで区切る   */ 
0062:   }; 
0063:  
0064: /*----------------------------------------------------------------------------*/ 
0065: /* 集計方法                                                                   */ 
0066: /*----------------------------------------------------------------------------*/ 
0067:   MssOptSEL optCAL={ 
0068:     OSEL,   /* オプションタイプ                                             */ 
0069:     "c",    /* キーワード(複数文字は不可)                                   */ 
0070:     1,      /* 0:オプション, 1:必須, 2:XMLtableでのみ必須(txtでは無視)      */ 
0071:     NULL,   /* デフォルト(文字列にて)                                       */ 
0072:     "var,std", 
0073:             /* 指定可能な値リスト                                           */ 
0074:     CALT,   /* このオプションのタイトル(Helpで表示)                         */ 
0075:     CALC,   /* このオプションのコメント(Helpで表示)                         */ 
0076:     CALS    /* フラグについての説明(Helpで表示)複数の場合はカンマで区切る   */ 
0077:   }; 
0078:  
0079: /*----------------------------------------------------------------------------*/ 
0080: /* シーケンシャル処理                                                         */ 
0081: /*----------------------------------------------------------------------------*/ 
0082:   MssOptFLG optSEQ={ 
0083:     OFLG,   /* オプションタイプ                                             */ 
0084:     "q",    /* キーワード(複数文字は不可)                                   */ 
0085:     0,      /* デフォルト(基本的には0) 常にonにしたいときは1にする          */ 
0086:     SEQT,   /* このオプションのタイトル(Helpで表示)                         */ 
0087:     SEQC    /* このオプションのコメント(Helpで表示)                         */ 
0088:   }; 
0089:  
0090: /*----------------------------------------------------------------------------*/ 
0091: /* 入力ファイル                                                               */ 
0092: /*----------------------------------------------------------------------------*/ 
0093:   MssOptINF optINF={ 
0094:     OINF,   /* オプションタイプ                                             */ 
0095:     "i",    /* キーワード(複数文字は不可)                                   */ 
0096:     0,      /* 0:オプション, 1:必須                                         */ 
0097:     1,      /* 指定可能の最大ファイル数                                     */ 
0098:     0,      /*1:file not foundのエラーで終了しない 0:する                   */ 
0099:     INFT,   /* このオプションのタイトル(Helpで表示)                         */ 
0100:     INFC    /* このオプションのコメント(Helpで表示)                         */ 
0101:   }; 
0102:  
0103: /*----------------------------------------------------------------------------*/ 
0104: /* 出力ファイル                                                               */ 
0105: /*----------------------------------------------------------------------------*/ 
0106:   MssOptOTF optOTF={ 
0107:     OOTF,   /* オプションタイプ                                             */ 
0108:     "o",    /* キーワード(複数文字は不可)                                   */ 
0109:     0,      /* 0:オプション, 1:必須                                         */ 
0110:     OTFT,   /* このオプションのタイトル(Helpで表示)                         */ 
0111:     OTFC    /* このオプションのコメント(Helpで表示)                         */ 
0112:   }; 
0113:  
0114: /*----------------------------------------------------------------------------*/ 
0115: /* 圧縮出力                                                                   */ 
0116: /*----------------------------------------------------------------------------*/ 
0117:   MssOptFLG optZIP={ 
0118:     OFLG,   /* オプションタイプ                                             */ 
0119:     "z",    /* キーワード(複数文字は不可)                                   */ 
0120:     0,      /* デフォルト(基本的には0) 常にonにしたいときは1にする          */ 
0121:     ZIPT,   /* このオプションのタイトル(Helpで表示)                         */ 
0122:     ZIPC    /* このオプションのコメント(Helpで表示)                         */ 
0123:   }; 
0124:  
0125: /*----------------------------------------------------------------------------*/ 
0126: /* plain text                                                                 */ 
0127: /*----------------------------------------------------------------------------*/ 
0128:   MssOptFLG optTXT={ 
0129:     OFLG,   /* オプションタイプ                                             */ 
0130:     "t",    /* キーワード(複数文字は不可)                                   */ 
0131:     0,      /* デフォルト(基本的には0) 常にonにしたいときは1にする          */ 
0132:     TXTT,   /* このオプションのタイトル(Helpで表示)                         */ 
0133:     TXTC    /* このオプションのコメント(Helpで表示)                         */ 
0134:   }; 
0135:  
0136: /*----------------------------------------------------------------------------*/ 
0137: /* ワークファイル用ディレクトリ名                                             */ 
0138: /*----------------------------------------------------------------------------*/ 
0139:   MssOptSTR optTMP={ 
0140:     OSTR,   /* オプションタイプ                                             */ 
0141:     "T",    /* キーワード(複数文字は不可)                                   */ 
0142:     0,      /* 0:オプション, 1:必須, 2:XMLtableでのみ必須(txtでは無視)      */ 
0143:     MssTempDir, /* デフォルト                                               */ 
0144:     1,      /* 文字列の最小長                                               */ 
0145:     MssFileNameMaxLen,  /* 文字列の最大長                                   */ 
0146:     TMPT,   /* このオプションのタイトル(Helpで表示)                         */ 
0147:     TMPC    /* このオプションのコメント(Helpで表示)                         */ 
0148:   }; 
0149:  
0150: /*----------------------------------------------------------------------------*/ 
0151: /* オプションをまとめる                                                       */ 
0152: /*----------------------------------------------------------------------------*/ 
0153:   void *opt[]={&optKEY,&optFLD,&optCAL,&optSEQ, 
0154:                &optINF,&optOTF,&optZIP,&optTXT,&optTMP,NULL}; 
0155:  
0156: /*============================================================================*/ 
0157: /* 変数宣言&定義                                                             */ 
0158: /*============================================================================*/ 
0159:   struct mssHeader    *hdi; /*入力ファイル用<head>タグ格納構造体*/ 
0160:   struct mssHeader    *hdo; /*出力ファイル用<head>タグ格納構造体*/ 
0161:   struct mssFPR       *fpr; /*入力ファイル構造体                */ 
0162:   struct mssFPW       *fpw; /*出力ファイル構造体                */ 
0163:   struct mssFldRecDbl *frd; /*項目-二行バッファ構造体           */ 
0164:   struct mssFields    *sf;  /*ソート項目構造体     */ 
0165:   struct mssAggDat    *ad;  /*集計計算用の構造体                */ 
0166:  
0167:   int sorted; 
0168:  
0169: /*----------------------------------------------------------------------------*/ 
0170: /* 前処理                                                                     */ 
0171: /*----------------------------------------------------------------------------*/ 
0172:   mssInit(argc,argv,&comHelp);       /* シグナル処理などの初期化              */ 
0173:   mssHelpDoc(opt,&comHelp,argc,argv);/* ヘルプ                                */ 
0174:   mssSetOption(opt,argc,argv);       /* コマンドオプションの設定              */ 
0175:   fpr=mssOpenFPR(optINF.str,4);      /* 入力ファイルオープン                  */ 
0176:   hdi=mssReadHeader(fpr);            /* ヘッダの読み込み                      */ 
0177:   mssSetOptKey(&optKEY, hdi);        /* -k 項目をヘッダー項目に関連づける     */ 
0178:   mssSetOptFld(&optFLD, hdi);        /* -f 項目をヘッダー項目に関連づける     */ 
0179:    
0180:   /*ソート項目の作成*/ 
0181:   sf=mssInitFields();  
0182:   mssAddFieldsByFields(sf,optKEY.flds); /* -k 項目をソート項目としてセット    */ 
0183:   sorted=mssChkSorted(sf,hdi);          /* ソート済かチェック                 */ 
0184:    
0185: /*prnOptFld(fld);*/ 
0186: /*prnOption(opt);*/ 
0187: /*prnHeader(hdi);*/                                                            
0188:  
0189: /*----------------------------------------------------------------------------*/ 
0190: /*出力ヘッダーの作成と出力                                                    */ 
0191: /*----------------------------------------------------------------------------*/ 
0192:   /*出力ヘッダーの初期化(タイトル等のコピー)*/ 
0193:   hdo=mssInitCpyHeader(hdi);          
0194:    
0195:   /*-fで指定された項目は-fから、その他は入力ヘッダから項目を追加する*/ 
0196:   mssAddHeadOrOptFields(hdo->flds,hdi,&optFLD); 
0197:    
0198:   /*ソートする必要があるならばsfのソート情報を反映*/ 
0199:   if(!optSEQ.set && !sorted){ 
0200:     mssSetFieldsSort(hdo->flds,sf);      
0201:   } 
0202:  
0203:   /*標準出力オープン+ヘッダーの出力*/                                          
0204:   fpw=mssOpenFPW(optOTF.str,optZIP.set,0); 
0205:   mssWriteHeader(hdo, fpw); 
0206:  
0207: /*----------------------------------------------------------------------------*/ 
0208: /*メインルーチン                                                              */ 
0209: /*----------------------------------------------------------------------------*/ 
0210:   /* 集計用構造体の初期化 */ 
0211:   ad=mssInitAggDat(hdi->flds->cnt,&optKEY,&optFLD,optCAL.str,optTMP.str,&mssGV.inCnt); 
0212:  
0213:   /*ソートが必用ならばソートしてソート済みファイルとしてオープン*/ 
0214:   if(!optSEQ.set && !sorted) 
0215:     fpr=mssReopenFPRsort(fpr,4,sf,hdi->flds->cnt,optTMP.str); 
0216:  
0217:   /*FRD構造体の初期化*/ 
0218:   frd=mssInitFRD(hdi->flds->cnt); 
0219:  
0220:   while( EOF!=mssReadFRD(fpr,frd) ){ 
0221:  
0222:     /*キーブレイク時の処理*/ 
0223:     if(mssKeyBreak(frd, &optKEY)){ 
0224:  
0225:       /*一行書き出し*/ 
0226:       mssWriteAggFld(frd->pnt[frd->old],ad->aggVal,ad->aggType,fpw); 
0227:       mssGV.outCnt++; 
0228:       if(frd->eof) break; 
0229:  
0230:       /*集計値の初期化*/ 
0231:       mssClearAggVal(ad->aggVal, ad->aggType, optFLD.flds->cnt); 
0232:     } 
0233:  
0234:     mssGV.inCnt++; 
0235:  
0236:     /* -fの項目の値をvalueとしてad->valにセットする*/ 
0237:     mssSetAggVal(ad->val, frd->pnt[frd->new]); 
0238:  
0239:     /* ad->valの値をad->aggValに反映(足し込みなど)する*/ 
0240:     mssCalAggVal(ad->aggVal, ad->aggType, ad->val); 
0241:   } 
0242:   mssFreeFRD(frd); 
0243:  
0244: /*----------------------------------------------------------------------------*/ 
0245: /*フッター出力&終了処理                                                       */ 
0246: /*----------------------------------------------------------------------------*/ 
0247:   mssWriteFooter(fpw);     /* フッターの出力             */ 
0248:   mssCloseFPR(fpr);        /* 入力ファイルのクローズ     */ 
0249:   mssCloseFPW(fpw);        /* 出力ファイルのクローズ     */ 
0250:   mssFreeFields(sf);       /* ソート項目構造体の領域開放 */ 
0251:   mssFreeHeader(hdi);      /* 入力ヘッダ領域開放         */ 
0252:   mssFreeHeader(hdo);      /* 出力ヘッダ領域開放         */ 
0253:   mssFreeOption(opt);      /* オプション領域開放         */ 
0254:   mssShowEndMsg();         /* 完了メッセージ             */ 
0255:   mssEnd(mssExitSuccess);  /* 終了                       */ 
0256:   return(0);               /* to avoid warning message   */ 
0257: }