Tags:
create new tag
view all tags
PROGETTOssario Metodologie di Programmazione A.A. 2009-2010

IMPORTANTE: Modalità di Consegna: il progetto va spedito per email entro le 24 del giorno precedente ogni appello scritto. E' possibile svolgere lo scritto ed il progetto in date differenti, purchè si resti nello stesso anno accademico. La discussione del progetto e dello scritto, che è parte integrante dell'esame, avverrà a seguito dell'ultima consegna. Per esempio, si può consegnare il progetto a Luglio e fare lo scritto a Settembre; in tal caso, però, la discussione SIA sul progetto CHE sullo scritto avverrà a Settembre. Ovviamente, nel caso di progetto svolto in gruppo, ogni studente farà storia a sè (cioè, dovrà discutere il progetto autonomamente a seguito della sua ultima consegna).

Tutti i sorgenti del progetto dovranno essere spedite per email come allegato in un file .zip a gorla@diNOSPAM.uniroma1.it, a fronte della quale si riceverà dal docente una conferma ESPLICITA della ricezione del messaggio. Se gli studenti non dovessero ricevere entro la data dello scritto tale conferma, sono autorizzati a ricontattare il docente. Il progetto deve essere perfettamente eseguibile (nessun altro file deve essere necessario).

SPECIFICA:

Il progetto consiste nella realizzazione di una piccola applicazione in Java per gestire un Sistema di Prenotazione di stanze in una catena di alberghi.

Si devono costruire e gestire (per uso interno) almeno due archivi, uno contenente i dati necessari dei clienti (cognome, nome, ecc.), ed uno con i dati (numero, piano, albergo, ecc.) delle stanze. All’inizio di ogni sessione, gli archivi sono costruiti utilizzando dati che vengono letti da file esterni. Alla fine (o prima della chiusura) della sessione, le informazioni sulle prenotazioni devono essere memorizzate per uso nella sessione successiva.

Il file che contiene le informazioni relative ad un albergo ha il seguente formato. Le prime 6 linee del file hanno il seguente formato:

ALBERGO
A
I
N1;N2;...;Nk
S

dove

ALBERGO La stringa "ALBERGO"
A Nome dell'albergo (una stringa)
I Indirizzo (una stringa)
N1;N2;...;Nk Recapiti telefonici (almeno uno),
S Servizi: una sequenza, eventualmente vuota, con i seguenti caratteri: 'R' ristorante, 'L' lavanderia, 'P' parcheggio, 'F' fotocopiatrice, 'S' servizio di segreteria, 'I' Internet

e poi una linea per ogni stanza con il seguente formato:

N;P;D;L;C;Q;T

dove

N : Numero stanza (un intero >= 1)
P : Piano (un intero >= 0)
D : Disponibilità (un carattere: 'D' disponibile, 'N' non disponibile)
L : Letti (1,2,3,.. oppure "M" per matrimoniale o "M+1" o "M+2", ecc. per matrimoniale più un letto, due letti, ecc.)
C : Caratteristiche (una sequenza, eventualmente vuota, dei seguenti caratteri: 'A' aria condizionata, 'T' televisore, 'B' mini-bar, 'I' connessione internet)
Q : Qualità (un carattere 'M' media qualità, 'L' lusso, 'U' superiore, 'S' suite)
T : Tariffa (un numero intero)

Esempio:

ALBERGO
Hotel Piazza di Spagna
via Mario de Fiori, 61 - Roma
06876744;068876565
RPI
11;1;D;1;ATB;M;80
12;1;D;2;ATB;M;90
15;1;N;1;BI;L;100
23;2;D;M;ATBI;U;120
24;2;D;M+1;AI;M;100
35;3;D;M+3;ATBI;S;200

Deve essere possibile aggiornare la disponibilità di un albergo (appena acquistato, per esempio, o appena riservato in blocco per un convegno) o delle stanze di un albergo (appena ristrutturate o che necessitano di nuovi mobili).

Ad ogni stanza è associato un insieme di clienti con le date di prenotazione, in aggiunta ad informazioni come numero, piano, albergo, tariffe, caratteristiche, disponibilità, ecc.

Ogni cliente è rappresentato da un oggetto della classe appropriata ed è caratterizzato da (almeno) cognome, nome, telefono, numero di carta di credito, ed eventuale numero di “cliente affezionato”. Il file che contiene le informazioni relative ai clienti ha il seguente formato.

La prima linea del file contiene la stringa "CLIENTI". Poi una linea per ogni cliente con il seguente formato:

C;N;T;R;A

dove

C Cognome
N Nome
T Telefono
R Tipo e numero di carta di credito
A Numero "cliente affezionato" (numero che identifica il cliente, o stringa vuota)

Esempio:

CLIENTI
Rossi;Mario;06987675;VISA4986754435540032;4567
De Luca;Lucia;;MASTERCARD4999954435540777;
Verdi;Gran Carlo;3456435466;VISA49999544355499988;3452

Deve essere possibile cancellare una prenotazione fatta o cambiarne le caratteristiche (stanza con 2 letti invece che matrimoniale, ecc.) se la permanenza non è iniziata. Si deve poter effettuare una prenotazione, previa verifica da parte del sistema della disponibilità da parte della catena.

All’inizio dell’accesso al sistema, la scelta è tra l’accesso alle “Gestione Prenotazione” o “Richiesta Prenotazione” da parte del cliente e l’accesso alla “Gestione Risorse” degli alberghi in una zona riservata ai gestori.

Con la scelta “Gestione Risorse”, si deve optare per la modifica dell’archivio di stanze e/o alberghi o per esportare/salvare su file testo tutte le prenotazioni di un particolare albergo in una particolare data. Se la rimozione di una stanza è possibile (non risulta prenotata nel periodo selezionato) viene mostrato un messaggio di conferma; altrimenti si presenta il messaggio appropriato (eventualmente, per progetti con ambiziosi, proponendo un trasferimento della prenotazione ad altra stanza equivalente). L’aggiunta di una stanza automaticamente la rende disponibile alle prenotazioni.

L’Esportazione crea un file testo cui possiamo assegnare un nome tramite una finestra di dialogo, con i due bottoni OK e Annulla. Il risultato ottenuto premendo il bottone OK è un file di testo con le prenotazioni in ordine di numero di stanza. Le prime due linee hanno il seguente formato:

PRENOTAZIONI
A

dove PRENOTAZIONI è la stringa "PRENOTAZIONI" ed A è il nome dell'albergo

poi una linea per ogni prenotazione, con il seguente formato:

N;C;I;O

dove

N Numero della stanza
C Cognome del cliente
I Data inizio (check-in) nel formato gg/mm/aaaa
O Data fine (check-out) nel formato gg/mm/aaaa

Esempio:

PRENOTAZIONI
Hotel Piazza di Spagna
11;De Luca;12/4/2010;14/4/2010
24;Verdi;4/10/2010;8/10/2010

Con la scelta “Richiesta Prenotazione”, è possibile inserire albergo e data, e chiedere la disponibilità; a questo punto viene data l’opzione di mostrare i “Dettagli” dell’eventuale stanza disponibile, e quella per “Prenotare” la stanza. Con “Dettagli”, vengono evidenziate le caratteristiche della stanza in formato testo. Con “Prenota”, si richiedono i dati del cliente e viene mostrato un messaggio di conferma della prenotazione; altrimenti si presenta il messaggio d’errore appropriato (carta di credito non valida, stanza della stessa catena già prenotata nello stesso giorno, ecc.).

Con la scelta “Gestione Prenotazione”, si richiedono le informazioni del cliente e la richiesta (se cancellazione o modifica di caratteristiche). Se la rimozione è di una prenotazione esistente, viene mostrato un messaggio di conferma, altrimenti si presenta il messaggio d’errore appropriato.

Per questa applicazione, si ignorano aspetti di autenticazione dell’utente. Per la verifica della carta di credito, si crea una classe con un solo metodo che restituisce True/False in maniera casuale.

La versione “minima” (cioè richiesta a tutti) di questa applicazione va sviluppata ipotizzando che tutti i dati/comandi dall’esterno siano ricevuti da tastiera o file.

Per una votazione più alta, è possibile sviluppare ANCHE una versione interattiva con finestre. La versione “deluxe” deve contenere, in aggiunta, un sistema di finestre (come oggetti di classi GestoreFrame, ClienteFrame, ecc.) in cui compaiono alternative visualizzate con pulsanti da “premere” (Aggiungi, Esporta, Dettagli, Prenota, Cancella) e campi dove “selezionare” (per esempio il nome dell’albergo) o “inserire” (data, cognome, no. carta di credito, ecc.) le informazioni ricevute dall’esterno.

VANNO PRESENTATI

1. Documentazione utilizzando Javadoc

2. Codice completo e funzionante

-- DanieleGorla - 14 May 2010

Edit | Attach | Watch | Print version | History: r2 < r1 | Backlinks | Raw View | Raw edit | More topic actions
Topic revision: r2 - 2010-06-07 - DanieleGorla






 
Questo sito usa cookies, usandolo ne accettate la presenza. (CookiePolicy)
Torna al Dipartimento di Informatica
This site is powered by the TWiki collaboration platform Powered by PerlCopyright © 2008-2025 by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding TWiki? Send feedback