Compare commits

4 Commits

Author SHA1 Message Date
2173f2984f Merge branch 'fs58-pywikibot-logging-changed' into test-v1 2016-07-11 23:38:25 +02:00
5ecfb2a37b Catch import Error due to change in pywikibot
In master branch of pywikibot the logging related stuff is moved to a
new module pywikibot.logging. As we want to be compatible to both
the master (for use of shared pywikibot on labs) and also the 2.0 branch
we need to catch this

[https://fs.golderweb.de/index.php?do=details&task_id=58 FS#58]
pywikibot-core commit d7d7a14
2016-07-11 23:36:57 +02:00
fbe9799df7 Merge branch 'jogobot-config' into test-v1 2016-03-11 14:43:52 +01:00
7212b8eee4 Re-Structure config module 2016-03-11 14:39:17 +01:00
2 changed files with 67 additions and 14 deletions

View File

@@ -31,21 +31,66 @@ import ast
import pywikibot
__config = configparser.ConfigParser(interpolation=None)
__config.read(pywikibot.config.get_base_dir() + "/jogobot.conf")
def load_config():
"""
Reads raw configuration from file and provides it as attribute
@param Config-Object
@r-type configparser.ConfigParser
"""
# Load configparser
config = configparser.ConfigParser(interpolation=None)
# Load config file
config.read(pywikibot.config.get_base_dir() + "/jogobot.conf")
return config
def parse_config( raw_config ):
"""
Converts config to normal dictionary
Parses each entry with ast.literal_eval
@param config Config-Object to parse
@type config configparser.ConfigParser
@return Parsed configuration
@rtype dict
"""
# Convert to dict as configparser could contain only strings
config = dict( __config )
config = dict( raw_config )
# Parse all sections
for section in __config.sections():
for section in raw_config.sections():
# Convert to dict as configparser could contain only strings
config[section] = dict( __config[section] )
config[section] = dict( raw_config[section] )
# Parse config with ast.literal_eval to get python datatypes
for key, value in config[section].items():
config[section][key] = ast.literal_eval( value )
# Make jogobot entrys available in root level (without sections)
for key, value in config["jogobot"].items():
return config
def root_section( config, section="jogobot" ):
"""
Make 'section' entrys available in root level (without sections)
@param config Config-Object to parse
@type config dict
@return Parsed configuration
@rtype dict
"""
for key, value in config[section].items():
config[key] = value
return config
# Load config
config = load_config()
# Parse config to get python datatypes
config = parse_config( config )
# Make jogobot section available as root
config = root_section( config )

View File

@@ -30,6 +30,14 @@ from subprocess import Popen, PIPE, TimeoutExpired
import pywikibot
# Location of logging related stuff in pywikibot was changed with
# commit d7d7a14 on Mon Sep 7 14:41:43 2015
# This is to be compatible with recent versions as well as 2.0-branch
try:
from pywikibot.logging import(
DEBUG, INFO, WARNING, ERROR, CRITICAL, STDOUT, VERBOSE, logoutput )
except( ImportError ):
# Legacy support (pywikibot 2.0 branch)
from pywikibot.bot import(
DEBUG, INFO, WARNING, ERROR, CRITICAL, STDOUT, VERBOSE, logoutput )