SMF - Just Installed!
|
Se non siete riusciti a reperire l'informazione che cercavate nei nostri articoli o sul nostro forum vi consiglio di visitare il Forum ufficiale di Lazarus in lingua inglese. Benvenuto! Effettua l'accesso oppure registrati.Hai perso l'e-mail di attivazione? Maggio 20, 2012, 03:07:14 amInserisci il nome utente, la password e la durata della sessione.
|
5 Visitatori,
0 Utenti
http://www.lazaruspascal.it/esempi/ExtGrid_Example.zip
Codice: [Seleziona]
Codice: [Seleziona]
Codice: [Seleziona]
Codice: [Seleziona]
Codice: [Seleziona]
Browser -> Server -> Browser Codice: [Seleziona]
22 Apr 2012 - Zeos ... dietro le quinte (prima parte)
Ciao a tutti.
Mi cimento per la prima volta a scrivere un articolo, quindi abbiate pietà di me :D Bando alle ciancie. Con questa primo articolo mi prefiggo di rendervi autonomi nel lancio delle query per interrogare il DB. Transazioni e modifiche dei dati saranno oggetto di un'altro articolo, per evitare di mettere troppa carne al fuoco sin da subito. ZEOS è una libreria molto potente nel suo insieme, spesso la si usa come alternativa ai driver Express Borland/Codegear/Embarcadero. La paragono a DBExpress visto che cambiando qualche parametro, si cambia il DB Engine target dell'applicazione. Le altre soluzioni prevedono il cambio di componenti di connettività (se va bene, solo quelli). I componenti di connettivita e data aware di VCL/LCL coprono la maggior parte delle esigenze per le applicazioni classiche. ZEOS permette di gestire agilmente anche le situazioni non proprio ortodosse. In questo articolo, cercherò di fare una panoramica su come utilizzare ZEOS in modo ... low level programming, se mi passate l'espressione, in modo da poter gestire queste situazioni. Chi lo ha installato su Lazarus ha notato che ci sono diversi pacchetti che vengono compilati, ma solo uno viene installato, per l'appunto zcomponent.lpk. Questo pacchetto dipende da altri 4: zcore.lpk Contiene classi e interfaccie utilizzate da tutti gli altri pacchetti. Una sorta di libreria base. zparsesql.lpk Questo pacchetto contiene delle librerie di aiuto per i vari DB Engine. Chi ha lavorato o smanettato con almeno due DBEngine, sa che sono molte le estensioni che ogni motore aggiunge. Per verificare, controllate le specifiche di liguaggio di due engine open source, Firebird e MySQL. zplain.lpk Plan è il pacchetto che contiene tutti i Wrapper alle librerie (dll, so e così via) messe a disposizione dai vari DB per connettersi. E' qui che dovreste mettere il vostro "driver" il giorno che scriverete il vostro DB Engine. Se non trovate il file ZPlanXXXX.pas vuol dire che ZEOS non supporta quel DB Engine. Esempio per tutti DB2. Zeos non supporta (per questioni di licenza) IBM DB2 Eventualmente una disamina sull'anatomia del driver può essere interessante, ma ai nostri fini è solo accademica. zdbc.lpk Questo è il cuore pulsante di ZEOS. Per poter accedre a questo pacchetto dal nostro codice, basta includere una unit :ZDBCIntfs. Per "accendere" il motore di ZEOS Low Level, basta una semplice chiamata: var Connection : IZConnection; .. Connection := DriverManager.GetConnection(connectionURL); Per spegnerlo Connection.Close; Connection := nil; Connection URL è una stringa che deve contenere alcune informazioni semplici, faccio subito un esempio pratico: 'zdbc:sqlite-3:/path_e_file_sqlite' Come potete notare sembra un indirizzo di rete, e in effetti si ispira proprio a quella sintassi. [Protocollo]:[Driver]:[Driver data]. Per gli indirizzi di rete, il formato è protocollo:host[:port]:[percorso della risorsa]. (Il formato string "URL" prevede anche altri parametri, tipo user name, per protocolli di rete diversi dall'HTTP e HTTPS) Per chi usa altri linguaggi, ad esempio Java, si renderà contro immediatamente che è lo stesso modo per utilizzare i driver JDBC, ed in effetti ha moltissime funzionalità esportate come in JDBC. Quindi (anche se non dichiarato) è un framework compatibile con le specifiche ODBC per UNIX (un sotto insieme di ODBC per Microsoft). Torniamo a ZEOS dopo questa piccola digressione. Cerchiamo una corrispondenza tra il componente TZConnection e i pezzi della stringa di connessione (basta che trascinate un componente ZConnection su di una Form/DataModule). Per la lista di Driver supportati dalla vostra installazione in Lazarus, consultate la proprietà protocol. (Qui il nome della property è forviante, ma hanno scelto questo nome). Per la risorsa (parametro specifico per l'engine) è la property Database. Per un SQLITE basterà mettere il nome del file da utilizzare come DB, per un Firebird, il file o l'alias configurato. Per un Oracle il SID, MySQL ... Come vedete, fino a qui, al posto di utilizzare il componente TZConnection, ci sono due righe di codice. A questo non si è ancora visto nulla di nuovo, apparentemente solo un modo più "difficile" di fare le cose. Lanciamo la nostra prima query, chiediamo a SQLITE quali sono le tabelle nel db: var statement:IZStatement; cursore :IZResultSet; begin [...] statement := FConnection.CreateStatement; cursore := stmt.ExecuteQuery('SELECT tbl_name FROM SQLITE_MASTER WHERE (type=''table'') AND (NOT tbl_name LIKE ''sqlite_%'') ORDER BY tbl_name'); E per chiudere il cursorse: cursore := nil; stmt := nil; Come si potrà notare non c'è bisogno di componenti (quindi il nostro programma avrà bisogno di meno Ram/Spazio su disco). Il modo di fare la fatch del cursore è semplicissimo: while rs.next do begin [...] end; Quindi, rispetto ai componenti classici, non c'è bisogno di fare un : while not cursore.EOF do begin [...] cursore.NEXT; end; Non so voi, ma dimentico spesso l'ultima riga :D Come si accede alle colonne? cursor.get[xxxxx](indice). o cursor.get[xxxxx]ByName(nome della colonna). la sintassi è molto diversa da quella a cui siamo abituati con i componenti classici. cursor.Fields[indice].as[xxxx] cursor.FieldByName(nome).as[xxxx] Altra differenza: con ZEOS le colonne iniziano da 1 e non da 0 come verrebbe da pensare. Piccolo esempio completo di lettura dei dati di un DB SQLITE: procedure TMainModel.loadDatabase(); var stmt :IZStatement; rs :IZResultSet; begin stmt := FConnection.CreateStatement; rs := stmt.ExecuteQuery('SELECT tbl_name FROM SQLITE_MASTER WHERE (type=''table'') AND (NOT tbl_name LIKE ''sqlite_%'') ORDER BY tbl_name'); while rs.Next do begin loadTable(rs.GetStringByName('tbl_name')); end; rs := nil; stmt := nil; End; procedure TMainModel.loadTable(const nomeTabella : String); { Qui puoi caricare i dati in una qualche maniera, a te conveniente, in memoria, porto come esempio, lo scrivere a console tutte le colonne in modo che vengano interpreatate come stringa. (Non sapendo a priori il tipo). Eventualmente puo fare un'operazione analoga caricando i dati in un documento XML. } var fieldIdx :Integer; stmt :IZStatement; rs :IZResultSet; rsMeta :IZResultSetMetadata; begin Writeln('Tabella',nomeTabella); try stmt := FConnection.CreateStatement; RS := stmt.ExecuteQuery(Format('SELECT * FROM %s',[nomeTabella])); rsMeta := rs.GetMetadata; while RS.Next do begin for fieldIdx := 1 to rsMeta.GetColumnCount do begin Writeln(rsMeta.GetColumnLabel(fieldIdx)),'=', rs.GetString(fieldIdx)); end; end; finally rsMeta := nil; rs := nil; stmt := nil; end; end;
http://code.google.com/p/extpascal/wiki/GettingStarted Download di ExtJs
http://www.sencha.com/products/extjs/download/ext-js-3.2.1 Download di ExtPascal
http://code.google.com/p/extpascal/downloads/list
http://code.google.com/p/extpascal/wiki/GettingStarted Citazione
Citazione
Citazione
Citazione
- /usr/lib/lazarus/0.9.28.2/components/indy/lazarus/lib/ - /usr/lib/lazarus/0.9.28.2/components/ExtPascal-0.9.8/ Citazione
Codice: [Seleziona]
Ultime impostazioni / Last settings
Lancio! / Run!
Codice: [Seleziona]
http://localhost:8080/Home ExtPascal toolkit
http://wiki.lazarus.freepascal.org/OrphPort
extp_ctrls/extp_ctrls.lpk extp_proj/extp_proj.lpk orpheus/orpheus.lpk extp_grid/extp_grid.lpk
Configurare Apache / Configure Apache
http://www.fastcgi.com/dist/mod_fastcgi-2.4.6-AP22.dll
Codice: [Seleziona]
Codice: [Seleziona]
Codice: [Seleziona]
Hello world
File --> New --> ExtPascal Application
Codice: [Seleziona]
Codice: [Seleziona] (Windows) Codice: [Seleziona]
http://localhost/cgi-bin/project1.exe (Windows) http://localhost/cgi-bin/project1 (Linux)
xinyiman e nomorelogic
15 Mar 2012 - ExtPascal: panoramica sulle licenzeVolendo sviluppare per web con lazarus, una delle possibili opzioni è
nell'uso delle librerie ExtJs tramite l'uso di ExtPascal. Allo scopo, ho fatto un piccolo approfondimento sulle licenze delle librerie in questione. ExtPascal Licenza LGPL e cioè: GNU LIBRARY GENERAL PUBLIC LICENSE - Version 2 - June 1991, modificata. La LGPL (la troviamo nel file "ExtP Toolkit/COPYING.LGPL") ci permette di utilizzare la libreria coperta da questa licenza senza imporre che il software da realizzare venga rilasciato sotto la medesima (nonostante permanga l'obbligo di fornire il sorgente se richiesto). In pratica viene lasciata libertà di scelta di licenziare sia con la LGPL stessa che con una licenza commerciale che di usare una GPL. Da sottolineare che gli sviluppatori di ExtPascal hanno ritenuto opportuno applicare la stessa licenza che deve essere applicata al software creato con Free Pascal e in caso di uso della RTL. Cito la modifica di ExtPascal Citazione
La quale differisce, rispetto a quella del Free Pascal, come si legge nel sito http://www.freepascal.org/faq.var#general-license, solamente nella sintassi del penultimo passaggio. Citazione
CodePress Nella cartella di ExtPascal troviamo anche CodePress. Come è possibile rilevare direttamente dal sito http://codepress.sourceforge.net/ anche CodePress viene rilasciato con licenza LGPL, senza modifiche. ExtJs Infine la libreria sulla quale tutto si basa: ExtJs. ExtJs viene rilasciato in triplice licenza, per maggiorni informazioni consiglio di leggere in http://www.sencha.com/products/extjs/license/ dove tutto viene spiegato molto approfonditamente. Prima licenza: Commercial Software License E' la licenza da utilizzare nel caso si intenda sviluppare un prodotto commerciale (che non verrà coperto quindi da una GPL). E' una licenza nominativa ma con possibilità di riassegnazione nel caso venga utilizzata da una software house. Seconda licenza: Commercial OEM License E' la licenza da usare se si intende sviluppare un SDK od un "web application builder". Terza licenza: Open Source License La quale, ovviamente, obbliga lo sviluppatore a rilasciare il software realizzato sotto GPL. Buon lavoro nomorelogic 13 Mar 2012 - Lavorare con file in formato JSON con Lazarus
Written by nomorelogic
posted in How to
Marzo 13, 2012, 06:54:00 pm
0 Views
Rating: 0 (0 Rates)
Print
Si sente spesso parlare di file JSON e se ne sente spesso parlare
relativamente allo sviluppo su web in quanto basato sul linguaggio JavaScript (Standard ECMA-262 3ª edizione dicembre 1999). In realtà la sua vera natura - quella di essere un formato per l'interscambio di dati tra applicazioni - lo ha portato ad essere usato nei contesti più disparati nell'ambito della programmazione e, come si può desumere da "http://www.json.org/", oramai esistono librerie per moltissimi linguaggi di programmazione, incluso il FreePascal. Ha diverse mancanze rispetto all'XML. Ad esempio non ha il concetto di attributo e non è utilizzabile né con file XLST, né con file DTD. Ha però dalla sua la semplicità della rappresentazione delle strutture dati (e quindi facilità nel parsing) e la semplicità di essere letto e manipolato dagli esseri umani. Giusto per avere un primo e semplice approccio, segue un esempio in questo formato: Codice: [Seleziona] La semplicità salta subito all'occhio. Si tratta fondamentalmente di combinazioni nome/valore dove il valore, quando di tipo stringa, è delimitato dal doppio apice. Un accenno particolare va ai campi "email" ed "indirizzi" che in realtà sono rappresentazioni di array. Un array è delimitato dalle parentesi quadre e quando composto da una semplice lista di valori ("email") basta indicare gli elementi separati da una virgola. Quando invece l'array è composto da tipi strutturati ("indirizzi"), gli elementi vanno specificati tra parentesi graffe. Ora però, come esempio pratico, vorrei proporre l'uso di questo formato per la memorizzazione delle impostazioni necessarie ad una ipotetica applicazione dedicata all'aggiornamento dei database. Segue il contenuto del file "": database.def. Codice: [Seleziona] La libreria che andremo a provare l'ho stata scaricata dal sito http://code.google.com/p/superobject/downloads/list e per chi volesse saperne di più: http://www.progdigy.com/ Si tratta di sorgenti con doppia licenza: MPL o LGPL. Una volta decompresso il file superobjectv1.2.4.zip, avremo a disposizione 2 file sorgenti chiamati superobject.pas e superxmlparser.pas che si occupano rispettivamente del parsing dei file JSON ed XML. A corredo anche una serie di demo e di progetti test da studiare. Tra le demo, ci sono interessanti applicazioni con google search, RTTI e VirtualTreeView. Tornando al nostro ipotetico tool per l'aggiornamento di database, andiamo a creare, con Lazarus, una nuova applicazione. Tramite l'analizzatore progetti possiamo aggiungere la unit superobject.pas al nostro progetto (il tutto risiede in un unico file .PAS e non ci sono pacchetti da installare). Sulla form principale aggiungiamo: - un TEdit chiamato edDefPath ed impostiamo la proprietà Text con la fullpath del file database.def - un TButton - un TMemo chiamato Memo1 Torniamo al sorgente della form principale e, sotto implementation, mettiamo in "uses" superobject. Fatto questo, nella sezione public, dichiariamo: procedure ScanDef(FilePath: string; log: TStrings); segue il relativo codice: Codice: [Seleziona] Ultima cosa da ricordare, impostare il richiamo della procedura nell'evento double click di Button1: Codice: [Seleziona] a questo punto non resta che lanciare il tutto con F9 e cliccare su Button1. Se tutto è andato come doveva, vedrete popolare il Memo con le impostazioni lette dal file. Quello mostrato qui è solo un piccolo sottoinsieme delle possibilità che si hanno a disposizione con l'utilizzo di questa libreria; una volta iniziato a capire come funziona è possibile dare un'occhiata alle varie demo e al file README.html per scoprirne altre funzionalità. Buon Lavoro. nomorelogic |
Trascinare un file nel programma by xinyiman Recuperare codice HTML da pagina web by xinyiman Mandare mail con Lazarus by xinyiman Stabilire il sistema operativo by xinyiman Esempio lista in pascal by xinyiman File INI by xinyiman Codice di attivazione by xinyiman Realizzare programmi multilingua by xinyiman Lavorare con le directory by xinyiman Utilizzare Unità esterne by Loryea TTreeView by xinyiman TTreeview e Menu by xinyiman Generare controlli RUN-TIME by xinyiman LazReport, PDF ed immagini by xinyiman Intercettare tasti premuti by xinyiman Ampliare Lazarus by xinyiman Lazarus e la crittografia by xinyiman System Tray con Lazarus by xinyiman UIB: Unified Interbase by Microges2000 Il file: questo sconosciuto by Microges2000 Conferma di chiusura di un applicazione by xinyiman Liste e puntatori by Microges2000 Overload di funzioni by Microges2000 Funzioni a parametri variabili by Microges2000 Proprietà by Microges2000 Conversione numerica by Microges2000 TImage su Form e Panel by Maverich Indy gestiore server FTP lato Client by Maverich PopUpMenu sotto Pulsante (TSpeedButton) by Maverich Direttiva $macro by Microges2000 Toolbar by xinyiman Evidenziare voci TreeView by Maverich Visualizzare un file Html esterno by Maverich StatusBar - aggirare l'errore variabile duplicata by Maverich Da DataSource a Excel by xinyiman Le permutazioni by xinyiman Brute force by xinyiman Indy 10 - Invio email con allegati by Maverich La gestione degli errori in Lazarus by xinyiman Pascal Script by xinyiman Linux + Zeos + Firebird by xinyiman Dataset virtuale by xinyiman Overload di operatori by Microges2000 Lavorare con file in formato JSON con Lazarus by nomorelogic Zeos ... dietro le quinte (prima parte) by Stilgar Free Spider concetti base e prima applicazione by xinyiman L'oggetto request by xinyiman L'oggetto response by xinyiman L'oggetto TSpiderAction by xinyiman L'oggetto TSpiderTable by xinyiman L'oggetto TSpiderForm by xinyiman L'oggetto TSpiderPage by xinyiman Il ciclo di vita di una CGI by xinyiman Richieste simultanee by xinyiman Le sessioni utente by xinyiman Download/Upload File by xinyiman Smart Module Loading Design by xinyiman Performance by xinyiman Free Spider e database by xinyiman JQuery UI by xinyiman JQuery - Oggetto template by xinyiman JQuery - Oggetto JQGrid by xinyiman Redirect by xinyiman ExtPascal: panoramica sulle licenze by nomorelogic ExtPascal: Installazione e configurazione / ExtPascal: Installation and configuration by nomorelogic Le griglie in ExtPascal - ExtPascalToolkit / Grids into ExtPascal - ExtPascalToolkit by xinyiman Cos'è Lazarus by xinyiman Le condizioni by xinyiman Installare Lazarus by xinyiman Il pascal e primo programma by xinyiman Costanti e variabili by xinyiman Input di dati by xinyiman OR/AND by xinyiman Maggiore minore uguale by xinyiman Cicli by xinyiman Assegnazione e confronto by xinyiman Funzioni numeriche by xinyiman Funzioni sui caratteri by xinyiman Numeri casuali by xinyiman I vettori (array) by xinyiman Le matrici by xinyiman Le strutture e gli insiemi by xinyiman Procedure e funzioni by xinyiman File by xinyiman Le librerie by xinyiman Funzioni/procedure ricorsive by xinyiman I puntatori by xinyiman OOP e Classi by xinyiman Utenti
Stats
Utenti Online Users: 0 Guests: 5 Total: 5 |
Benvenuto!
Maggio 20, 2012, 03:07:14 am
