Differenze tra le versioni di "Caricare i dati di un vettore scritto in C in un vettore di un'applicazione Gambas"

Da Gambas-it.org - Wikipedia.
Riga 1: Riga 1:
Se si ha un codice sorgente, scritto in C, nel quale vi è una variabile vettoriale ''globale'' istanziata con dei valori, per assumere e caricare tali valori in una variabile vettoriale di un'applicazione Gambas senza che vengano ricopiati manualmente nel codice sorgente di tale applicazione, si potrà copiare - qualora siano presenti anche altri simboli e risorse - la variabile vettoriale del sorgente C in un nuovo sorgente scritto sempre in linguaggio C, aggiungendovi anche una semplice funzione che restituisca la dimensione del vettore (ossia la quantità di byte/valori contenuti) e finalmente trasformata in un'apposita libreria dinamica condivisa .so da richiamare nell'applicazione Gambas.
+
Se si ha un codice sorgente, scritto in C, nel quale vi è una variabile vettoriale ''globale'' istanziata con dei valori, per assumere e caricare tali valori in una variabile vettoriale di un'applicazione Gambas senza che vengano ricopiati manualmente nel codice sorgente di tale applicazione, si potrà generare dal codice sorgente, scritto in C, un'apposita libreria dinamica condivisa .so da richiamare nell'applicazione Gambas.
  
  
 
Mostriamo di seguito un semplice esempio.
 
Mostriamo di seguito un semplice esempio.
  
Poniamo il caso che i dati della variabile vettoriale del codice sorgente C siano i seguenti:
+
Poniamo il caso che la variabile vettoriale del codice sorgente C con i suoi valori contenuti sia la seguente:
 
  unsigned char vettore_C[] = {
 
  unsigned char vettore_C[] = {
 
     0x70, 0x7d, 0x86, 0x9a, 0xac, 0xb8, 0xbc, 0xc5,
 
     0x70, 0x7d, 0x86, 0x9a, 0xac, 0xb8, 0xbc, 0xc5,
Riga 10: Riga 10:
 
  };
 
  };
  
Dal codice sorgente, nel quale è presente il predetto vettore, si genererà un'apposita libreria esterna dinamica condivisa .so . L'area di memoria del vettore, poi, sarà puntata in Gambas con il meotodo ''GetExternSymbol()'' della Classe ''System''. Ottenuto il relativo ''Puntatore'' a quell'area di memoria, poiché nel nostro caso non esistono valori uguali a zero, si leggerà all'interno dell'area medesima sino a quando non si giungerà al primo valore pari a zero, che rappresenta così l'uscita dall'area di memoria del vettore. Ad ogni modo, se si conosce (come nel nostro esempio) la quantità di elementi costituenti l'array del sorgente C, sarà ovviamente molto agevole leggere tutti i valori contenuti, utilizzando un ciclo ''For...Next'' .
+
Dal codice sorgente, nel quale è presente il predetto vettore, si genererà a parte - come già detto - un'apposita libreria esterna dinamica condivisa .so . L'area di memoria del vettore, poi, sarà puntata in Gambas con il meotodo ''GetExternSymbol()'' della Classe ''System''. Ottenuto il relativo ''Puntatore'' a quell'area di memoria, poiché nel nostro caso non esistono valori uguali a zero, si leggerà all'interno dell'area medesima sino a quando non si giungerà al primo valore pari a zero, che rappresenta così l'uscita dall'area di memoria del vettore. Ad ogni modo, se si conosce (come nel nostro esempio) la quantità di elementi costituenti l'array del sorgente C, sarà ovviamente molto agevole leggere tutti i valori contenuti, utilizzando un ciclo ''For...Next'' .
 +
<BR>Poniamo il caso che la libreria esterna .so, generata, si chiami Lib_C.so.
 
  '''Public''' Sub Main()
 
  '''Public''' Sub Main()
 
   
 
   
Riga 16: Riga 17:
 
   Dim i As Integer
 
   Dim i As Integer
 
   Dim bb As New Byte[]
 
   Dim bb As New Byte[]
 
+
 
  <FONT Color=gray>' ''Generiamo l'apposita libreria dinamica condivisa .so:''</font>
+
  <FONT Color=gray>' ''Puntiamo all'area di memoria della variabile vettoriale ora contenuta dall'apposita libreria dinamica .so:''</font>
 +
  p = System.GetExternSymbol("''/percorso/della/libreria/esterna/Lib_C", "vettore_C")
 +
  If IsNull(p) Then Error.Raise("Puntatore NULLO !")
 +
 
 +
<FONT Color=gray>' ''Leggiamo dall'area di memoria della variabile vettoriale contenuta dallalibreria dinamica .so, fino a che il valore letto non sia zero''
 +
' ''ed assegnamo i valori, così letti, alla variabile vettoriale dell'applicazione Gambas:''</font>
 +
  While Byte@(p + i) > 0            <FONT Color=gray>' oppure nel nostro caso: For i = 0 To 15</font>
 +
    bb.Push(Byte@(p + i))            <FONT Color=gray>'                          bb.Push(Byte@(p + i))</font>
 +
    Inc i                            <FONT Color=gray>'                        Next</font>
 +
  Wend
 +
     
 +
<FONT Color=gray>' ''Vediamo semplicemente in console la quantità di elementi del vettore istanziati:''</font>
 +
  Print bb.Count
 +
 +
'''End'''
 +
 
 +
 
 +
Nel caso in cui, invece, la dichiarazione e la definizione dell'array sia presente in un file ''header'' C, allora si potrà creare un file sorgente in C ove sia posta la direttiva ''#include'' con il percorso del predetto file ''header'', e sia inserita anche la dichiarazione (come globale) del vettore che deve essere richiamato.
 +
 
 +
Poi il codice Gambas sarà il seguente:
 +
  '''Public''' Sub Main()
 +
 +
  Dim p As Pointer
 +
  Dim i As Integer
 +
  Dim bb As New Byte[]
 +
 
   CreaSo()
 
   CreaSo()
+
 
 
  <FONT Color=gray>' ''Puntiamo all'area di memoria della variabile vettoriale ora contenuta dall'apposita libreria dinamica .so:''</font>
 
  <FONT Color=gray>' ''Puntiamo all'area di memoria della variabile vettoriale ora contenuta dall'apposita libreria dinamica .so:''</font>
   p = System.GetExternSymbol("/tmp/Lib_C", "vettore_C")
+
   p = System.GetExternSymbol("''/percorso/della/libreria/esterna/Lib_C", "vettore_C")
 
   If IsNull(p) Then Error.Raise("Puntatore NULLO !")
 
   If IsNull(p) Then Error.Raise("Puntatore NULLO !")
 
    
 
    
Riga 35: Riga 61:
 
   
 
   
 
  '''End'''
 
  '''End'''
 
 
 
   
 
   
 
  '''Private''' Procedure CreaSo()
 
  '''Private''' Procedure CreaSo()
 
   
 
   
   File.Save("/tmp/Lib_C.c", "unsigned char vettore_C[] = {" &
+
   File.Save("''/percorso/del/file/sorgente/della/libreria''", "#include <''/percorso/del/file/header.h>''" &
                            "0x70, 0x7d, 0x86, 0x9a, 0xac, 0xb8, 0xbc, 0xc5," &
+
                             "\n\nunsigned char vettore_C[];")
                             "\n0x9d, 0xba, 0xd5, 0xe9, 0xf7, 0xfd, 0xfd, 0xf2\n};")
 
 
      
 
      
   Shell "gcc -o /tmp/Lib_C.so /tmp/Lib_C.c -shared" Wait
+
   Shell "gcc -o ''/percorso/della/libreria/esterna.so'' ''/percorso/del/file/sorgente/della/libreria/esterna.c'' -shared" Wait
 
    
 
    
 
  '''End'''
 
  '''End'''

Versione delle 02:46, 28 ago 2015

Se si ha un codice sorgente, scritto in C, nel quale vi è una variabile vettoriale globale istanziata con dei valori, per assumere e caricare tali valori in una variabile vettoriale di un'applicazione Gambas senza che vengano ricopiati manualmente nel codice sorgente di tale applicazione, si potrà generare dal codice sorgente, scritto in C, un'apposita libreria dinamica condivisa .so da richiamare nell'applicazione Gambas.


Mostriamo di seguito un semplice esempio.

Poniamo il caso che la variabile vettoriale del codice sorgente C con i suoi valori contenuti sia la seguente:

unsigned char vettore_C[] = {
   0x70, 0x7d, 0x86, 0x9a, 0xac, 0xb8, 0xbc, 0xc5,
   0x9d, 0xba, 0xd5, 0xe9, 0xf7, 0xfd, 0xfd, 0xf2
};

Dal codice sorgente, nel quale è presente il predetto vettore, si genererà a parte - come già detto - un'apposita libreria esterna dinamica condivisa .so . L'area di memoria del vettore, poi, sarà puntata in Gambas con il meotodo GetExternSymbol() della Classe System. Ottenuto il relativo Puntatore a quell'area di memoria, poiché nel nostro caso non esistono valori uguali a zero, si leggerà all'interno dell'area medesima sino a quando non si giungerà al primo valore pari a zero, che rappresenta così l'uscita dall'area di memoria del vettore. Ad ogni modo, se si conosce (come nel nostro esempio) la quantità di elementi costituenti l'array del sorgente C, sarà ovviamente molto agevole leggere tutti i valori contenuti, utilizzando un ciclo For...Next .
Poniamo il caso che la libreria esterna .so, generata, si chiami Lib_C.so.

Public Sub Main()

 Dim p As Pointer
 Dim i As Integer
 Dim bb As New Byte[]
  
' Puntiamo all'area di memoria della variabile vettoriale ora contenuta dall'apposita libreria dinamica .so:
  p = System.GetExternSymbol("/percorso/della/libreria/esterna/Lib_C", "vettore_C")
  If IsNull(p) Then Error.Raise("Puntatore NULLO !")
  
' Leggiamo dall'area di memoria della variabile vettoriale contenuta dallalibreria dinamica .so, fino a che il valore letto non sia zero
' ed assegnamo i valori, così letti, alla variabile vettoriale dell'applicazione Gambas:
  While Byte@(p + i) > 0             ' oppure nel nostro caso: For i = 0 To 15
    bb.Push(Byte@(p + i))            '                           bb.Push(Byte@(p + i))
    Inc i                            '                         Next
  Wend
     
' Vediamo semplicemente in console la quantità di elementi del vettore istanziati:
  Print bb.Count

End


Nel caso in cui, invece, la dichiarazione e la definizione dell'array sia presente in un file header C, allora si potrà creare un file sorgente in C ove sia posta la direttiva #include con il percorso del predetto file header, e sia inserita anche la dichiarazione (come globale) del vettore che deve essere richiamato.

Poi il codice Gambas sarà il seguente:

  Public Sub Main()

 Dim p As Pointer
 Dim i As Integer
 Dim bb As New Byte[]

  CreaSo()
  
' Puntiamo all'area di memoria della variabile vettoriale ora contenuta dall'apposita libreria dinamica .so:
  p = System.GetExternSymbol("/percorso/della/libreria/esterna/Lib_C", "vettore_C")
  If IsNull(p) Then Error.Raise("Puntatore NULLO !")
  
' Leggiamo dall'area di memoria della variabile vettoriale contenuta dallalibreria dinamica .so, fino a che il valore letto non sia zero
' ed assegnamo i valori, così letti, alla variabile vettoriale dell'applicazione Gambas:
  While Byte@(p + i) > 0             ' oppure nel nostro caso: For i = 0 To 15
    bb.Push(Byte@(p + i))            '                           bb.Push(Byte@(p + i))
    Inc i                            '                         Next
  Wend
     
' Vediamo semplicemente in console la quantità di elementi del vettore istanziati:
  Print bb.Count

End

Private Procedure CreaSo()

  File.Save("/percorso/del/file/sorgente/della/libreria", "#include </percorso/del/file/header.h>" &
                            "\n\nunsigned char vettore_C[];")
   
  Shell "gcc -o /percorso/della/libreria/esterna.so /percorso/del/file/sorgente/della/libreria/esterna.c -shared" Wait
  
End