*** empty log message ***
git-svn-id: svn://10.65.10.50/trunk@11841 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
		
							parent
							
								
									ee474af565
								
							
						
					
					
						commit
						980fbadf0b
					
				| @ -179,19 +179,19 @@ bool TArray::destroy( | ||||
| 
 | ||||
| 
 | ||||
| TArray::TArray(int arraysize)    | ||||
|       : _size(0), _items(0), _next(0), _data(NULL) | ||||
|       : _data(NULL), _size(0), _items(0), _next(0) | ||||
| { | ||||
|   if (arraysize)  | ||||
|     resize(arraysize); | ||||
| } | ||||
| 
 | ||||
| TArray::TArray()  | ||||
|       : _size(0), _items(0), _next(0), _data(NULL) | ||||
|       :  _data(NULL), _size(0), _items(0), _next(0) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| TArray::TArray(const TArray& a)  | ||||
|       : _size(0), _items(0), _next(0), _data(NULL) | ||||
|       : _data(NULL), _size(0), _items(0), _next(0) | ||||
| { | ||||
|   (*this) = a; | ||||
| }               | ||||
| @ -629,7 +629,7 @@ int TPointer_array::insert(const TObject& object, int index, bool force) | ||||
| ///////////////////////////////////////////////////////////
 | ||||
| 
 | ||||
| TBit_array::TBit_array(long size)  | ||||
|           : _bit(NULL), _size(0) | ||||
|           : _size(0), _bit(NULL) | ||||
| { | ||||
|   if (size) | ||||
|     resize(index(size)); | ||||
| @ -653,7 +653,7 @@ void TBit_array::copy( | ||||
|   memcpy(_bit, ba._bit, _size); | ||||
| } | ||||
| 
 | ||||
| TBit_array::TBit_array(const TBit_array& ba) : _bit(NULL), _size(0) | ||||
| TBit_array::TBit_array(const TBit_array& ba) : _size(0), _bit(NULL) | ||||
| {       copy(ba); } | ||||
| 
 | ||||
| TBit_array& TBit_array::operator=(const TBit_array& ba) | ||||
| @ -747,7 +747,7 @@ void TBit_array::reset(long n) | ||||
| } | ||||
| 
 | ||||
| // Certified 99%
 | ||||
| void TBit_array::not(long n) | ||||
| void TBit_array::neg(long n) | ||||
| { | ||||
|   const word i = index(n); | ||||
|   if (i >= _size) resize(i); | ||||
|  | ||||
| @ -208,7 +208,7 @@ inline TObject& TArray::operator[] (int index) const | ||||
| #define FOR_EACH_ARRAY_ITEM(__arr, __r, __obj)      \ | ||||
|   TObject* __obj;                                   \ | ||||
|   for (int __r = __arr.first();                     \ | ||||
|        __obj = __arr.objptr(__r);                   \ | ||||
|        (__obj = __arr.objptr(__r));                   \ | ||||
|        __r = __arr.succ(__r)) | ||||
| 
 | ||||
| #define FOR_EACH_ARRAY_ITEM_BACK(__arr, __r, __obj) \ | ||||
| @ -309,7 +309,7 @@ public: | ||||
|   // @cmember Setta a 0 il bit n-esimo dell'array
 | ||||
|   void reset(long n); | ||||
|   // @cmember Not logico del bit n-esimo dell'array
 | ||||
|   void not(long n); | ||||
|   void neg(long n); | ||||
| 
 | ||||
|   // @cmember Setta il bit n-esimo a seconda del valore passato come secondo elemento
 | ||||
|   void set(long n, bool on) { on ? set(n) : reset(n); } | ||||
|  | ||||
| @ -43,8 +43,9 @@ THash_object* TAssoc_array::_lookup( | ||||
|   TArray& arr = bucket(hv); | ||||
|   THash_object* o = NULL; | ||||
|   isnew = FALSE; | ||||
|   int i; | ||||
| 
 | ||||
|   for (int i = 0; i < arr.items(); i++) | ||||
|   for (i = 0; i < arr.items(); i++) | ||||
|   { | ||||
|     THash_object* ob = (THash_object*)arr.objptr(i); | ||||
|     if (ob->_key == key) | ||||
| @ -198,7 +199,7 @@ bool TAssoc_array::add(const char* key, const TObject& obj, bool force) | ||||
| {  | ||||
|   // Non inserire l'Hash_object se non lo trovi (ci pensa la add sotto)
 | ||||
|   bool isnew = FALSE; | ||||
|   THash_object* o = _lookup(key,isnew,FALSE);  | ||||
|   _lookup(key,isnew,FALSE);  | ||||
|   if (!isnew && !force) | ||||
|     return TRUE; | ||||
|   return add(key,obj.dup(),force); | ||||
| @ -221,7 +222,9 @@ bool TAssoc_array::remove( | ||||
|   const word hv = key.hash() % HASH_SIZE; | ||||
|   TArray& arr = bucket(hv); | ||||
|   THash_object* o = NULL; | ||||
|   for (int i = 0; i < arr.items(); i++) | ||||
|   int i; | ||||
|    | ||||
|   for (i = 0; i < arr.items(); i++) | ||||
|   { | ||||
|     THash_object* ob = (THash_object*)&arr[i]; | ||||
|     if (ob->_key == key) | ||||
| @ -349,7 +352,7 @@ int TAssoc_array::get_keys(TString_array& kl, bool add_values) | ||||
|   restart(); | ||||
|   THash_object* o = NULL;   | ||||
|   TString tmp(80); | ||||
|   while (o = get_hashobj()) | ||||
|   while ((o = get_hashobj())) | ||||
|   { | ||||
|     TToken_string* tt = new TToken_string(o->key()); | ||||
|     if (add_values) | ||||
|  | ||||
| @ -60,7 +60,6 @@ TField_event TAutomask::key2event(TMask_field& f, KEY key) const | ||||
|   case K_SPACE: | ||||
|     if (!f.is_edit()) | ||||
|     { | ||||
|       const TMask& wm = f.mask(); | ||||
|       if (f.is_kind_of(CLASS_BUTTON_FIELD)) | ||||
|         fe = fe_button; else | ||||
|       if (f.is_kind_of(CLASS_TREE_FIELD)) | ||||
|  | ||||
| @ -83,7 +83,9 @@ | ||||
| #define         ntrrec          "trc.gen" | ||||
| #define         nditta          "dta.gen" | ||||
| 
 | ||||
| #ifndef __STDTYPES_H | ||||
| typedef unsigned char byte; | ||||
| #endif | ||||
| typedef char    Str8[9]; | ||||
| typedef char    Str25[26]; | ||||
| typedef char    Str30[32]; | ||||
| @ -99,9 +101,6 @@ extern Str80            cprefix; | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|   char *esc(char *); | ||||
| 
 | ||||
| 
 | ||||
|    int CIOResult(void ); | ||||
| #ifdef WIN32 | ||||
|   void tmpfname(char *,char *); | ||||
|  | ||||
| @ -1,21 +1,15 @@ | ||||
| #include "ccustio.h"          | ||||
| 
 | ||||
| #include "checks.h" | ||||
| 
 | ||||
| #include <sys/stat.h> | ||||
| #ifdef WIN32 | ||||
| #include <sys/types.h> | ||||
| #endif | ||||
| 
 | ||||
| #include <sys/stat.h> | ||||
| 
 | ||||
| #ifdef LINUX | ||||
| #include <sys/ipc.h> | ||||
| #include <sys/sem.h> | ||||
| #include <unistd.h> | ||||
| #else | ||||
| #include <io.h> | ||||
| #include <share.h> | ||||
| #include <sys/locking.h>            | ||||
| #else | ||||
| #include "../xvaga/xvt.h" | ||||
| #include <sys/ipc.h> | ||||
| #include <sys/sem.h> | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| 
 | ||||
| #define         CalcPos(Rec, Len, Base) (((Rec) - 1) * ((RecNoType) (Len)) + ((RecNoType) (Base))) | ||||
| @ -25,8 +19,8 @@ | ||||
| #define         LOCKSEM "locksem" | ||||
| 
 | ||||
| /* extern long lseek(int, long, int);*/ | ||||
| extern int chsize(int, long); | ||||
| extern int lockf(int, int, long); | ||||
| // extern int chsize(int, long);
 | ||||
| // extern int lockf(int, int, long);
 | ||||
| #endif | ||||
| 
 | ||||
| unsigned        setlock(unsigned); | ||||
| @ -262,8 +256,13 @@ void                            CCreate(S, Name, Len, Base, MaxSec) | ||||
|     if ((S->F = open(Name, O_RDWR | O_CREAT, 0666)) == -1) | ||||
| #endif | ||||
|       if ((S->IOR = CIOResult()) != NoErr) return ; | ||||
| #ifdef WIN32 | ||||
|   if (chsize(S->F, ((RecNoType) MaxSec)*BlockLenIO) == -1) | ||||
| #else | ||||
|   if (lseek(S->F, ((RecNoType) MaxSec)*BlockLenIO, SEEK_SET) == -1) | ||||
| #endif | ||||
| 		S->IOR = CIOResult(); | ||||
| 
 | ||||
|   if (close(S->F) == -1) | ||||
|   { | ||||
|     junk = CIOResult(); | ||||
| @ -300,7 +299,12 @@ void                            CChsize(S, Name, Len, Base, MaxSec) | ||||
|     if ((S->F = open(Name, O_RDWR, 0666)) == -1) | ||||
| #endif | ||||
|       if ((S->IOR = CIOResult()) != NoErr) return ; | ||||
|   if (chsize(S->F, ((RecNoType) MaxSec)*BlockLenIO) == -1) | ||||
| #ifdef WIN32 | ||||
|   if (chsize(S->F, ((RecNoType) MaxSec)*BlockLenIO) == -1)#else | ||||
| #else | ||||
|   if (lseek(S->F, ((RecNoType) MaxSec)*BlockLenIO, SEEK_SET) == -1) | ||||
| #endif | ||||
| 
 | ||||
|     S->IOR = CIOResult(); | ||||
|   if (close(S->F) == -1) | ||||
|   { | ||||
| @ -731,9 +735,7 @@ void    VS(sid) | ||||
| 
 | ||||
|    sid       = identificatore del semaforo su locksem. | ||||
| 
 | ||||
|    errno     = numero errore. | ||||
| 
 | ||||
|    sb        = struttura che contiene informazioni sullo stato del file (vedi "stat"). | ||||
|    errno     = codice errore. | ||||
| 
 | ||||
|    @(FSV) | ||||
|    */ | ||||
| @ -747,7 +749,6 @@ int excllock(name,excl) | ||||
|   char  path[200], dir[200]; | ||||
|   int           fd, junk, sid; | ||||
|   extern int errno; | ||||
|   struct stat   sb; | ||||
| 
 | ||||
|   strcpy(path, lockpath(name)); | ||||
|   strcpy(dir, dirname(path)); | ||||
| @ -755,7 +756,8 @@ int excllock(name,excl) | ||||
|   if (semres == -1) return(-1); | ||||
|   PS(sid); | ||||
|   if (semres == -1) return(-1); | ||||
|   if ((stat(dir, &sb) == -1) && (errno == ENOENT)) CMkDir(dir); | ||||
|   if (xvt_fsys_access(dir, F_OK) == ENOENT) | ||||
| 	 xvt_fsys_mkdir(dir); | ||||
|   if (((fd = open(path, O_WRONLY | O_CREAT | O_EXCL, 0666)) == -1) &&  | ||||
|       errno == EEXIST) | ||||
|   { | ||||
|  | ||||
| @ -49,7 +49,7 @@ typedef struct  { | ||||
| #define TESTLOCK(x)             ((x) == 13 || (x) == 11) | ||||
| #define DEADLOCK(x)             ((x) == EDEADLOCK) | ||||
| #else    | ||||
| #define TESTLOCK(x)             (((x) == EACCES) || ((x) == EGAIN) || ((x) == ENOLCK)) | ||||
| #define TESTLOCK(x)             (((x) == EACCES) || ((x) == ENOLCK)) | ||||
| #define DEADLOCK(x)             (((x) == EDEADLOCK) || ((x) == EDEADLK)) | ||||
| #endif | ||||
| #define BLOCKEXT(len,rec)       (((((RecNoType) (len)) * ((RecNoType) (rec))) / BlockLenIO) + 1) | ||||
|  | ||||
| @ -2,6 +2,11 @@ | ||||
| 
 | ||||
| #include <xvt.h> | ||||
| 
 | ||||
| #ifdef LINUX | ||||
| extern const char * _c_user; | ||||
| extern BOOLEAN _is_admin;  | ||||
| #endif | ||||
| 
 | ||||
| #include "cfiles.h" | ||||
| 
 | ||||
| int  dirfl[2] = {0, 0}, recfl[2] = {0, 0} ; | ||||
| @ -390,8 +395,8 @@ int CGetCampoStpValue(const char* name, char* value, int valsize) | ||||
|       break; | ||||
|     } | ||||
|   } | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
|   return bFound; | ||||
| } | ||||
| 
 | ||||
| @ -413,13 +418,15 @@ const char* CGetCampoIni(void) | ||||
|   static char* prawin = NULL; | ||||
|   if (prawin == NULL) | ||||
|   { | ||||
|     BOOLEAN bFound = FALSE; | ||||
| #ifdef WIN32 | ||||
|     // Nelle installazioni sfigate con programmi in rete cerca di stabilire il percorso locale di Campo.ini
 | ||||
|     DIRECTORY dir;  | ||||
|     char exedir[_MAX_PATH], path[_MAX_PATH]; | ||||
|     DIRECTORY dir;  | ||||
| 
 | ||||
|     // Nelle installazioni sfigate con programmi in rete cerca di stabilire il percorso locale di Campo.ini
 | ||||
|     xvt_fsys_get_default_dir(&dir); | ||||
|     xvt_fsys_convert_dir_to_str(&dir, exedir, sizeof(exedir)); | ||||
| #ifdef WIN32 | ||||
|     BOOLEAN bFound = FALSE; | ||||
| 
 | ||||
|     if (xvt_fsys_is_network_drive(exedir)) | ||||
|     { | ||||
|       bFound = CGetCampoStpValue("CampoIni", path, sizeof(path)); | ||||
| @ -435,14 +442,9 @@ const char* CGetCampoIni(void) | ||||
|         } | ||||
|       } | ||||
|     } | ||||
| #endif | ||||
|     if (!bFound) | ||||
|     { | ||||
| #ifdef LINUX | ||||
|       char ininame[32]; | ||||
|       sprintf(ininame, "campo%u", getuid()); | ||||
|       xvt_fsys_build_pathname(path, NULL, exedir, ininame, "ini", NULL); | ||||
| #else | ||||
| #endif | ||||
|       xvt_fsys_build_pathname(path, NULL, exedir, "campo", "ini", NULL); | ||||
|       if (! xvt_fsys_file_exists(path)) | ||||
|       { | ||||
| @ -450,8 +452,9 @@ const char* CGetCampoIni(void) | ||||
|         sprintf(msg, "Impossibile aprire '%s'", (const char *)path); | ||||
|         xvt_dm_post_fatal_exit(msg); | ||||
|       } | ||||
| #endif | ||||
| #ifdef WIN32 | ||||
|     } | ||||
| #endif | ||||
|     prawin = xvt_str_duplicate(path); | ||||
|   } | ||||
|   return prawin; | ||||
| @ -463,12 +466,31 @@ HIDDEN BOOLEAN CGetFirmDir() | ||||
|   BOOLEAN good = xvt_fsys_file_exists(prawin); | ||||
|   if (good)   | ||||
|   { | ||||
|     const int len = xvt_sys_get_profile_string(prawin, "Main", "Study", "", __ptprf, sizeof(__ptprf)); | ||||
|     int len = 0; | ||||
| #ifdef LINUX | ||||
| 		good = FALSE; | ||||
| 		if (!_is_admin) | ||||
| 		{ | ||||
| 			char varname[80]; | ||||
| 			sprintf(varname, "Study[%s]", _c_user); | ||||
|     	len = xvt_sys_get_profile_string(prawin, "Main", varname, "", __ptprf, sizeof(__ptprf)); | ||||
|     	good = len > 0; | ||||
| 		} | ||||
| 		if (!good) | ||||
| 		{ | ||||
| #endif | ||||
|     	len = xvt_sys_get_profile_string(prawin, "Main", "Study", "", __ptprf, sizeof(__ptprf)); | ||||
|     	good = len > 0; | ||||
| #ifdef LINUX | ||||
| 		} | ||||
| #endif | ||||
|     if (good) | ||||
|     { | ||||
|       char firm[8]; | ||||
|       long ditta; | ||||
| #ifdef LINUX | ||||
| 	    char path[_MAX_PATH], user[80]; | ||||
| #endif | ||||
|      | ||||
|       if (__ptprf[len-1] != '\\' && __ptprf[len-1] != '/') | ||||
|       { | ||||
| @ -476,9 +498,16 @@ HIDDEN BOOLEAN CGetFirmDir() | ||||
|         __ptprf[len+1] = '\0'; | ||||
|       } | ||||
|        | ||||
|       xvt_sys_get_profile_string(prawin, "Main", "Firm", "COM", firm, sizeof(firm)); | ||||
| #ifdef LINUX | ||||
| 			strcpy(user, _c_user), | ||||
| 			xvt_str_make_lower(user); | ||||
| 			sprintf(path, "%sconfig%c%s.ini", __ptprf, DIRSEP, user); | ||||
|       len = xvt_sys_get_profile_string(path, "Main", "Firm", "", firm, sizeof(firm)); | ||||
| 			if (len == 0) | ||||
| #endif | ||||
|       	xvt_sys_get_profile_string(prawin, "Main", "Firm", "com", firm, sizeof(firm)); | ||||
|       ditta = atol(firm); | ||||
|       if (ditta > 0) sprintf(firm, "%05ldA", ditta); | ||||
|       if (ditta > 0) sprintf(firm, "%05lda", ditta); | ||||
|       xvt_fsys_build_pathname(cprefix, NULL, __ptprf, firm, NULL, NULL); | ||||
|     }    | ||||
|   }   | ||||
| @ -489,7 +518,26 @@ HIDDEN BOOLEAN CGetFirmDir() | ||||
| BOOLEAN CPutFirmDir(const char* pref) | ||||
| {            | ||||
|   const char* prawin = CGetCampoIni(); | ||||
| #ifdef LINUX | ||||
|   char path[_MAX_PATH], user[80]; | ||||
| 
 | ||||
| 	strcpy(user, _c_user), | ||||
| 	xvt_str_make_lower(user); | ||||
| 	sprintf(path, "%sconfig%c%s.ini", __ptprf, DIRSEP, user); | ||||
|   BOOLEAN good = xvt_sys_set_profile_string(path, "Main", "Firm", pref); | ||||
| #else | ||||
|   BOOLEAN good = xvt_sys_set_profile_string(prawin, "Main", "Firm", pref); | ||||
| #endif | ||||
| 
 | ||||
| #ifdef LINUX | ||||
| 	if (!_is_admin) | ||||
| 	{ | ||||
| 		char varname[80]; | ||||
| 		sprintf(varname, "Study[%s]", _c_user); | ||||
|    	xvt_sys_set_profile_string(prawin, "Main", varname, __ptprf); | ||||
|  	} | ||||
|   else | ||||
| #endif | ||||
| 	  xvt_sys_set_profile_string(prawin, "Main", "Study", __ptprf); | ||||
|   return good; | ||||
| } | ||||
| @ -516,7 +564,7 @@ const char* CGetPref() | ||||
| {                     | ||||
|   if (!CGetFirmDir())  | ||||
|   {           | ||||
| 		strcpy(cprefix, "COM"); | ||||
| 		strcpy(cprefix, "com");  | ||||
|     CPutFirmDir(cprefix); | ||||
|   }   | ||||
|   return cprefix; | ||||
|  | ||||
							
								
								
									
										1276
									
								
								include/codeb.c
									
									
									
									
									
								
							
							
						
						
									
										1276
									
								
								include/codeb.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -61,7 +61,7 @@ unsigned int color_distance(COLOR col1, COLOR col2) | ||||
|   const int g2 = XVT_COLOR_GET_GREEN(col2); | ||||
|   const int b2 = XVT_COLOR_GET_BLUE(col2); | ||||
| 	const int r = abs(r1-r2); | ||||
| 	const int g = abs(g1-b2); | ||||
| 	const int g = abs(g1-g2); | ||||
| 	const int b = abs(b1-b2); | ||||
|   return (r > g && r > b) ? r : (g > b ? g : b); | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user