summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Core.py30
-rw-r--r--Logs/faild.txt29
-rw-r--r--Plugins/Plugin.py2
-rw-r--r--Plugins/RSDF.py5
-rw-r--r--module/download_thread.py18
-rwxr-xr-xmodule/network/Request.py3
-rw-r--r--module/thread_list.py2
7 files changed, 63 insertions, 26 deletions
diff --git a/Core.py b/Core.py
index e674c45a8..fd1ae9de2 100644
--- a/Core.py
+++ b/Core.py
@@ -1,7 +1,7 @@
#!/usr/bin/python
# -*- coding: utf-8 -*-
#
-#Copyright (C) 2009 sp00b, sebnapi
+#Copyright (C) 2009 sp00b, sebnapi, RaNaN
#
#This program is free software; you can redistribute it and/or modify
#it under the terms of the GNU General Public License as published by
@@ -25,19 +25,19 @@ from glob import glob
from string import find, split
from os import sep, chdir, mkdir, curdir, name, system, remove
from os.path import exists, abspath, dirname, basename
-from sys import path, exit
+from sys import path, exit, stdout
from logging import warning, basicConfig
import urllib2
import re
from time import sleep, time
+import logging
+import logging.handlers
#my imports
from module.download_thread import Download_Thread
from module.thread_list import Thread_List
from module.Py_Load_File import PyLoadFile
-basicConfig(filename='Logs/faild.txt', format = '%(message)s')
-
class Core(object):
""" pyLoad main
"""
@@ -45,9 +45,9 @@ class Core(object):
self.download_folder = ""
self.link_file = "links.txt"
self.plugins_avaible = {}
- #self.plugins_needed = {}
- #self.plugins_dict = {}
- #self.applicationPath = ""
+ self.read_config()
+ self.init_logger(logging.DEBUG) # logging level
+
self.search_updates = False
self.plugins_folder = ""
self.read_config()
@@ -90,7 +90,7 @@ class Core(object):
pass
if plugin_pattern != "":
self.plugins_avaible[plugin_file] = plugin_pattern
- print plugin_file, "hinzugefuegt"
+ self.logger.debug(plugin_file + " hinzugefuegt")
print "Index der Plugins erstellt"
## def check_needed_plugins(self):
@@ -207,6 +207,20 @@ class Core(object):
self.thread_list.append_py_load_file(new_file)
return True
+ def init_logger(self, level):
+ handler = logging.handlers.RotatingFileHandler('Logs/log.txt', maxBytes = 12800 , backupCount = 10) #100 kb
+ console = logging.StreamHandler(stdout)
+ #handler = logging.FileHandler('Logs/log.txt')
+ frm = logging.Formatter("%(asctime)s: %(levelname)-8s %(message)s",
+ "%d.%m.%Y %H:%M:%S")
+ handler.setFormatter(frm)
+ console.setFormatter(frm)
+
+ self.logger = logging.getLogger() # settable in config
+ self.logger.addHandler(handler)
+ self.logger.addHandler(console) #if console logging
+ self.logger.setLevel(level)
+
def _test_print_status(self):
if self.thread_list.py_downloading:
diff --git a/Logs/faild.txt b/Logs/faild.txt
index e69de29bb..d77ca4862 100644
--- a/Logs/faild.txt
+++ b/Logs/faild.txt
@@ -0,0 +1,29 @@
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+testest
+geloggt
+geloggt
diff --git a/Plugins/Plugin.py b/Plugins/Plugin.py
index 90781f765..f7ea99b7d 100644
--- a/Plugins/Plugin.py
+++ b/Plugins/Plugin.py
@@ -45,8 +45,6 @@ class Plugin():
def get_file_url(self):
""" returns the absolute downloadable filepath
"""
- if self.html != None:
- self.download_html()
return self.parent.url
diff --git a/Plugins/RSDF.py b/Plugins/RSDF.py
index 9b377a2a3..65f01d41b 100644
--- a/Plugins/RSDF.py
+++ b/Plugins/RSDF.py
@@ -36,11 +36,6 @@ class RSDF(Plugin):
""" returns True or False
"""
return True
-
- def get_file_url(self):
- """ returns the absolute downloadable filepath
- """
- return self.parent.url
def __call__(self):
return self.plugin_name
diff --git a/module/download_thread.py b/module/download_thread.py
index 502d42ddc..96bc4dd34 100644
--- a/module/download_thread.py
+++ b/module/download_thread.py
@@ -83,13 +83,12 @@ class Download_Thread(threading.Thread):
if self.parent.py_load_files:
self.loadedPyFile = self.parent.get_job()
if self.loadedPyFile:
- try:
+ try:
self.download(self.loadedPyFile)
- except Exception, e:
- print "Error:", e
- #catch up all error here
- finally:
- self.parent.job_finished(self.loadedPyFile)
+ except Exception, e:
+ print "Error:", e #catch up all error here
+ finally:
+ self.parent.job_finished(self.loadedPyFile)
sleep(0.5)
if self.shutdown:
sleep(1)
@@ -99,9 +98,9 @@ class Download_Thread(threading.Thread):
pyfile = py_load_file
status = pyfile.status
pyfile.prepareDownload()
-
- if not status.exists:
- raise "FileDontExists" #i know its deprecated, who cares^^
+
+ if not status.exists:
+ raise "FileDontExists" #i know its deprecated, who cares^^
if status.want_reconnect:
print "handle reconnect"
@@ -112,7 +111,6 @@ class Download_Thread(threading.Thread):
try:
status.type = "downloading"
- print "download", status.filename
pyfile.plugin.proceed(status.url, pyfile.download_folder + "/" + status.filename)
status.type = "finished"
diff --git a/module/network/Request.py b/module/network/Request.py
index 1c0317cc7..510f6d069 100755
--- a/module/network/Request.py
+++ b/module/network/Request.py
@@ -27,6 +27,7 @@ class Request:
def __init__(self):
self.dl_time = 0
+ self.dl_finished = 0
self.dl_size = 0
self.dl_arrived = 0
self.dl = False
@@ -114,7 +115,7 @@ class Request:
def get_ETA(self):
try:
- return (self.dl_size - self.dl_arrived) / (self.dl_arrived / (time.time() - self.dl_time))
+ return (self.dl_size - self.dl_arrived) / (self.dl_arrived / (time.time() - self.dl_time if self.dl else self.dl_finished))
except:
return "No Download"
diff --git a/module/thread_list.py b/module/thread_list.py
index 979a98c60..065318a56 100644
--- a/module/thread_list.py
+++ b/module/thread_list.py
@@ -73,6 +73,7 @@ class Thread_List(object):
self.py_downloading.append(pyfile)
if not pyfile.plugin.multi_dl:
self.occ_plugins.append(pyfile.modul.__name__)
+ self.parent.logger.info('start downloading ' + pyfile.url )
self.lock.release()
return pyfile
@@ -85,6 +86,7 @@ class Thread_List(object):
self.occ_plugins.remove(pyfile.modul.__name__)
self.py_downloading.remove(pyfile)
+ self.parent.logger.info('finished downloading ' + pyfile.url + ' @'+str(pyfile.status.get_speed())+'kb/s')
if pyfile.plugin.plugin_type == "container":
self.parent.extend_links(pyfile.plugin.links)