2 # Permet de charger des données depuis allocine.fr
3 # Permet d'effectuer des recherches depuis allocine.fr
4 # TODO : rendre la classe indépendant de la source de donnée pour pouvoir utiliser d'autres sites comme par exemple imdb.com
9 require 'constantes.rb'
11 require 'modules/allocine.rb'
13 # ajout de deux méthodes à la classe String
16 return gsub(/<(.*?)>/, '')
25 def Film
::setModule(m
)
29 # toutes les données membres sont accessibles par défaut (écriture/lecture)
30 attr_accessor
:id, :titre, :url, :fichiers, :annee, :realisateurs, :acteurs, :pays, :duree, :critiquePresse, :critiqueSpectateur, :genres, :synopsis, :budget
32 # Constructeur. N'entreprend aucune action (chargement), crée juste un film vide.
33 # p1 [String] : le fichier correspondant au film
34 def initialize(fichier
)
35 @fichiers = [fichier
] # le chemin des fichiers est relatif au repertoire de base
45 @critiqueSpectateur = nil
54 # mémorise les tuples {nom => id} dans le cas ou il y a plusieurs choix de films après une recherche
58 # Est-ce qu'il y a eu plusieurs réponses pour ce film lors de la cherche sur le net ?
59 def plusieursReponses
?
60 return @nbReponses > 1
63 # Est-ce qu'il y a eu plusieurs réponses pour ce film lors de la cherche sur le net ?
68 # Demande à l'utilisateur de faire un choix.
69 # ret : 1 si le conflit à été résolu, 2 si le film est à ignorer, 3 si tout les films sont à ignorer
70 def reglerConflitPlusieursReponses
73 puts
" -> " +
@fichiers[0]
74 puts
"Fais ton choix jeune padawan (un caractère et pas plus)"
83 puts
"A. Passer et l'ajouter"
85 puts
"C. Tout ignorer"
97 if choix
> 0 && choix
<= tabNoms
.length
101 puts
"Choix pas bon !!
"
105 @@module.load(@choix[tabNoms[choix-1]], self)
110 # Ajoute un fichier comme faisant partie du film
111 def addFichier(fichier)
112 if !@fichiers.include?(fichier
)
117 # Charge les informations du films à partir d'allocine.fr
120 #extrait le nom à partir du nom du fichier
121 /^.*?([^\/]*?)\
.(.{3,4})$/ =~
@fichiers[0]
122 #remplace undescores et points par des espaces
123 titre
= $1.gsub(/[_\.]/, ' ')
124 #remplace les suites d'espaces par un seul
125 titre
.gsub!
(/ {2,}/,' ')
126 titre
.gsub!
(/\[.*?\]/,'')
127 titre
.gsub!
(/\(.*?\)/,'')
128 titre
.gsub!
(/\{.*?\}/,'')
129 #vire les espaces au début et à la fin
138 reponses
= @
@module.rechercherFilm(titre
)
139 @nbReponses = reponses
.size
142 @
@module.load(reponses
.values
[0], self)
150 # Renvoie un film sous la forme d'un élément XML .
151 # ret [REXML::Element] : un element xml <film>
154 racine
= REXML
::Element::new('film')
155 racine
.add_attribute('id', @id.to_s
)
157 fichiers
= REXML
::Element::new('fichiers')
159 fichiers
.add(REXML
::Element::new('fichier').add_text(f
))
163 racine
.add(REXML
::Element::new('titre').add_text(@titre))
164 racine
.add(REXML
::Element::new('annee').add_text(@annee))
166 realisateurs
= REXML
::Element::new('realisateurs')
167 @realisateurs.each
{|r
|
168 realisateurs
.add(REXML
::Element::new('realisateur').add_text(r
.nom
))
170 racine
.add(realisateurs
)
172 acteurs
= REXML
::Element::new('acteurs')
174 acteurs
.add(REXML
::Element::new('acteur').add_text(a
.nom
))
178 lespays
= REXML
::Element::new('lespays')
180 lespays
.add(REXML
::Element::new('pays').add_text(p
.nom
))
184 racine
.add(REXML
::Element::new('duree').add_text(@duree.to_s
))
186 racine
.add(REXML
::Element::new('critiquePresse').add_text(@critiquePresse))
187 racine
.add(REXML
::Element::new('critiqueSpectateur').add_text(@critiqueSpectateur))
189 genres
= REXML
::Element::new('genres')
191 genres
.add(REXML
::Element::new('genre').add_text(g
.nom
))
195 synopsisElement
= REXML
::Element::new('synopsis')
196 unless @synopsis.nil?
197 @synopsis.split("\n").each
{|s
|
199 synopsisElement
.add(REXML
::Element::new('p').add_text(s
))
202 racine
.add(synopsisElement
)
204 budgetElement
= REXML
::Element::new('budget')
205 budgetElement
.add_text(@budget)
206 budgetElement
.add_attribute('unite', @budgetUnite)
207 racine
.add(budgetElement
)
209 racine
.add(REXML
::Element::new('url').add_text(@url))