projects
/
pompage.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
git-svn-id: svn://euphorik.ch/pompage@45 02bbb61a-6d21-0410-aba0-cb053bdfd66a
[pompage.git]
/
src
/
yopyop.rb
diff --git
a/src/yopyop.rb
b/src/yopyop.rb
index
949edd8
..
47da578
100644
(file)
--- a/
src/yopyop.rb
+++ b/
src/yopyop.rb
@@
-1,3
+1,4
@@
+# coding: utf-8
\r
# YopYop est un super programme permettant de :
\r
# - Parcourir des dossiers recursivement à la recherche de fichier video
\r
# - Parser les fichiers afin d'en retirer les infos suivantes :
\r
# YopYop est un super programme permettant de :
\r
# - Parcourir des dossiers recursivement à la recherche de fichier video
\r
# - Parser les fichiers afin d'en retirer les infos suivantes :
\r
@@
-10,38
+11,69
@@
# o ogm
\r
# o mkv
\r
# o rmvb
\r
# o ogm
\r
# o mkv
\r
# o rmvb
\r
-# - Rechercher chaque film sur le site 'allocine.com' et en pomper un max d'infos
\r
+# - Rechercher chaque film sur le site 'allocine.com' et
'imdb.com' et
en pomper un max d'infos
\r
# - Etablir une petit base de données des films au format xml
\r
\r
# - Etablir une petit base de données des films au format xml
\r
\r
-# non ce n'est pas du perl ;)
\r
-$: << Dir::getwd + "/" + __FILE__.split('/')[0]
\r
-
\r
-#$KCODE = 'UTF-8'
\r
-#require 'jcode.rb'
\r
+require 'films.rb'
\r
require 'film.rb'
\r
\r
require 'film.rb'
\r
\r
+require 'images.rb'
\r
+
\r
# vérifie les arguments donnés
\r
# vérifie les arguments donnés
\r
-rep = '.'
\r
-if $*.empty?
\r
- puts 'USAGE : <xml file> [<directory>]'
\r
+$xmlFile = nil
\r
+$repBase = Dir::getwd
\r
+$repFilms = '.'
\r
+$repAffichette = '../img/affichette/'
\r
+mod = 'Allocine'
\r
+purgeImages = false
\r
+
\r
+aPrec = ''
\r
+$*.each{|a|
\r
+ case a
\r
+ when '-p'
\r
+ purgeImages = true
\r
+ next
\r
+ end
\r
+ case aPrec
\r
+ when '-x'
\r
+ $xmlFile = a
\r
+ when '-d'
\r
+ $repFilms = a
\r
+ when '-m'
\r
+ mod = a
\r
+ when '-a'
\r
+ $repAffichette = a
\r
+ end
\r
+ aPrec = a
\r
+}
\r
+
\r
+if $xmlFile.nil?
\r
+ puts USAGE
\r
exit 0
\r
exit 0
\r
-elsif $*.size == 1
\r
- puts 'no directory given, use the current'
\r
-else
\r
- rep = $*[1]
\r
end
\r
end
\r
-xmlFile = $*[0]
\r
\r
\r
-unless File::directory?(
rep
)
\r
- puts "'#{
rep
}' is not a valid directory"
\r
+unless File::directory?(
$repFilms
)
\r
+ puts "'#{
$repFilms
}' is not a valid directory"
\r
exit 1
\r
exit 1
\r
-end
\r
+end
\r
+
\r
+begin
\r
+ require "modules/#{mod}"
\r
+rescue
\r
+ puts "Le module '#{mode}' n'existe pas. Les modules se trouvent dans le dossier 'src/modules'"
\r
+ puts USAGE
\r
+ exit 1
\r
+end
\r
\r
# charge les films à partir du fichier xml
\r
\r
# charge les films à partir du fichier xml
\r
-
Film::loadFilmsXml(xmlFile
)
\r
+
films = Films::new($xmlFile, Module.class_eval(mod)
)
\r
\r
\r
-# lit le repertoire
\r
-Film::litRepertoire(rep)
\r
+if purgeImages
\r
+ Images.nettoyer(films, $repAffichette)
\r
+else
\r
+ # parcours le dossier donné et recherche les infos sur le net
\r
+ films.pomper($repFilms)
\r
\r
\r
-# ecrit le fichier XML
\r
-Film::getFilmsXml.write(File::new(xmlFile, 'w'), 0)
\r
+ # écrit le fichier XML
\r
+ films.sauverFilms()
\r
+end
\r