/usr/lib/python2.7/dist-packages/mpop/utils.py is in python-mpop 1.0.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 | #!/usr/bin/env python
# -*- coding: utf-8 -*-
# Copyright (c) 2009, 2012.
# SMHI,
# Folkborgsvägen 1,
# Norrköping,
# Sweden
# Author(s):
# Martin Raspaud <martin.raspaud@smhi.se>
# Adam Dybbroe <adam.dybbroe@smhi.se>
# Esben S. Nielsen <esn@dmi.dk>
# This file is part of mpop.
# mpop is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# mpop is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with mpop. If not, see <http://www.gnu.org/licenses/>.
"""Module defining various utilities.
"""
import os
import re
import ConfigParser
import logging
from mpop import CONFIG_PATH
class OrderedConfigParser(object):
"""Intercepts read and stores ordered section names.
Cannot use inheritance and super as ConfigParser use old style classes.
"""
def __init__(self, *args, **kwargs):
self.config_parser = ConfigParser.ConfigParser(*args, **kwargs)
def __getattr__(self, name):
return getattr(self.config_parser, name)
def read(self, filename):
"""Reads config file
"""
try:
conf_file = open(filename, 'r')
config = conf_file.read()
config_keys = re.findall(r'\[.*\]', config)
self.section_keys = [key[1:-1] for key in config_keys]
except IOError, e:
# Pass if file not found
if e.errno != 2:
raise
return self.config_parser.read(filename)
def sections(self):
"""Get sections from config file
"""
try:
return self.section_keys
except:
return self.config_parser.sections()
def ensure_dir(filename):
"""Checks if the dir of f exists, otherwise create it.
"""
import os
directory = os.path.dirname(filename)
if len(directory) and not os.path.isdir(directory):
os.makedirs(directory)
class NullHandler(logging.Handler):
"""Empty handler.
"""
def emit(self, record):
"""Record a message.
"""
pass
def debug_on():
"""Turn debugging logging on.
"""
logging_on(logging.DEBUG)
_is_logging_on = False
def logging_on(level=logging.INFO):
"""Turn logging on.
"""
global _is_logging_on
if not _is_logging_on:
console = logging.StreamHandler()
console.setFormatter(logging.Formatter("[%(levelname)s: %(asctime)s :"
" %(name)s] %(message)s",
'%Y-%m-%d %H:%M:%S'))
console.setLevel(level)
logging.getLogger('').addHandler(console)
_is_logging_on = True
log = logging.getLogger('')
log.setLevel(level)
for h in log.handlers:
h.setLevel(level)
def logging_off():
"""Turn logging off.
"""
logging.getLogger('').handlers = [NullHandler()]
def get_logger(name):
"""Return logger with null handle
"""
log = logging.getLogger(name)
if not log.handlers:
log.addHandler(NullHandler())
return log
# Read default log level from mpop's config file
_config = ConfigParser.ConfigParser()
_config.read(os.path.join(CONFIG_PATH, 'mpop.cfg'))
try:
default_loglevel = _config.get('general', 'loglevel')
except (ConfigParser.NoOptionError, ConfigParser.NoSectionError):
default_loglevel = 'WARNING'
default_loglevel = getattr(logging, default_loglevel.upper())
del _config
logging_on(default_loglevel)
###
import re
def strftime(utctime, format_string):
"""Like datetime.strftime, except it works with string formatting
conversion specifier items on windows, making the assumption that all
conversion specifiers use mapping keys.
E.g.:
>>> from datetime import datetime
>>> t = datetime.utcnow()
>>> a = "blabla%Y%d%m-%H%M%S-%(value)s"
>>> strftime(t, a)
'blabla20120911-211448-%(value)s'
"""
res = format_string
for i in re.finditer("%\w", format_string):
res = res.replace(i.group(), utctime.strftime(i.group()))
return res
|