Debug Tools
Basic logger for Python logging
module.
Usage
pip install debug_tools
Or clone this repository locally by running the commands:
git clone https://github.com/evandrocoan/debugtools
cd debugtools
Then, run python setup.py install
or python setup.py develop
to install it on development mode.
from debug_tools import getLogger
log = getLogger( 127, __name__ )
log( 1, "Debugging" )
Cleaning the log file every start up
If you are logging the debug output to a file and you would like to clean/erase all the log file contents,
every time you re-create the logger,
you need first to unlock the log file lock, otherwise,
the file contents are not going to be erased.
To unlock your log file,
you just need to call log.setup("")
,
with an empty string before creating a new logger.
On Sublime Text, this could be done with te following:
from debug_tools import getLogger
log = getLogger(debug_enabled, "wrap_plus", "wrapplus.txt", mode='w')
def plugin_unloaded():
log.delete()
Dynamically Reloading It
If you want to reload the debug tools code on the fly, you can use this to import it:
import imp
import debug_tools.logger
imp.reload( debug_tools.logger )
from debug_tools.logger import Debugger
from debug_tools.logger import getLogger
Debugger.deleteAllLoggers()
log = getLogger(1, "LSP")
Using file logger configuration
If you want to load the logger configuration from a file, you need to replace the standard logging
module class with this one:
import logging
import debug_tools
if log_config:
with open(log_config, 'r') as f:
logging.Logger.manager = debug_tools.Debugger.manager
logging.Logger.manager.setLoggerClass( debug_tools.Debugger )
logging.config.dictConfig(json.load(f))
Sublime Text Dependency
To use this as a Package Control Dependency https://packagecontrol.io/docs/dependencies create
this dependencies.json
file on the root of your Package:
{
"windows": {
">3000": [
"python-pywin32",
"portalockerfile",
"concurrentloghandler",
"debugtools"
]
},
"*": {
"*": [
"portalockerfile",
"concurrentloghandler",
"debugtools"
]
}
}
Update estimated_time_left from upstream
To update the subtree all/debug_tools/estimated_time_left
,
from upstream updates you can use the command:
git subtree pull --prefix=all/debug_tools/estimated_time_left https://github.com/evandrocoan/EstimatedTimeLeft master
To send updates back to the upstream, use the following command:
git subtree push --prefix=all/debug_tools/estimated_time_left https://github.com/evandrocoan/EstimatedTimeLeft master
License
See the file LICENSE.txt