Indice |
Preparativi Creare un tipo file personalizzato Icona Riconoscimento dei file Descrizione Applicazione preferita Attributi Extra Indicizzazione Inserire i dati Interrogare il database |
Workshop: tipi di file, attributi, indici e interrogazioni
Questo è un workshop, una sezione in cui verrà mostrato l'uso degli Attributi, delle Interrogazioni, dell'Indice del filesystem e dei Tipi di File. Si costruirà a titolo di esempio un database per tenere traccia di una collezione di DVD.
Preparativi
Innanzi tutto, devi decidere di che attributi e tipo di file hai necessità. All'inizio, l'idea era di usare un file di segnalibri con i collegamenti al sito IMdB, ma all'epoca il browser di Haiku non aveva il supporto per i segnalibri a differenza di NetPositive, il browser del BeOS. La soluzione (più ragionevole) che è stata scelta è allora la seguente: il file sarà un'immagine JPEG che rappresenta la copertina del film.
WebPositive adesso supporta i file di segnalibri, così l'idea iniziale può ora, se preferisci, essere realizzata.
In ogni caso, andremo ad aggiungere al file un paio di attributi. È in questa fase in cui dovremo decidere se vogliamo riservarci la possibilità di interrogare il file successivamente (e in questo caso dovremo aggiungerlo all'indice) e, in caso affermativo, stabilire di che tipo saranno i nuovi attributi. Ricorda che i numeri (int, float) possono essere valutati differentemente dal testo (</=/> oppure is/contains/starts with).
Ecco alcuni attributi utili per classificare i DVD:
- Titolo del film
- Genere
- URL, per esempio, su IMdB
- Direttore e Regia
- Trama
- Il proprio giudizio da 1 a 10
- Coordinate nello scaffale, ad esempio A2, B3, in modo da reperire i DVD anche nella realtà
- Se e a chi è stato prestato il DVD
Creare un tipo file personalizzato
Prima di tutto, apri il pannello delle preferenze Tipi di File cliccando sul pulsante sotto la lista gerarchica a sinistra. Si aprirà una piccola finestra di dialogo dove verrà richiesto tra quali MIME Group verrà collocato il filetype, è sufficiente scegliere "applicazioni" impostando il nome interno come DVDdb. Ricorda che è anche possibile creare un gruppo completamente nuovo.
A questo punto si aprirà un pannello per il nuovo tipo file DVDdb:
Icona
Facendo doppio clic sull'icona si aprirà Icon-O-Matic che permette di disegnare un'icona per il proprio tipo file. È anche possibile trascinare sopra un'icona da un altro tipo, da usare magari come punto di partenza per crearne una versione modificata.
Riconoscimento dei file
È possibile specificare dei suffissi come .txt, .jpg, .mp3 in modo da permettere l'identificazione dei file a partire dalla loro estensione. Questo può risultare utile quando si ha a che fare con file di sistemi che non prevedono il MIME Type. Non è necessario fare uso dei suffissi ai fini dell'esempio.
Descrizione
- Type Name - Apparirà ad esempio nel menù Attributi della finestra del Tracker e come attributo "Tipo" di un file.
- Descrizione - Una descrizione un po' più dettagliata.
Applicazione preferita
Questo menù pop-up mostra una lista di tutte le applicazioni che supportano questo particolare tipo file. Da qui è possibile selezionare quale programma dovrà aprire il file specifico quando ci si effettuerà un doppio click.
apre una finestra di dialogo dove è possibile selezionare un'applicazione per aprire il tipo di file. Nel nostro esempio è stato impostato ShowImage per visualizzare la copertina del DVD. | ||
apre una finestra di dialogo dove è possibile selezionare qualsiasi file che abbia già come applicazione preferita quella che si sta cercando. |
Attributi Extra
Questo è il luogo dove verranno inseriti tutti gli attributi personalizzati stabiliti durante la preparazione. Cliccando sul pulsante
si aprirà il pannello per l'inserimento di tutti i dati relativi al nuovo attributo. Puoi modificare un attributo esistente con un doppio click.Nome Attributo - Appare, ad esempio, come colonna in alto nella finestra di Tracker.
Nome Interno - È utilizzato per indicizzare l'attributo.
- Type - Defines the value the attribute can hold and therefore how it can be queried.
- for normal text
- for binary data: 0 (false) or >=1 (true)
- : -128 to 127
- : -32,768 to 32,767
- : -2,147,483,648 to 2,147,483,647
- : -9,223,372,036,854,775,808 to 9,223,372,036,854,775,807
for integer numbers with different ranges:
- for floating-point numbers, single precision
- for floating-point numbers, double precision
- for time and date format
- Visibile - Questa casella di controllo determina se l'attributo è visibile all'interno della finestra del Tracker. Dato che il Tracker si interfaccerà col database dei DVD, sarà necessario spuntare la casella e definire il loro aspetto con:
- - Può essere usata per mostrare uno o due simboli, vedi sotto.
- - Mostra un intero come 1/60, wa. "90" diventa "1:30".
- - Mostra una valurazione da zero a dieci, visualizzata con l'ausilio di stelline.
- Lasciare su "Predefinito" se i valori dovranno essere visualizzati coerentemente al tipo dell'attributo (es. stringa/intero/virgola mobile). Le altre opzioni disponibili sono:
- - Determina se l'attributo è modificabile attraverso il Tracker.
- - Definiscei due simboli da utilizzare per la visualizzazione della casella di spunta. Per esempio, "xo" mostrerà una "x" per tutti i valori >0 e "o" per lo 0.
- - La larghezza predefinita della colonna dell'attributo nelle finestre del Tracker.
- - L'attributo può essere visualizzato a sinistra, centrato o a destra.
Ora, bisogna inserire tutte le informazioni sugli attributi:
Nome interno | Tipo attributo | Indicizzato? | Descrizione |
---|---|---|---|
DVDdb:titolo | testo | si | Titolo del film |
DVDdb:genere | testo | si | Genere |
DVDdb:url | testo | no | URL |
DVDdb:cast | testo | si | Direttore e Regia |
DVDdb:trama | testo | no | Trama |
DVDdb:voto | intero - 32 bit | si | Voto da 1 a 10 |
DVDdb:coordinate | testo | no | Scaffale |
DVDdb:prestato | testo | si | Prestato a |
Indicizzazione
Prima di iniziare con l'immissione dei dati nel piccolo database dei DVD, è necessario aggiungere gli attributi all'Indice, solo gli attributi indicizzati potranno essere raggiunti da Haiku tramite una Interrogazione.
Allora, cosa si dovrà cercare in futuro? Probabilmente non ci si chiederà "Cosa c'è nella coordinata B4 dello scaffale?" o "In quale film la parola 'pope-shenooda' è contenuta nell'url di IMdB o nella trama?".
Questa scelta porta a usare solo questi attributi:
Nome interno | Tipo attributo |
---|---|
DVDdb:titolo | testo |
DVDdb:genere | testo |
DVDdb:cast | testo |
DVDdb:voto | intero - 32 bit |
Per indicizzarli, si deve aprire un terminale aggiungendo semplicemente un attributo dopo l'altro:
mkindex -t string DVDdb:title mkindex -t string DVDdb:genre mkindex -t string DVDdb:cast mkindex -t int DVDdb:rating
L'opzione -t specifica il tipo dell'attributo, in questo caso "string" per tutti, fa eccezione il voto che è un numero intero.
Inserire i dati
Ora che tutto è sistemato, è possibile cominciare ad inserire alcuni dati all'interno del database.
Dal momento che il file di base è l'immagine della copertina, ci si collegherà a qualche risorsa online come IMdB per reperire la copertina o la locandina del primo film salvandola in una nuova cartella dove si vuole posizionare il database dei file DVDdb.
Aprendo questa cartella ci si troverà davanti la solita finestra di Tracker contenente un file JPEG. Cliccandoci su col tasto destro, è possibile impostare il suo filetype come application/DVDdb con l' Addon Filetype. Maggiori informazioni sull'argomento sono reperibili nel capitolo sui Tipi di File.
A questo punto è necessario attivare tutti gli attributi di DVDdb dal menù
della finestra di Tracker e risistemare a piacere le colonne:Cliccando su un attributo ancora vuoto (o premendo ALT E) si passa alla modalità per la modifica nella quale è possibile inserire ciascun attributo. È possibile spostarsi tra gli attributi con la scorciatoia TAB e SHIFT TAB.
Nell'esempio visto, solitamente si cominciava scaricando un file JPG e cambiando il suo filetype in applications/DVDdb. Esiste un altro metodo elegante per produrre analoghi risultati. Basta copiare un file vuoto che abbia il filetype desiderato in /boot/home/config/settings/Tracker/Tracker New Templates e rinominarlo come DVDdb.
Cliccando col tasto destro all'interno della finestra di Tracker ci sarà una nuova voce sotto
accanto alla voce predefinita "New folder".Effettuare interrogazioni al database
Dopo un paio d'ore di duro lavoro, si avrà un piccolo database nel quale è possibile ricercare tutti i film di Christina Ricci che hanno un bel 7+...
È possibile determinare il layout dei risultati di uno specifico tip di file.
Per fare questo aprire la cartella contenente i file DVDdb e sistemare a piacere i risultati come dovrebbero essere presentati. Infine copiare questo layout con .
Open /boot/home/config/settings/Tracker/DefaultQueryTemplates, create a new folder and rename it to group/filetype, replacing slashes with underscores; in our case "application_DVDdb".
Per finire si apra una nuova cartella e ci si incolli il layout con
. Ed ecco il risultato: