Files correlati : Ricompilazione Demo : [ ] Commento : Riportata la versione 2.1 598 git-svn-id: svn://10.65.10.50/trunk@13909 c028cbd2-c16b-5b4b-a496-9718f37d4682
333 lines
10 KiB
C++
Executable File
333 lines
10 KiB
C++
Executable File
#ifndef __MRPLIB_H
|
|
#define __MRPLIB_H
|
|
|
|
#ifndef __AUTOMASK_H
|
|
#include <automask.h>
|
|
#endif
|
|
|
|
#ifndef __ASSOC_H
|
|
#include <assoc.h>
|
|
#endif
|
|
|
|
#ifndef __DBLIB_H
|
|
#include "../db/dblib.h"
|
|
#endif
|
|
#ifndef __MGLIB_H
|
|
#include "../mg/mglib.h"
|
|
#endif
|
|
|
|
|
|
class TMRP_array : public TObject
|
|
{
|
|
TAssoc_array _by_key;
|
|
TPointer_array _by_idx;
|
|
|
|
void swap(long i, long j) { _by_idx.swap(int(i), int(j)); }
|
|
|
|
protected:
|
|
TToken_string _key; // Token string di lavoro
|
|
|
|
virtual TSortable* new_obj(const TToken_string& key) const pure;
|
|
TSortable* add_obj(const TToken_string& key);
|
|
TSortable* find_obj(const TToken_string& key) const
|
|
{ return (TSortable*)_by_key.objptr(key); }
|
|
TSortable& find_obj(long n) const
|
|
{ return (TSortable&)_by_idx[int(n)]; }
|
|
|
|
public:
|
|
long items() const { return _by_key.items(); }
|
|
void destroy();
|
|
long sort();
|
|
void add(TMRP_array &a, bool force=false);
|
|
|
|
// I metodi add(), find() e operator[] devono essere dichiarati
|
|
// dalle classi derivate e ritornare i tipi giusti tramite cast
|
|
// TSortable* add(const char* key, bool create)
|
|
// { return (TSortable*)add_obj(key); }
|
|
// TSortable* find(const char* key) const
|
|
// { return (TSortable*)find_obj(key); }
|
|
// TSortable& operator[](long index) const
|
|
// { return (TSortable&)*find_obj(index); }
|
|
TMRP_array & operator=(const TMRP_array& a);
|
|
|
|
TMRP_array() { }
|
|
TMRP_array(const TMRP_array& a);
|
|
virtual ~TMRP_array() { }
|
|
};
|
|
|
|
class TMRP_calendar : public TObject
|
|
{
|
|
static TString16 _days;
|
|
static TToken_string _holidays;
|
|
int _inizturno[8];
|
|
int _lungturno[8];
|
|
int _persturno[8];
|
|
|
|
TAssoc_array _exc_imp, _exc_lin;
|
|
TString8 _codimp, _codlin;
|
|
|
|
protected:
|
|
void init_default();
|
|
void read_cal(const TString& key, char tipo);
|
|
int write_cal(char tipo) const;
|
|
int remove_cal(const TString& code, char tipo) const;
|
|
|
|
public:
|
|
int turni(const TDate& date, int& mini, int& maxi, bool as_is = false) const;
|
|
|
|
int turni_min(const TDate& date) const
|
|
{ int mini, maxi; turni(date, mini, maxi); return mini; }
|
|
|
|
int turni_max(const TDate& date) const
|
|
{ int mini, maxi; turni(date, mini, maxi); return maxi; }
|
|
|
|
// ore minime e massime ad una certa data
|
|
int add_oremacchina(real & var,const TDate& date, bool max=false) const;
|
|
int add_oremacchina_max(real & var,const TDate& date) const;
|
|
|
|
int add_oreuomo(real & var,const TDate& date, bool max=false) const;
|
|
int add_oreuomo_max(real & var,const TDate& date) const;
|
|
|
|
TDate& next_working_day(TDate& from, int gap = 1) const;
|
|
TDate& prev_working_day(TDate& from, int gap = 1) const
|
|
{ return next_working_day(from, -gap); }
|
|
|
|
int set_turni(const TDate& date, int mini, int maxi);
|
|
|
|
int write() const;
|
|
int rewrite() const { return write(); }
|
|
int remove() const;
|
|
|
|
void declare_holiday(int g, int m);
|
|
void suppress_holiday(int g, int m);
|
|
bool is_holiday(int g, int m) const;
|
|
bool is_holiday(const TDate& date) const;
|
|
bool is_red(const TDate& date) const;
|
|
|
|
void set(const char* linea = NULL, const char* impianto = NULL);
|
|
const TString& linea() const { return _codlin; }
|
|
const TString& impianto() const { return _codimp; }
|
|
char tipo() const;
|
|
|
|
TMRP_calendar(const char* linea = NULL, const char* impianto = NULL);
|
|
virtual ~TMRP_calendar() { }
|
|
};
|
|
|
|
class TCalendar_field : public TWindowed_field
|
|
{
|
|
protected: // TWindowed_field
|
|
virtual TField_window* create_window(int x, int y, int dx, int dy,
|
|
WINDOW parent);
|
|
public:
|
|
void set_calendar(TMRP_calendar* cal, int year = 0);
|
|
|
|
TCalendar_field(TMask* m) : TWindowed_field(m) { }
|
|
virtual ~TCalendar_field() { }
|
|
};
|
|
|
|
class TCalendar_mask : public TAutomask
|
|
{
|
|
TMRP_calendar _calendar;
|
|
|
|
protected:
|
|
virtual TMask_field* parse_field(TScanner& scanner);
|
|
// void make_profile_name(TFilename& f) const;
|
|
|
|
public:
|
|
TMRP_calendar& calendar() { return _calendar; }
|
|
// void save_profile();
|
|
// void load_profile();
|
|
|
|
const TMRP_calendar& calendar() const { return _calendar; }
|
|
void update_calendar(short calendar, short year, short plant = 0, short line = 0);
|
|
|
|
TCalendar_mask(const char* name, int num = 0);
|
|
virtual ~TCalendar_mask() {};
|
|
};
|
|
|
|
|
|
class TMRP_time : public TSortable
|
|
{
|
|
static TAssoc_array _frate_indovino;
|
|
|
|
TString8 _imp, _lin;
|
|
TDate _date;
|
|
int _hour;
|
|
|
|
TMRP_calendar& calendario();
|
|
void copy(const TMRP_time& t) { set(t._date, t._hour, t._imp, t._lin); }
|
|
|
|
public:
|
|
static TMRP_calendar& get_calendar(const char* codimp=NULL,const char* ccodlin=NULL);
|
|
|
|
const TString& impianto() const {return _imp;}
|
|
const TString& linea() const {return _lin;}
|
|
const TDate& date() const { return _date; }
|
|
int hour() const { return _hour; }
|
|
|
|
virtual int compare(const TSortable& s) const;
|
|
|
|
TMRP_time& add_time(int days, long hours = 0, bool macchina=TRUE);
|
|
TMRP_time& sub_time(int days, long hours = 0, bool macchina=TRUE) { return add_time(-days, -hours,macchina); }
|
|
|
|
void set(const TDate& d, int h, const char* imp, const char* lin);
|
|
TMRP_time& operator=(const TMRP_time& t) { copy(t); return *this; }
|
|
|
|
TMRP_time();
|
|
TMRP_time(const TDate& d, int h, const char* imp, const char* lin);
|
|
TMRP_time(const TMRP_time& t) { copy(t); }
|
|
virtual ~TMRP_time() { }
|
|
};
|
|
|
|
class TMRP_config : public TConfig
|
|
{
|
|
protected:
|
|
void set_inizio_turno(int t,int time);
|
|
void set_durata_turno(int t,int time);
|
|
|
|
public:
|
|
// **
|
|
void set_inizio_turno(int t,int ore, int minuti);
|
|
void set_durata_turno(int t,int ore, int minuti);
|
|
void set_numpers_turno(int t, int pers) {set("NUMPERS", pers, "mr", TRUE, t);}
|
|
void set_turni(int n) {set("NTURNI", n, "mr", TRUE);}
|
|
void set_gestimpianti(bool gi) {set("GESTIMPIANTI", gi ? "X" : "", "mr", TRUE); }
|
|
|
|
// **
|
|
int inizio_turno(int t);
|
|
int durata_turno(int t);
|
|
// **
|
|
int ora_inizio_turno(int t);
|
|
int min_inizio_turno(int t);
|
|
int ore_durata_turno(int t);
|
|
int min_durata_turno(int t);
|
|
int num_turni() {return get_int("NTURNI", "mr");}
|
|
int numpers_turno(int t);
|
|
bool gestimpianti() {return get_bool("GESTIMPIANTI","mr"); }
|
|
|
|
TMRP_config() : TConfig(CONFIG_DITTA,"mr") {}
|
|
virtual ~TMRP_config() {}
|
|
};
|
|
|
|
class TUnita_produttiva : public TRectype
|
|
{
|
|
const char *erre1(int t); // campo durata e inizio turno
|
|
const char *erre2(int t); // numero persone
|
|
protected:
|
|
void set_inizio_turno(int t,int time);
|
|
void set_durata_turno(int t,int time);
|
|
|
|
public:
|
|
|
|
const char * codice() const {return get("CODTAB");}
|
|
const char * descr() const {return get("S0");}
|
|
|
|
int raw_numpers_turno(int t) ;
|
|
// **
|
|
void set_inizio_turno(int t,int ore, int minuti);
|
|
void set_durata_turno(int t,int ore, int minuti);
|
|
void set_numpers_turno(int t, int pers);
|
|
|
|
virtual int num_turni() {return get_int("I0");}
|
|
virtual real tempo_minimo() {return get_real("R1");}
|
|
virtual int inizio_turno(int t);
|
|
virtual int durata_turno(int t);
|
|
// **
|
|
int ora_inizio_turno(int t);
|
|
int min_inizio_turno(int t);
|
|
int ore_durata_turno(int t);
|
|
int min_durata_turno(int t);
|
|
// numero di persone sul turno
|
|
virtual int numpers_turno(int t) ;
|
|
// flag di personale dedicato
|
|
virtual bool personale_dedicato() const { return get_bool("B0"); }
|
|
|
|
virtual const char * codmagdep() const { return get("S7"); }
|
|
virtual const char * codmagdep_coll() const { return get("S8"); }
|
|
const char * codmag() const ;
|
|
const char * coddep() const ;
|
|
|
|
virtual TRectype & operator=(const TRectype& rec);
|
|
|
|
TUnita_produttiva(const TUnita_produttiva& rec) : TRectype (rec){}
|
|
TUnita_produttiva(const TRectype& rec) : TRectype (rec){}
|
|
TUnita_produttiva() : TRectype (LF_TAB){}
|
|
virtual ~TUnita_produttiva() { }
|
|
};
|
|
|
|
class TImpianto : public TUnita_produttiva
|
|
{
|
|
protected:
|
|
TObject* dup() const { return new TImpianto(*this); }
|
|
|
|
public:
|
|
virtual TRectype & operator=(const TRectype& rec);
|
|
// **
|
|
TImpianto(const char* cod = "") ;
|
|
TImpianto(const TRectype& rec) : TUnita_produttiva (rec) {}
|
|
TImpianto(const TImpianto& rec) : TUnita_produttiva (rec){}
|
|
virtual ~TImpianto() { }
|
|
};
|
|
|
|
class TLinea_prod : public TUnita_produttiva
|
|
{
|
|
protected:
|
|
TObject* dup() const { return new TLinea_prod(*this); }
|
|
public:
|
|
TImpianto * get_impianto() const;
|
|
// **
|
|
const char * codimp() const;
|
|
virtual const char * codmagdep() const ;
|
|
virtual const char * codmagdep_coll() const ;
|
|
bool to_check() const {return !get_bool("B9");} //
|
|
int check_level() const {return !get_bool("I2");} //
|
|
|
|
// **
|
|
virtual int num_turni() ;
|
|
virtual int inizio_turno(int t);
|
|
virtual int durata_turno(int t);
|
|
virtual int numpers_turno(int t) ;
|
|
|
|
virtual TRectype & operator=(const TRectype& rec);
|
|
|
|
TLinea_prod(const char* cod = "") ;
|
|
TLinea_prod(const TRectype& rec) : TUnita_produttiva (rec) {}
|
|
TLinea_prod(const TLinea_prod& rec) : TUnita_produttiva (rec){}
|
|
virtual ~TLinea_prod() { }
|
|
};
|
|
|
|
TImpianto * get_impianto(const char * codice);
|
|
TLinea_prod* get_linea(const char * codice);
|
|
|
|
void find_price(const TString &tipocv, const TString &codcv, const TString &codcatven,
|
|
const char * tipocf, long codcf, const char * codice, const real & qta, real & price);
|
|
|
|
class TProduzione : public TMultiple_rectype
|
|
{
|
|
|
|
protected:
|
|
void init();
|
|
virtual TProduzione & copy(const TProduzione & d) { return (TProduzione &) TMultiple_rectype::operator=((TMultiple_rectype &)d);}
|
|
virtual TObject* dup() const { return new TProduzione(*this); }
|
|
virtual bool renum();
|
|
virtual bool key_complete() { return head().get_int("PROG") != 0; }
|
|
|
|
public:
|
|
virtual TProduzione & operator =(const TProduzione & d) {return copy(d);}
|
|
static void set_key(TRectype& rec, const char* codart, TDate datacons, int prog);
|
|
static void copy_data(TRectype & dst, const TRectype & src);
|
|
static void copy_row(TRectype & dst, const TRectype & src) { copy_data((TRectype&)dst, (const TRectype&)src);}
|
|
void copy_contents(const TProduzione & src);
|
|
|
|
int read_art(const char* codart, TDate datacons, int prog, word op = _isequal, word lockop = _nolock);
|
|
int read_ordp(const char* codnum, int anno, char provv, long ndoc, int nriga, word op = _isequal, word lockop = _nolock);
|
|
int read_bolp(const char* codnum, int anno, char provv, long ndoc, int nriga, word op = _isequal, word lockop = _nolock);
|
|
|
|
TProduzione();
|
|
TProduzione(const TProduzione & d);
|
|
TProduzione(const char* codart, TDate datacons, int prog = 0);
|
|
virtual ~TProduzione() {}
|
|
};
|
|
|
|
#endif
|