Logo Search packages:      
Sourcecode: gretl version File versions  Download package

dbread.h

/*
 *   Copyright (c) by Allin Cottrell
 *
 *   This program is free software; you can redistribute it and/or modify
 *   it under the terms of the GNU General Public License as published by
 *   the Free Software Foundation; either version 2 of the License, or
 *   (at your option) any later version.
 *
 *   This program is distributed in the hope that it will be useful,
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *   GNU General Public License for more details.
 *
 *   You should have received a copy of the GNU General Public License
 *   along with this program; if not, write to the Free Software
 *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 */

#ifndef DBREAD_H
#define DBREAD_H

#define DB_DESCRIP_LEN 72  /* size of array to hold "# description" */

typedef enum {
    DB_MISSING_DATA = E_MAX + 1,
    DB_NO_SUCH_SERIES,
    DB_PARSE_ERROR
} db_error_codes;

typedef enum {
    COMPACT_NONE,
    COMPACT_SUM,
    COMPACT_AVG,
    COMPACT_SOP,
    COMPACT_EOP,
    COMPACT_WDAY,
    COMPACT_MAX
} CompactMethod; 

typedef float dbnumber;

typedef struct _db_table db_table;

typedef struct _SERIESINFO SERIESINFO;

struct _SERIESINFO {
    char varname[VNAMELEN];
    char descrip[MAXLABEL];
    int nobs;
    char stobs[OBSLEN];
    char endobs[OBSLEN];
    int pd;
    int offset;
    int err;
    int undated;
};

struct _db_table {
    int nvars;
    int nalloc;
    SERIESINFO *sinfo;
};

int get_native_db_data (const char *dbbase, SERIESINFO *sinfo, 
                  double **Z);

int get_pcgive_db_data (const char *dbbase, SERIESINFO *sinfo, 
                  double **Z);

int get_rats_db_data (const char *fname, SERIESINFO *sinfo, double **Z);

db_table *read_rats_db (FILE *fp);

db_table *read_pcgive_db (FILE *fp);

double *compact_db_series (const double *src, SERIESINFO *sinfo,
                     int target_pd, CompactMethod method);

double *expand_db_series (const double *src, SERIESINFO *sinfo,
                    int target_pd);

void init_datainfo_from_sinfo (DATAINFO *pdinfo, SERIESINFO *sinfo);

int set_db_name (const char *fname, int filetype, const PATHS *ppaths, 
             PRN *prn);

int db_set_sample (const char *line, DATAINFO *pdinfo);

int db_get_series (const char *line, double ***pZ, DATAINFO *datainfo, 
               PRN *prn);

void get_db_padding (SERIESINFO *sinfo, DATAINFO *pdinfo, 
                 int *pad1, int *pad2);

int check_db_import (SERIESINFO *sinfo, DATAINFO *pdinfo);

int compact_data_set (double ***pZ, DATAINFO *pdinfo, int newpd,
                  CompactMethod default_method, int monstart,
                  int repday);

int expand_data_set (double ***pZ, DATAINFO *pdinfo, int newpd);

#endif /* DBREAD_H */

Generated by  Doxygen 1.6.0   Back to index