Patch level : 2.1 nopatch
Files correlati : Ricompilazione Demo : [ ] Commento : Aggiunta gestione limiti di stampa git-svn-id: svn://10.65.10.50/trunk@11947 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
		
							parent
							
								
									82a4637049
								
							
						
					
					
						commit
						591c49e4c5
					
				| @ -738,7 +738,10 @@ bool TQuery_mask::get_qry_path(TFilename& path) const | |||||||
|   const bool ok = name.not_empty(); |   const bool ok = name.not_empty(); | ||||||
|   if (ok) |   if (ok) | ||||||
|   { |   { | ||||||
|     get_sql_directory(path); |     path = firm2dir(-1); | ||||||
|  |     path.add("custom"); | ||||||
|  |     if (!path.exist()) | ||||||
|  |       xvt_fsys_mkdir(path); | ||||||
|     path.add(name); |     path.add(name); | ||||||
|     path.ext("qry"); |     path.ext("qry"); | ||||||
|   } |   } | ||||||
| @ -748,7 +751,7 @@ bool TQuery_mask::get_qry_path(TFilename& path) const | |||||||
| bool TQuery_mask::select_query() | bool TQuery_mask::select_query() | ||||||
| { | { | ||||||
|   TFilename path; |   TFilename path; | ||||||
|   const bool ok = select_sql_file(path, "qry"); |   const bool ok = select_custom_file(path, "qry"); | ||||||
|   if (ok) |   if (ok) | ||||||
|   { |   { | ||||||
|     path = path.name(); path.ext(""); |     path = path.name(); path.ext(""); | ||||||
|  | |||||||
| @ -38,9 +38,9 @@ ENDPAGE | |||||||
| 
 | 
 | ||||||
| PAGE "Query" -1 -1 78 23 | PAGE "Query" -1 -1 78 23 | ||||||
| 
 | 
 | ||||||
| STRING F_CODICE 16 | STRING F_CODICE 128 24 | ||||||
| BEGIN | BEGIN | ||||||
|   PROMPT 1 0 "Codice " |   PROMPT 1 0 "" | ||||||
|   FLAGS "B" |   FLAGS "B" | ||||||
|   WARNING "E' necessario specificare il codice" |   WARNING "E' necessario specificare il codice" | ||||||
|   CHECKTYPE REQUIRED |   CHECKTYPE REQUIRED | ||||||
|  | |||||||
							
								
								
									
										218
									
								
								ba/ba8201.cpp
									
									
									
									
									
								
							
							
						
						
									
										218
									
								
								ba/ba8201.cpp
									
									
									
									
									
								
							| @ -235,21 +235,34 @@ TVariant& TVariant::sub(const TVariant& var) | |||||||
|   return *this; |   return *this; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | ///////////////////////////////////////////////////////////
 | ||||||
|  | // Utility
 | ||||||
|  | ///////////////////////////////////////////////////////////
 | ||||||
|  | 
 | ||||||
|  | static bool is_numeric(const char* str) | ||||||
|  | { | ||||||
|  |   if (str == NULL || *str == '\0' || *str == '0') | ||||||
|  |     return false;    // Se comincia per zero va preservato!
 | ||||||
|  |   if (*str == '-') | ||||||
|  |   { | ||||||
|  |     str++; | ||||||
|  |     if (*str <= ' ') | ||||||
|  |       return false; | ||||||
|  |   } | ||||||
|  |   while (*str) | ||||||
|  |   { | ||||||
|  |     if (strchr("0123456789.", *str) == NULL) | ||||||
|  |       return false; | ||||||
|  |     str++; | ||||||
|  |   } | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| ///////////////////////////////////////////////////////////
 | ///////////////////////////////////////////////////////////
 | ||||||
| // TRecordset
 | // TRecordset
 | ||||||
| ///////////////////////////////////////////////////////////
 | ///////////////////////////////////////////////////////////
 | ||||||
| 
 | 
 | ||||||
| const TVariant& TRecordset::get(const char* column_name) const |  | ||||||
| { |  | ||||||
|   for (unsigned int i = 0; i < columns(); i++) |  | ||||||
|   { |  | ||||||
|     const TRecordset_column_info& info = column_info(i); |  | ||||||
|     if (info._name == column_name) |  | ||||||
|       return get(i); |  | ||||||
|   } |  | ||||||
|   return NULL_VARIANT; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const TString& TRecordset::query_text() const | const TString& TRecordset::query_text() const | ||||||
| { | { | ||||||
|   return EMPTY_STRING; |   return EMPTY_STRING; | ||||||
| @ -472,21 +485,97 @@ bool TRecordset::save_as(const char* path, TRecordsetExportFormat fmt) | |||||||
|   return ok; |   return ok; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const TVariant& TRecordset::get(const char* column_name) const | ||||||
|  | { | ||||||
|  |   if (*column_name == '#' && variables().items() > 0) | ||||||
|  |     return get_var(column_name); | ||||||
|  | 
 | ||||||
|  |   for (unsigned int i = 0; i < columns(); i++) | ||||||
|  |   { | ||||||
|  |     const TRecordset_column_info& info = column_info(i); | ||||||
|  |     if (info._name == column_name) | ||||||
|  |       return get(i); | ||||||
|  |   } | ||||||
|  |   return NULL_VARIANT; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const TVariant& TRecordset::get_var(const char* name) const | ||||||
|  | { | ||||||
|  |   const TVariant* var = (const TVariant*)_var.objptr(name); | ||||||
|  |   return var != NULL ? *var : NULL_VARIANT; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool TRecordset::set_var(const char* name, const TVariant& var, bool create) | ||||||
|  | { | ||||||
|  |   bool ok = false; | ||||||
|  |   TVariant* old = (TVariant*)_var.objptr(name); | ||||||
|  |   if (old != NULL) | ||||||
|  |   { | ||||||
|  |     *old = var; | ||||||
|  |     ok = true; | ||||||
|  |   } | ||||||
|  |   else | ||||||
|  |   { | ||||||
|  |     if (create) | ||||||
|  |     { | ||||||
|  |       _var.add(name, var); | ||||||
|  |       _varnames.add(name); | ||||||
|  |       ok = true; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return ok; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool ask_variable(const char* name, TVariant& var) | ||||||
|  | { | ||||||
|  |   TMask m("Richiesta variabile", 1, 52, 4); | ||||||
|  |   m.add_static(-1, 0, name, 1, 0); | ||||||
|  |   m.add_string(101, 0, "", 1, 1, 80, "", 50); | ||||||
|  |   m.add_button(DLG_OK, 0, "", -12, -1, 10, 2); | ||||||
|  |   m.add_button(DLG_CANCEL, 0, "", -22, -1, 10, 2); | ||||||
|  |   m.set(101, var.as_string()); | ||||||
|  |   const bool ok = m.run() == K_ENTER; | ||||||
|  |   if (ok) | ||||||
|  |   { | ||||||
|  |     const TString& str = m.get(101); | ||||||
|  |     if (is_numeric(str)) | ||||||
|  |       var = real(str); | ||||||
|  |     else | ||||||
|  |       var = str; | ||||||
|  |   } | ||||||
|  |   return ok; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool TRecordset::ask_variables(bool all) const | ||||||
|  | { | ||||||
|  |   const bool ok = variables().items() > 0; | ||||||
|  |   if (ok) // Se ci sono variabili faccio le sostituzioni
 | ||||||
|  |   { | ||||||
|  |     FOR_EACH_ARRAY_ROW(_varnames, i, name) | ||||||
|  |     { | ||||||
|  |       TVariant var = get_var(*name); | ||||||
|  |       if (var.is_null() || all) // Mi serve assolutamente un valore!
 | ||||||
|  |       { | ||||||
|  |         ask_variable(*name, var); | ||||||
|  |         ((TSQL_recordset*)this)->set_var(*name, var); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return ok; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| ///////////////////////////////////////////////////////////
 | ///////////////////////////////////////////////////////////
 | ||||||
| // Utility
 | // Utility
 | ||||||
| ///////////////////////////////////////////////////////////
 | ///////////////////////////////////////////////////////////
 | ||||||
| 
 | 
 | ||||||
| void get_sql_directory(TFilename& name) | bool select_custom_file(TFilename& path, const char* ext) | ||||||
| { | { | ||||||
|   name = firm2dir(-1);  |   TFilename custom = firm2dir(-1); | ||||||
|   name.add("sql"); |   custom.add("custom"); | ||||||
|   if (!name.exist()) |   if (!custom.exist()) | ||||||
|     make_dir(name); |     xvt_fsys_mkdir(custom); | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| bool select_sql_file(TFilename& path, const char* ext) |   path = custom; | ||||||
| { |  | ||||||
|   get_sql_directory(path); |  | ||||||
|   path.add("*"); |   path.add("*"); | ||||||
|   path.ext(ext); |   path.ext(ext); | ||||||
| 
 | 
 | ||||||
| @ -521,7 +610,7 @@ bool select_sql_file(TFilename& path, const char* ext) | |||||||
|   const bool ok = sheet.run() == K_ENTER; |   const bool ok = sheet.run() == K_ENTER; | ||||||
|   if (ok) |   if (ok) | ||||||
|   { |   { | ||||||
|     get_sql_directory(path); |     path = custom; | ||||||
|     path.add(sheet.row(-1).get(0)); |     path.add(sheet.row(-1).get(0)); | ||||||
|     path.ext(ext); |     path.ext(ext); | ||||||
|   } |   } | ||||||
| @ -569,6 +658,14 @@ public: | |||||||
|   virtual ~TSQLite(); |   virtual ~TSQLite(); | ||||||
| } _TheDataBase; | } _TheDataBase; | ||||||
| 
 | 
 | ||||||
|  | void get_sql_directory(TFilename& name) | ||||||
|  | { | ||||||
|  |   name = firm2dir(-1);  | ||||||
|  |   name.add("sql"); | ||||||
|  |   if (!name.exist()) | ||||||
|  |     make_dir(name); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void TSQLite::build_curr_path(TFilename& name) const | void TSQLite::build_curr_path(TFilename& name) const | ||||||
| { | { | ||||||
|   TString16 firm; firm.format("%05ldA.sql", prefix().get_codditta()); |   TString16 firm; firm.format("%05ldA.sql", prefix().get_codditta()); | ||||||
| @ -841,6 +938,13 @@ bool TSQLite::import(int logicnum) | |||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | bool is_var_separator(char c) | ||||||
|  | { | ||||||
|  |   if (isspace(c)) | ||||||
|  |     return true; | ||||||
|  |   return strchr("<=>,", c) != NULL; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool TSQLite::parse_select_from(const char* szSql) | bool TSQLite::parse_select_from(const char* szSql) | ||||||
| { | { | ||||||
|   test_path(); |   test_path(); | ||||||
| @ -887,25 +991,6 @@ TSQLite::~TSQLite() | |||||||
| // TSQL_recordset
 | // TSQL_recordset
 | ||||||
| ///////////////////////////////////////////////////////////
 | ///////////////////////////////////////////////////////////
 | ||||||
| 
 | 
 | ||||||
| static bool is_numeric(const char* str) |  | ||||||
| { |  | ||||||
|   if (str == NULL || *str == '\0' || *str == '0') |  | ||||||
|     return false;    // Se comincia per zero va preservato!
 |  | ||||||
|   if (*str == '-') |  | ||||||
|   { |  | ||||||
|     str++; |  | ||||||
|     if (*str <= ' ') |  | ||||||
|       return false; |  | ||||||
|   } |  | ||||||
|   while (*str) |  | ||||||
|   { |  | ||||||
|     if (strchr("0123456789.", *str) == NULL) |  | ||||||
|       return false; |  | ||||||
|     str++; |  | ||||||
|   } |  | ||||||
|   return true; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void TSQL_recordset::reset() | void TSQL_recordset::reset() | ||||||
| { | { | ||||||
|   _firstrow = _items = 0; |   _firstrow = _items = 0; | ||||||
| @ -951,10 +1036,39 @@ static int query_get_items(void* jolly, int argc, char** values, char** columns) | |||||||
|   return SQLITE_OK; |   return SQLITE_OK; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void TSQL_recordset::parsed_sql_text(TString& sql) const | ||||||
|  | { | ||||||
|  |   sql = _sql; | ||||||
|  |   if (ask_variables(false)) // Se ci sono variabili faccio le sostituzioni
 | ||||||
|  |   { | ||||||
|  |     const TString_array& names = variables(); | ||||||
|  |     FOR_EACH_ARRAY_ROW(names, i, name) // Scandisco tutte le variabili
 | ||||||
|  |     { | ||||||
|  |       TVariant var = get_var(*name); | ||||||
|  |       int pos = sql.find(*name); | ||||||
|  |       for ( ; pos > 0; pos = sql.find(*name, pos+1)) | ||||||
|  |       { | ||||||
|  |         const TString& after = sql.mid(pos+name->len()); | ||||||
|  |         sql.cut(pos); | ||||||
|  |         TString s = var.as_string(); | ||||||
|  |         if ((var.type() == _alfafld && s[0] != '\'') || var.is_null()) | ||||||
|  |         { | ||||||
|  |           s.insert("'"); | ||||||
|  |           s << '\''; | ||||||
|  |         } | ||||||
|  |         sql << s << after; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| TRecnotype TSQL_recordset::items() const | TRecnotype TSQL_recordset::items() const | ||||||
| { | { | ||||||
|   if (_items == 0) |   if (_items == 0) | ||||||
|     _TheDataBase.exec(_sql, query_get_items, (TSQL_recordset*)this); |   { | ||||||
|  |     TString sql; parsed_sql_text(sql); | ||||||
|  |     _TheDataBase.exec(sql, query_get_items, (TSQL_recordset*)this); | ||||||
|  |   } | ||||||
|   return _items; |   return _items; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -995,7 +1109,7 @@ bool TSQL_recordset::move_to(TRecnotype n) | |||||||
| 
 | 
 | ||||||
|   if (n < _firstrow || n >= _firstrow+_page.items()) |   if (n < _firstrow || n >= _firstrow+_page.items()) | ||||||
|   { |   { | ||||||
|     TString sql = _sql; |     TString sql; parsed_sql_text(sql); | ||||||
|     if (sql.find("LIMIT ") < 0) |     if (sql.find("LIMIT ") < 0) | ||||||
|     { |     { | ||||||
|       const int semicolon = sql.rfind(';'); |       const int semicolon = sql.rfind(';'); | ||||||
| @ -1040,7 +1154,27 @@ void TSQL_recordset::set(const char* sql) | |||||||
|   reset();  |   reset();  | ||||||
|   _sql = sql; |   _sql = sql; | ||||||
|   if (_sql.find("SELECT") >= 0 || _sql.find("select") >= 0) |   if (_sql.find("SELECT") >= 0 || _sql.find("select") >= 0) | ||||||
|  |   { | ||||||
|     _TheDataBase.parse_select_from(_sql); |     _TheDataBase.parse_select_from(_sql); | ||||||
|  | 
 | ||||||
|  |     // Cerca le variabili nel testo SQL:
 | ||||||
|  |     // Una variabile comincia per # ed e' composta da soli caratteri alfanumerici.
 | ||||||
|  |     // Prima del simbolo # e dopo il nome della variabile deve esserci un separatore o blank
 | ||||||
|  |     int diesis = _sql.find('#'); // cerco il primo #
 | ||||||
|  |     for ( ; diesis > 0; diesis = _sql.find('#', diesis+1)) // Cerco tutti i #
 | ||||||
|  |     { | ||||||
|  |       if (is_var_separator(_sql[diesis-1])) // Controllo che ci sia un separatore prima del #
 | ||||||
|  |       { | ||||||
|  |         int i = diesis+1; | ||||||
|  |         for ( ; _sql[i] && (isalnum(_sql[i]) || _sql[i] == '_'); i++); | ||||||
|  |         if (i > diesis+1) | ||||||
|  |         { | ||||||
|  |           const TString& name = _sql.sub(diesis, i); | ||||||
|  |           set_var(name, NULL_VARIANT, true); | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| TSQL_recordset::TSQL_recordset(const char* sql)  | TSQL_recordset::TSQL_recordset(const char* sql)  | ||||||
|  | |||||||
							
								
								
									
										16
									
								
								ba/ba8201.h
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								ba/ba8201.h
									
									
									
									
									
								
							| @ -1,6 +1,10 @@ | |||||||
| #ifndef __RECORDSET_H | #ifndef __RECORDSET_H | ||||||
| #define __RECORDSET_H | #define __RECORDSET_H | ||||||
| 
 | 
 | ||||||
|  | #ifndef __ASSOC_H | ||||||
|  | #include <assoc.h> | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| #ifndef __RECTYPES_H | #ifndef __RECTYPES_H | ||||||
| #include <rectypes.h> | #include <rectypes.h> | ||||||
| #endif | #endif | ||||||
| @ -80,6 +84,9 @@ enum TRecordsetExportFormat { fmt_unknown, fmt_html, fmt_text, fmt_silk, fmt_cam | |||||||
| 
 | 
 | ||||||
| class TRecordset : public TObject | class TRecordset : public TObject | ||||||
| { | { | ||||||
|  |   TAssoc_array _var; | ||||||
|  |   TString_array _varnames; | ||||||
|  | 
 | ||||||
| protected: | protected: | ||||||
|   bool save_as_html(const char* path); |   bool save_as_html(const char* path); | ||||||
|   bool save_as_silk(const char* path); |   bool save_as_silk(const char* path); | ||||||
| @ -102,6 +109,11 @@ public: // Absolutely needed methods | |||||||
|   virtual const TRecordset_column_info& column_info(unsigned int column) const pure; |   virtual const TRecordset_column_info& column_info(unsigned int column) const pure; | ||||||
|   virtual const TVariant& get(unsigned int column) const pure; |   virtual const TVariant& get(unsigned int column) const pure; | ||||||
| 
 | 
 | ||||||
|  |   virtual const TString_array& variables() const { return _varnames; } | ||||||
|  |   virtual const TVariant& get_var(const char* name) const; | ||||||
|  |   virtual bool set_var(const char* name, const TVariant& var, bool create = false); | ||||||
|  |   bool ask_variables(bool all) const; | ||||||
|  | 
 | ||||||
|   virtual const TString& query_text() const;  |   virtual const TString& query_text() const;  | ||||||
|   virtual const TVariant& get(const char* column_name) const; |   virtual const TVariant& get(const char* column_name) const; | ||||||
|   virtual const TToken_string& sheet_head() const; |   virtual const TToken_string& sheet_head() const; | ||||||
| @ -123,6 +135,7 @@ class TSQL_recordset : public TRecordset | |||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|   void reset(); |   void reset(); | ||||||
|  |   void parsed_sql_text(TString& sql) const; | ||||||
| 
 | 
 | ||||||
| public: // TRecordset
 | public: // TRecordset
 | ||||||
|   virtual TRecnotype items() const; |   virtual TRecnotype items() const; | ||||||
| @ -164,8 +177,7 @@ public: | |||||||
| // Utility
 | // Utility
 | ||||||
| ///////////////////////////////////////////////////////////
 | ///////////////////////////////////////////////////////////
 | ||||||
| 
 | 
 | ||||||
| void get_sql_directory(TFilename& path); | bool select_custom_file(TFilename& path, const char* ext); | ||||||
| bool select_sql_file(TFilename& path, const char* ext); |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -535,6 +535,8 @@ void TReport_properties_mask::set_report(const TReport& r) | |||||||
| { | { | ||||||
|   set(F_DY, r.lpi()); |   set(F_DY, r.lpi()); | ||||||
|   set_font_info(r.font()); |   set_font_info(r.font()); | ||||||
|  |   set(F_PRESCRIPT, r.prescript()); | ||||||
|  |   set(F_POSTSCRIPT, r.postscript()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void TReport_properties_mask::get_report(TReport& r) const | void TReport_properties_mask::get_report(TReport& r) const | ||||||
| @ -544,6 +546,8 @@ void TReport_properties_mask::get_report(TReport& r) const | |||||||
|   TReport_font f; |   TReport_font f; | ||||||
|   if (get_font_info(f)) |   if (get_font_info(f)) | ||||||
|     r.set_font(f); |     r.set_font(f); | ||||||
|  |   r.set_prescript(get(F_PRESCRIPT)); | ||||||
|  |   r.set_postscript(get(F_POSTSCRIPT)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ///////////////////////////////////////////////////////////
 | ///////////////////////////////////////////////////////////
 | ||||||
| @ -600,7 +604,7 @@ TMask_field* TReport_mask::parse_field(TScanner& scanner) | |||||||
| bool TReport_mask::select_report() | bool TReport_mask::select_report() | ||||||
| { | { | ||||||
|   TFilename path; |   TFilename path; | ||||||
|   const bool ok = select_sql_file(path, "rep"); |   const bool ok = select_custom_file(path, "rep"); | ||||||
|   if (ok) |   if (ok) | ||||||
|   { |   { | ||||||
|     path = path.name(); path.ext(""); |     path = path.name(); path.ext(""); | ||||||
| @ -612,7 +616,7 @@ bool TReport_mask::select_report() | |||||||
| bool TReport_mask::select_query() | bool TReport_mask::select_query() | ||||||
| { | { | ||||||
|   TFilename path;  |   TFilename path;  | ||||||
|   bool ok = select_sql_file(path, "qry"); |   bool ok = select_custom_file(path, "qry"); | ||||||
|   if (ok) |   if (ok) | ||||||
|   { |   { | ||||||
|     TXmlItem item; item.Load(path); |     TXmlItem item; item.Load(path); | ||||||
| @ -633,7 +637,10 @@ bool TReport_mask::get_rep_path(TFilename& path) const | |||||||
|   const bool ok = name.not_empty(); |   const bool ok = name.not_empty(); | ||||||
|   if (ok) |   if (ok) | ||||||
|   { |   { | ||||||
|     get_sql_directory(path); |     path = firm2dir(-1); | ||||||
|  |     path.add("custom"); | ||||||
|  |     if (!path.exist()) | ||||||
|  |       xvt_fsys_mkdir(path); | ||||||
|     path.add(name); |     path.add(name); | ||||||
|     path.ext("rep"); |     path.ext("rep"); | ||||||
|   } |   } | ||||||
| @ -717,10 +724,7 @@ bool TReport_mask::delete_report() | |||||||
| void TReport_mask::on_print() | void TReport_mask::on_print() | ||||||
| { | { | ||||||
|   TReport_printer rp(_report); |   TReport_printer rp(_report); | ||||||
|   if (printer().printtype() == screenvis) |   rp.print(printer().printtype() == screenvis); | ||||||
|     rp.preview(); |  | ||||||
|   else |  | ||||||
|     rp.print(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| TReport_section& TReport_mask::curr_section() | TReport_section& TReport_mask::curr_section() | ||||||
|  | |||||||
| @ -43,9 +43,9 @@ ENDPAGE | |||||||
| 
 | 
 | ||||||
| PAGE "@bReport" -1 -1 78 23 | PAGE "@bReport" -1 -1 78 23 | ||||||
| 
 | 
 | ||||||
| STRING F_CODICE 16 | STRING F_CODICE 128 24 | ||||||
| BEGIN | BEGIN | ||||||
|   PROMPT 1 0 "Report " |   PROMPT 1 0 "" | ||||||
|   FLAGS "B" |   FLAGS "B" | ||||||
|   WARNING "E' necessario specificare il codice" |   WARNING "E' necessario specificare il codice" | ||||||
|   CHECKTYPE REQUIRED |   CHECKTYPE REQUIRED | ||||||
|  | |||||||
| @ -103,6 +103,7 @@ BEGIN | |||||||
|   PROMPT -33 -1 "" |   PROMPT -33 -1 "" | ||||||
| END | END | ||||||
| 
 | 
 | ||||||
|  | ENDPAGE | ||||||
| 
 | 
 | ||||||
| ENDMASK | ENDMASK | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -25,5 +25,29 @@ END | |||||||
| 
 | 
 | ||||||
| ENDPAGE | ENDPAGE | ||||||
| 
 | 
 | ||||||
|  | PAGE "Avanzate" -1 -1 50 16 | ||||||
|  | 
 | ||||||
|  | MEMO F_PRESCRIPT 48 6 | ||||||
|  | BEGIN | ||||||
|  |   PROMPT 1 0 "Script iniziale" | ||||||
|  | END | ||||||
|  | 
 | ||||||
|  | MEMO F_POSTSCRIPT 48 5 | ||||||
|  | BEGIN | ||||||
|  |   PROMPT 1 6 "Script finale" | ||||||
|  | END | ||||||
|  | 
 | ||||||
|  | BUTTON DLG_CANCEL 10 2 | ||||||
|  | BEGIN | ||||||
|  |   PROMPT -13 -1 "" | ||||||
|  | END | ||||||
|  | 
 | ||||||
|  | BUTTON DLG_OK 10 2 | ||||||
|  | BEGIN | ||||||
|  |   PROMPT -33 -1 "" | ||||||
|  | END | ||||||
|  | 
 | ||||||
|  | ENDPAGE | ||||||
|  | 
 | ||||||
| ENDMASK | ENDMASK | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										126
									
								
								ba/ba8302.cpp
									
									
									
									
									
								
							
							
						
						
									
										126
									
								
								ba/ba8302.cpp
									
									
									
									
									
								
							| @ -1,6 +1,7 @@ | |||||||
| #include <colors.h> | #include <colors.h> | ||||||
| #include <expr.h> | #include <expr.h> | ||||||
| #include <image.h> | #include <image.h> | ||||||
|  | #include <relation.h> | ||||||
| #include <xml.h> | #include <xml.h> | ||||||
| 
 | 
 | ||||||
| #include "ba8201.h" | #include "ba8201.h" | ||||||
| @ -694,8 +695,8 @@ void TReport_script::set(const char* source) | |||||||
| 
 | 
 | ||||||
| bool TReport_script::execute(TReport& rep, TString& output) | bool TReport_script::execute(TReport& rep, TString& output) | ||||||
| { | { | ||||||
|   bool good = ok(); |   bool good = true; | ||||||
|   if (good) |   if (ok()) | ||||||
|   { |   { | ||||||
|     if (_bc == NULL) |     if (_bc == NULL) | ||||||
|     { |     { | ||||||
| @ -713,8 +714,8 @@ bool TReport_script::execute(TReport& rep, TString& output) | |||||||
| 
 | 
 | ||||||
| bool TReport_script::execute(TReport_field& rf) | bool TReport_script::execute(TReport_field& rf) | ||||||
| { | { | ||||||
|   bool good = ok(); |   bool good = true; | ||||||
|   if (good) |   if (ok()) | ||||||
|   { |   { | ||||||
|     TString str; |     TString str; | ||||||
|     TReport& rep = rf.section().report(); |     TReport& rep = rf.section().report(); | ||||||
| @ -1396,6 +1397,9 @@ bool TReport::load(const char* fname) | |||||||
|       sql->GetEnclosedText(str); |       sql->GetEnclosedText(str); | ||||||
|       set_recordset(str); |       set_recordset(str); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     _prescript.load(xml, "prescript"); | ||||||
|  |     _postscript.load(xml, "postscript"); | ||||||
|   } |   } | ||||||
|   return ok; |   return ok; | ||||||
| } | } | ||||||
| @ -1427,6 +1431,10 @@ bool TReport::save(const char* fname) const | |||||||
| 
 | 
 | ||||||
|     if (_recordset != NULL) |     if (_recordset != NULL) | ||||||
|       xml.AddChild("sql") << _recordset->query_text(); |       xml.AddChild("sql") << _recordset->query_text(); | ||||||
|  | 
 | ||||||
|  |     _prescript.save(xml, "prescript"); | ||||||
|  |     _postscript.save(xml, "postscript"); | ||||||
|  | 
 | ||||||
|     xml.Save(fname); |     xml.Save(fname); | ||||||
|   } |   } | ||||||
|   return ok; |   return ok; | ||||||
| @ -1444,8 +1452,31 @@ void TReport::unmap_font() | |||||||
| 
 | 
 | ||||||
| bool TReport::execute_prescript() | bool TReport::execute_prescript() | ||||||
| { | { | ||||||
|   TString80 str; |   bool ok = true; | ||||||
|   return _prescript.execute(*this, str); | 
 | ||||||
|  |   if (_prescript.ok()) | ||||||
|  |   { | ||||||
|  |     TString80 str; | ||||||
|  |     ok = _prescript.execute(*this, str);  | ||||||
|  |   } | ||||||
|  |   else | ||||||
|  |   { | ||||||
|  |     // Script dei poveri: lancia la maschera associata al report
 | ||||||
|  |     TFilename msk = _path; msk.ext("msk"); | ||||||
|  |     if (msk.exist()) | ||||||
|  |     { | ||||||
|  |       const KEY key = run_form(msk.name()); | ||||||
|  |       ok = key != K_ESC && key != K_QUIT; | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |       // Script dei poverissimi: chiede le eventuali variabili
 | ||||||
|  |       if (recordset() != NULL)  | ||||||
|  |         recordset()->ask_variables(true); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return ok; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool TReport::execute_postscript() | bool TReport::execute_postscript() | ||||||
| @ -1471,13 +1502,7 @@ bool TReport::get_usr_val(const TString& name, TVariant& var) const | |||||||
|    |    | ||||||
|   if (_recordset != NULL) |   if (_recordset != NULL) | ||||||
|   { |   { | ||||||
|     if (name[0] == '#') |     var = _recordset->get(name); | ||||||
|     { |  | ||||||
|       const TFixed_string str((const char*)name + 1); |  | ||||||
|       var = _recordset->get(str); |  | ||||||
|     } |  | ||||||
|     else |  | ||||||
|       var = _recordset->get(name); |  | ||||||
|     if (!var.is_null()) |     if (!var.is_null()) | ||||||
|       return true; |       return true; | ||||||
|   } |   } | ||||||
| @ -1498,9 +1523,10 @@ bool TReport::set_usr_val(const TString& name, const TVariant& var) | |||||||
| 
 | 
 | ||||||
| unsigned int TReport::compile_usr_word(const TString& name) const | unsigned int TReport::compile_usr_word(const TString& name) const | ||||||
| { | { | ||||||
|   const int words = 9; |   const int words = 10; | ||||||
|   const char* const names[words] = { NULL, "DISABLE", "ENABLE", "GET_SIZE", "HIDE",  |   const char* const names[words] = { NULL, "DISABLE", "ENABLE", "GET_SIZE", "HIDE",  | ||||||
|                                      "SET_BACK_COLOR", "SET_FORE_COLOR", "SET_SIZE", "SHOW" }; |                                      "RUN_FORM", "SET_BACK_COLOR", "SET_FORE_COLOR",  | ||||||
|  |                                      "SET_SIZE", "SHOW" }; | ||||||
|   int i;  |   int i;  | ||||||
|   for (i = words-1; i > 0; i--) |   for (i = words-1; i > 0; i--) | ||||||
|     if (name == names[i]) |     if (name == names[i]) | ||||||
| @ -1566,6 +1592,61 @@ bool TReport::do_message(const TVariant& var, FLDMSG_FUNC msg, void* jolly) | |||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | KEY TReport::run_form(const TString& maskname) | ||||||
|  | { | ||||||
|  |   TFilename fname = maskname; fname.ext("msk"); | ||||||
|  |   KEY key = K_QUIT; | ||||||
|  |   if (fname.custom_path()) | ||||||
|  |   { | ||||||
|  |     TMask m(maskname); | ||||||
|  |     TVariant var; | ||||||
|  |     for (int i = m.fields()-1; i >= 0; i--) | ||||||
|  |     { | ||||||
|  |       TMask_field& f = m.fld(i); | ||||||
|  |       const TFieldref* ref = f.field(); | ||||||
|  |       if (ref != NULL) | ||||||
|  |       { | ||||||
|  |         TString name = ref->name(); | ||||||
|  |         if (name[0] != '#') | ||||||
|  |           name.insert("#"); | ||||||
|  |         if (get_usr_val(name, var)) | ||||||
|  |           f.set(var.as_string()); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     key = m.run(); | ||||||
|  |     if (key != K_QUIT && key != K_ESC) | ||||||
|  |     { | ||||||
|  |       TRecordset* rset = recordset(); | ||||||
|  |       if (rset != NULL && rset->variables().items() == 0) | ||||||
|  |         rset = NULL; | ||||||
|  | 
 | ||||||
|  |       // Rendi visibili tutte le variabili utente al report
 | ||||||
|  |       for (int i = m.fields()-1; i >= 0; i--) | ||||||
|  |       { | ||||||
|  |         TMask_field& f = m.fld(i); | ||||||
|  |         const TFieldref* ref = f.field(); | ||||||
|  |         if (ref != NULL) | ||||||
|  |         { | ||||||
|  |           switch (f.class_id()) | ||||||
|  |           { | ||||||
|  |           case CLASS_CURRENCY_FIELD: | ||||||
|  |           case CLASS_REAL_FIELD: var = real(f.get()); break; | ||||||
|  |           case CLASS_DATE_FIELD: var = TDate(f.get()); break; | ||||||
|  |           default: var = f.get(); break; | ||||||
|  |           }        | ||||||
|  |           TString name = ref->name(); | ||||||
|  |           if (name[0] != '#') | ||||||
|  |             name.insert("#"); | ||||||
|  |           set_usr_val(name, var); | ||||||
|  |           if (rset != NULL) | ||||||
|  |             rset->set_var(name, var); | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return key; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool TReport::execute_usr_word(unsigned int opcode, TVariant_stack& stack) | bool TReport::execute_usr_word(unsigned int opcode, TVariant_stack& stack) | ||||||
| { | { | ||||||
|   switch (opcode) |   switch (opcode) | ||||||
| @ -1591,19 +1672,26 @@ bool TReport::execute_usr_word(unsigned int opcode, TVariant_stack& stack) | |||||||
|   case 4: // HIDE
 |   case 4: // HIDE
 | ||||||
|     do_message(stack.pop(), do_show, NULL); |     do_message(stack.pop(), do_show, NULL); | ||||||
|     break; |     break; | ||||||
|   case 5: // SET_BACK_COLOR
 |   case 5: // RUN_FORM
 | ||||||
|  |     { | ||||||
|  |       const TString& msk = stack.pop().as_string(); | ||||||
|  |       const KEY key = run_form(msk); | ||||||
|  |       stack.push(key); | ||||||
|  |     } | ||||||
|  |     break; | ||||||
|  |   case 6: // SET_BACK_COLOR
 | ||||||
|     { |     { | ||||||
|       const COLOR rgb = stack.pop().as_color(); |       const COLOR rgb = stack.pop().as_color(); | ||||||
|       do_message(stack.pop(), do_set_back_color, (void*)rgb); |       do_message(stack.pop(), do_set_back_color, (void*)rgb); | ||||||
|     } |     } | ||||||
|     break; |     break; | ||||||
|   case 6: // SET_FORE_COLOR
 |   case 7: // SET_FORE_COLOR
 | ||||||
|     { |     { | ||||||
|       const COLOR rgb = stack.pop().as_color(); |       const COLOR rgb = stack.pop().as_color(); | ||||||
|       do_message(stack.pop(), do_set_fore_color, (void*)rgb); |       do_message(stack.pop(), do_set_fore_color, (void*)rgb); | ||||||
|     } |     } | ||||||
|     break; |     break; | ||||||
|   case 7: // SET_SIZE
 |   case 8: // SET_SIZE
 | ||||||
|     { |     { | ||||||
|       const TVariant& fld = stack.pop(); |       const TVariant& fld = stack.pop(); | ||||||
|       const real h = stack.pop().as_real() * CENTO; |       const real h = stack.pop().as_real() * CENTO; | ||||||
| @ -1612,7 +1700,7 @@ bool TReport::execute_usr_word(unsigned int opcode, TVariant_stack& stack) | |||||||
|       do_message(fld, do_set_size, (void*)&sz); |       do_message(fld, do_set_size, (void*)&sz); | ||||||
|     } |     } | ||||||
|     break; |     break; | ||||||
|   case 8: // SHOW
 |   case 9: // SHOW
 | ||||||
|     do_message(stack.pop(), do_show, (void*)1); |     do_message(stack.pop(), do_show, (void*)1); | ||||||
|     break; |     break; | ||||||
|   default:  |   default:  | ||||||
|  | |||||||
| @ -337,6 +337,7 @@ protected: | |||||||
|   virtual bool execute_usr_word(unsigned int opcode, TVariant_stack& stack); |   virtual bool execute_usr_word(unsigned int opcode, TVariant_stack& stack); | ||||||
|   virtual bool get_usr_val(const TString& name, TVariant& var) const; |   virtual bool get_usr_val(const TString& name, TVariant& var) const; | ||||||
|   virtual bool set_usr_val(const TString& name, const TVariant& var); |   virtual bool set_usr_val(const TString& name, const TVariant& var); | ||||||
|  |   KEY run_form(const TString& msk); | ||||||
|    |    | ||||||
|   int parse_field(const char* code, char& type, int& level, int& id) const; |   int parse_field(const char* code, char& type, int& level, int& id) const; | ||||||
|   bool do_message(const TVariant& var, FLDMSG_FUNC msg, void* jolly); |   bool do_message(const TVariant& var, FLDMSG_FUNC msg, void* jolly); | ||||||
|  | |||||||
| @ -418,7 +418,7 @@ static BOOLEAN main_loop_callback(long jolly) | |||||||
|   return pp->main_loop(); |   return pp->main_loop(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool TPage_printer::print() | bool TPage_printer::do_print() | ||||||
| { | { | ||||||
|   bool ok = ask_pages(); |   bool ok = ask_pages(); | ||||||
|   if (ok) |   if (ok) | ||||||
| @ -433,7 +433,7 @@ void TPage_printer::print_page(word page) | |||||||
|   print_loop(); |   print_loop(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool TPage_printer::preview() | bool TPage_printer::do_preview() | ||||||
| { | { | ||||||
|   TPrinter& p = printer(); |   TPrinter& p = printer(); | ||||||
|   _rcd = p.get_printrcd(); |   _rcd = p.get_printrcd(); | ||||||
| @ -462,6 +462,11 @@ bool TPage_printer::preview() | |||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | bool TPage_printer::print(bool prev_mode) | ||||||
|  | { | ||||||
|  |   return prev_mode ? do_preview() : do_print(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| TPoint TPage_printer::page_size() const | TPoint TPage_printer::page_size() const | ||||||
| { | { | ||||||
|   return TPoint(_pw, _ph); |   return TPoint(_pw, _ph); | ||||||
| @ -681,3 +686,15 @@ bool TReport_printer::print_loop() | |||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | bool TReport_printer::print(bool preview_mode) | ||||||
|  | { | ||||||
|  |   bool ok = _report.execute_prescript(); | ||||||
|  |   if (ok) | ||||||
|  |   { | ||||||
|  |     ok = TPage_printer::print(preview_mode); | ||||||
|  |     if (ok) | ||||||
|  |       _report.execute_postscript(); | ||||||
|  |   } | ||||||
|  |   return ok; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | |||||||
| @ -35,16 +35,19 @@ protected: | |||||||
|   virtual bool close_page(); |   virtual bool close_page(); | ||||||
|   bool page_in_range() const; |   bool page_in_range() const; | ||||||
| 
 | 
 | ||||||
|  |   // Called by print(bool)
 | ||||||
|  |   virtual bool do_print();   | ||||||
|  |   virtual bool do_preview(); | ||||||
|  | 
 | ||||||
| public: | public: | ||||||
|   bool main_loop();          // Internal use only  
 |   bool main_loop();          // Internal use only  
 | ||||||
|   virtual bool print();      // Use this ...
 |  | ||||||
|   virtual bool preview();    // ... and this
 |  | ||||||
|   virtual void print_page(word page);  // Inefficient default implementation
 |   virtual void print_page(word page);  // Inefficient default implementation
 | ||||||
| 
 | 
 | ||||||
|   virtual TPoint page_size() const; |   virtual TPoint page_size() const; | ||||||
|   virtual TPoint page_res() const; |   virtual TPoint page_res() const; | ||||||
|   virtual word last_printed_page() { return _lastprinted; } |   virtual word last_printed_page() { return _lastprinted; } | ||||||
| 
 | 
 | ||||||
|  |   virtual bool print(bool preview = false); | ||||||
|   bool print_mode() const { return _preview_mask == NULL; } |   bool print_mode() const { return _preview_mask == NULL; } | ||||||
|   bool preview_mode() const { return _preview_mask != NULL; } |   bool preview_mode() const { return _preview_mask != NULL; } | ||||||
| 
 | 
 | ||||||
| @ -74,6 +77,8 @@ protected: | |||||||
|   long print_section(char type, int level); |   long print_section(char type, int level); | ||||||
| 
 | 
 | ||||||
| public: | public: | ||||||
|  |   virtual bool print(bool preview = false); | ||||||
|  | 
 | ||||||
|   TReport_printer(TReport& r) : _report(r) { } |   TReport_printer(TReport& r) : _report(r) { } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -380,7 +380,12 @@ bool TAVM::execute(const TBytecode& bc, ostream& outstr) | |||||||
|       break; |       break; | ||||||
|     case avm_swap: _stack.roll(1); break; |     case avm_swap: _stack.roll(1); break; | ||||||
|     case avm_then: break; |     case avm_then: break; | ||||||
|     case avm_usrword: _vm->execute_usr_word(op.var().as_int(), _stack); break; |     case avm_usrword:  | ||||||
|  |       { | ||||||
|  |         const long usrword = op.var().as_int(); | ||||||
|  |         _vm->execute_usr_word(usrword, _stack);  | ||||||
|  |       } | ||||||
|  |       break; | ||||||
|     default: |     default: | ||||||
|       _last_error << "Bad op code: " << op.op() << '\n'; |       _last_error << "Bad op code: " << op.op() << '\n'; | ||||||
|       log_error(_last_error); |       log_error(_last_error); | ||||||
| @ -394,6 +399,13 @@ bool TAVM::execute(const TBytecode& bc, ostream& outstr) | |||||||
| // TAlex_virtual_machine
 | // TAlex_virtual_machine
 | ||||||
| ///////////////////////////////////////////////////////////
 | ///////////////////////////////////////////////////////////
 | ||||||
| 
 | 
 | ||||||
|  | TAVM& TAlex_virtual_machine::avm() | ||||||
|  | { | ||||||
|  |   if (_avm == NULL) | ||||||
|  |     _avm = new TAVM(this); | ||||||
|  |   return *_avm; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| const TString& TAlex_virtual_machine::get_last_error() const | const TString& TAlex_virtual_machine::get_last_error() const | ||||||
| { | { | ||||||
|   if (_avm != NULL) |   if (_avm != NULL) | ||||||
| @ -403,16 +415,12 @@ const TString& TAlex_virtual_machine::get_last_error() const | |||||||
| 
 | 
 | ||||||
| bool TAlex_virtual_machine::compile(istream& instr, TBytecode& bc) | bool TAlex_virtual_machine::compile(istream& instr, TBytecode& bc) | ||||||
| { | { | ||||||
|   if (_avm == NULL) |   return avm().compile(instr, bc); | ||||||
|     _avm = new TAVM(this); |  | ||||||
|   return _avm->compile(instr, bc); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool TAlex_virtual_machine::execute(const TBytecode& bc, ostream& outstr) | bool TAlex_virtual_machine::execute(const TBytecode& bc, ostream& outstr) | ||||||
| { | { | ||||||
|   if (_avm == NULL) |   return avm().execute(bc, outstr); | ||||||
|     _avm = new TAVM(this); |  | ||||||
|   return _avm->execute(bc, outstr); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool TAlex_virtual_machine::compile(const char* cmd, TBytecode& bc) | bool TAlex_virtual_machine::compile(const char* cmd, TBytecode& bc) | ||||||
|  | |||||||
| @ -43,6 +43,9 @@ class TAlex_virtual_machine : public TObject | |||||||
| { | { | ||||||
|   TAVM* _avm; // Chesire's cat class
 |   TAVM* _avm; // Chesire's cat class
 | ||||||
| 
 | 
 | ||||||
|  | protected: | ||||||
|  |   TAVM& avm(); | ||||||
|  | 
 | ||||||
| public: | public: | ||||||
|   virtual unsigned int compile_usr_word(const TString& name) const; |   virtual unsigned int compile_usr_word(const TString& name) const; | ||||||
|   virtual bool execute_usr_word(unsigned int opcode, TVariant_stack& stack); |   virtual bool execute_usr_word(unsigned int opcode, TVariant_stack& stack); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user