6 require 'constantes.rb'
8 require 'modules/allocine.rb'
10 # ajout de deux méthodes à la classe String
13 return gsub(/<(.*?)>/, '')
21 # Permet de charger des données depuis allocine.fr
22 # Permet d'effectuer des recherches depuis allocine.fr
25 # toutes les données membres sont accessibles par défaut (écriture/lecture)
26 attr_accessor
:id, :titre, :url, :fichiers, :mod, :annee, :realisateurs, :acteurs, :pays, :duree, :critiquePresse, :critiqueSpectateur, :genres, :synopsis, :budget
28 # Constructeur. N'entreprend aucune action (chargement), crée juste un film vide.
29 # p1 [String] : le fichier correspondant au film
30 def initialize(fichier
, mod
)
31 @fichiers = [fichier
] # le chemin des fichiers est relatif au repertoire de base
42 @critiqueSpectateur = nil
51 # mémorise les tuples {nom => id} dans le cas ou il y a plusieurs choix de films après une recherche
55 # Est-ce qu'il y a eu plusieurs réponses pour ce film lors de la cherche sur le net ?
56 def plusieursReponses
?
57 return @nbReponses > 1
60 # Est-ce qu'il y a eu plusieurs réponses pour ce film lors de la cherche sur le net ?
65 # Demande à l'utilisateur de faire un choix.
66 # ret : 1 si le conflit à été résolu, 2 si le film est à ignorer, 3 si tout les films sont à ignorer
67 def reglerConflitPlusieursReponses
70 puts
" -> " +
@fichiers[0]
71 puts
"Fais ton choix jeune padawan (un caractère et pas plus)"
81 puts
"A. Passer et l'ajouter"
83 puts
"C. Tout ignorer"
95 if choix
> 0 && choix
<= tabNoms
.length
99 puts
"Choix pas bon !!
"
103 @mod.load(@choix[tabNoms[choix-1]], self)
108 # Ajoute un fichier comme faisant partie du film
109 def addFichier(fichier)
110 if !@fichiers.include?(fichier
)
115 # Charge les informations du films à partir d'allocine.fr
118 #extrait le nom à partir du nom du fichier
119 /^.*?([^\/]*?)\
.(.{3,4})$/ =~
@fichiers[0]
120 #remplace undescores et points par des espaces
121 titre
= $1.gsub(/[_\.]/, ' ')
122 #remplace les suites d'espaces par un seul
123 titre
.gsub!
(/ {2,}/,' ')
124 titre
.gsub!
(/\[.*?\]/,'')
125 titre
.gsub!
(/\(.*?\)/,'')
126 titre
.gsub!
(/\{.*?\}/,'')
127 #vire les espaces au début et à la fin
136 reponses
= @mod.rechercherFilm(titre
)
137 @nbReponses = reponses
.size
140 @mod.load(reponses
.values
[0], self)
148 # Met à jour un ou plusieurs champs correspondant à 'champ'.
150 return if @url == nil || @url == ""
152 @mod.loadURL(@url, self)
155 # Renvoie un film sous la forme d'un élément XML .
156 # ret [REXML::Element] : un element xml <film>
159 racine
= REXML
::Element::new('film')
160 racine
.add_attribute('id', @id.to_s
)
162 fichiers
= REXML
::Element::new('fichiers')
164 fichiers
.add(REXML
::Element::new('fichier').add_text(f
))
168 racine
.add(REXML
::Element::new('titre').add_text(@titre))
169 racine
.add(REXML
::Element::new('annee').add_text(@annee))
171 realisateurs
= REXML
::Element::new('realisateurs')
172 @realisateurs.each
{|r
|
173 realisateurs
.add(REXML
::Element::new('realisateur').add_text(r
.nom
))
175 racine
.add(realisateurs
)
177 acteurs
= REXML
::Element::new('acteurs')
179 acteurs
.add(REXML
::Element::new('acteur').add_text(a
.nom
))
183 lespays
= REXML
::Element::new('lespays')
185 lespays
.add(REXML
::Element::new('pays').add_text(p
.nom
))
189 racine
.add(REXML
::Element::new('duree').add_text(@duree.to_s
))
191 racine
.add(REXML
::Element::new('critiquePresse').add_text(@critiquePresse))
192 racine
.add(REXML
::Element::new('critiqueSpectateur').add_text(@critiqueSpectateur))
194 genres
= REXML
::Element::new('genres')
196 genres
.add(REXML
::Element::new('genre').add_text(g
.nom
))
200 synopsisElement
= REXML
::Element::new('synopsis')
201 unless @synopsis.nil?
202 @synopsis.split("\n").each
{|s
|
204 synopsisElement
.add(REXML
::Element::new('p').add_text(s
))
207 racine
.add(synopsisElement
)
209 budgetElement
= REXML
::Element::new('budget')
210 budgetElement
.add_text(@budget)
211 budgetElement
.add_attribute('unite', @budgetUnite)
212 racine
.add(budgetElement
)
214 racine
.add(REXML
::Element::new('url').add_text(@url))