Italian community of Lazarus and Free Pascal

Programmazione => Componenti Aggiuntivi => Topic aperto da: tiberi72 - Ottobre 03, 2012, 09:45:41 am

Titolo: path del database
Inserito da: tiberi72 - Ottobre 03, 2012, 09:45:41 am
Ciao,
so che in questi giorni vi sto martellando, ma ho incontrato dei problemi che all'inizio neanche mi sognavo.
Ho sviluppato (come avrete ben capito) un programmino in lazarus e vorrei spostarlo su un altro pc.
Fino ad ora la path del database, impostata su un oggetto TIBConnection, era assoluta e puntava alla cartella dove sono memorizzati tutti i miei sorgenti.
Ora dovrei spostarla.
Ho provato ad utilizzare sul codice application.location, ma il programma segnala comunque errore perche' il percorso assoluto che utilizzo nel sorgente e' utilizzato anche nel file .lfm.
Come posso fare per inserire un percorso relativo direttamente nell'oggetto TIBConnection?

Voi di solito come avete risolto il problema?
Titolo: Re:path del database
Inserito da: nomorelogic - Ottobre 03, 2012, 02:40:05 pm
Con un file .ini
Titolo: Re:path del database
Inserito da: tiberi72 - Ottobre 04, 2012, 09:52:27 am
Con un file .ini
Penso di non essermi spiegato troppo bene: io ho i miei sorgenti (incluso il relativo db) in C:\Documents and Settings\Utente\Documenti\sorgenti\prova
Nel computer dove dovro' istallare il programma il db (che e' sempre nella stessa cartella dell'eseguibile) sara' nella cartella c:\prg\ .
il problema e' che quando vado sul computer definitivo il programma mi da errore per il database sul percorso C:\Documents and Settings\Utente\Documenti\sorgenti\prova\ (che ovviamente non esiste), anche se imposto il nome del database da sorgente con application.location + 'dati.fdb'
Titolo: Re:path del database
Inserito da: El Salvador - Ottobre 04, 2012, 02:29:01 pm
Citazione
Ho provato ad utilizzare sul codice application.location, ma il programma segnala comunque errore perche' il percorso assoluto che utilizzo nel sorgente e' utilizzato anche nel file .lfm.
Ma non riesci ad utilizzare i percorsi relativi e quindi modificare la proprietà del percorso in runtime, prima di usare il componente?
Titolo: Re:path del database
Inserito da: nomorelogic - Ottobre 04, 2012, 04:20:56 pm
se usi un TIBConnection vuol dire che usi Firebird
imposta un alias in aliases.conf

semplicemente con una riga
MYDB = c:\prg\database.fdb

nel componente, a design time, ci metti MYDB come percorso (oppure 127.0.0.1:MYDB) e dovrebbe funzionare

Certo è che a runtime qualcosa nella riassegnazione della path del DB non funziona :)
Titolo: Re:path del database
Inserito da: xinyiman - Ottobre 04, 2012, 04:49:36 pm
Mi sembra strano. A me ha sempre funzionato il metodo Application.Location


Prova a usare i file ini così dovresti risolvere il problema, spulcia gli how to. E' un argomento già trattato :)
Titolo: Re:path del database
Inserito da: Stilgar - Ottobre 04, 2012, 08:45:53 pm
Ciao,
 io uso un trucco molto semplice.
Siccome la connessione punta con l'ide al DB, ma poi voglio avere il controllo su quello che fa l'applicazione a runtime, uso 2 configurazioni.
Una a Design e una a Runtime.
La cosa importante è che la connessione all'avvio dell'applicazione sia off.
Altrimenti all'avvio prova a connettersi e va tutto a scatafascio.
Quindi imposto a runtime il mio bel path e attivo la connessione al DB.
Insomma, metà della roba che con l'ide posso fare la disabilito e connetto tutto a manina ;)
Database, DataSource.
Alla fine è un loop banalissimo. Sia in creazione che in distruzione dei componenti.
Altra cosa che faccio è spostare tutta la parte "backend" in di un DataModule.
Sovrascrivo il costruttore e il distruttore, in modo che connettano e sconnettano tutto.
Questo perchè non voglio incasinare altre parti dell'applicazione. D'altra parte è uno dei principi dell'incapsulamento della OOP :D
EDIT:
Altro vantaggio.
Se esplode qualche cosa in connessione è dentro il loop e non dentro i meccanismi sui quali non ho controllo ;)
Titolo: Re:path del database
Inserito da: tiberi72 - Ottobre 09, 2012, 10:39:58 am
Mi sembra strano. A me ha sempre funzionato il metodo Application.Location


Prova a usare i file ini così dovresti risolvere il problema, spulcia gli how to. E' un argomento già trattato :)
In effetti e' strano, perche' in alcuni casi, nonostante io imposti a false tutti i connected, mi da errore e non riesco a modificare il databasename perche' mi dice che e' gia' connesso.
In un programma di questi quando rivado in lazarus addirittura vedo nella tibconnection connected=true, mentre se apro con notepad il file .lfm vedo connected = false