Skip to content

A simple VBA logging utility for tracking messages with customizable log levels and output options.

License

Notifications You must be signed in to change notification settings

6i-software/vba-logger

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

VBA Logger

LICENSE  Want to support me? Offer me a coffee!

A simple VBA logging utility for tracking messages with customizable log levels and output options.

Overview

VBA Logger is a logging system designed to track and record events or messages within a VBA (Visual Basic for Applications) application. It supports logging messages with different levels of severity and can output logs either to the VBA console or to a specific log file. It supports also allows for customization, such as adjusting log verbosity, customizing the log output location, and more.

VBALogger-output-all.png VBA Logger — Output logs simultaneously to the VBA console and a file.

Main features:

  • Verbosity levels: Control the granularity of logs by adjusting the verbosity level, from critical errors to detailed debug information. The current verbosity level is set using the LogVerbosityLevelSession property, which corresponds to the values of the LogVerbosityLevel enumeration.

    Level Description
    Error Logs runtime errors.
    Warning Logs exceptional occurrences that are not errors.
    Log Normal logs for general purposes.
    Notice Logs significant events.
    Info Logs interesting events, useful for understanding.
    Trace Logs detailed debug information for troubleshooting.
  • Each log entry is prefixed with the type of message (e.g., [ERROR], [WARNING], etc.), except for general "Log" entries, which have no prefix. This helps in quickly identifying the type and severity of the log entry.

  • Configure log output: By default, logs are displayed only in the VBA console (Excel's immediate window). You can change their destination using the LogOutputSession property according to the values of the LogOutput enumeration.

    Log output Description
    Console Logs are sent to the VBA immediate window.
    File Logs are written to a file.
    All Logs are sent both to the console and a file.

    Logs can be sent to the VBA console, a file, or both. The logger also allows you to choose a name and folder for the log file. If the folder (and its subfolders) does not exist, the logger will create it automatically.

  • Contextual logging to simplify debugging of complex variables: At the trace level, you can add extra context to your logs, such as collections or objects. This approach improves debugging and issue tracking by providing deeper insights into variable values.

  • Add a customizable splashscreen: A customizable splashscreen can be shown at the beginning of a logging session, providing a visual confirmation that logging is initialized. This can be turned off as needed.

Documentation

Please refer to the documentation for details on how to use VBA Logger and its features.

Installation

VBA Logger supports several installation methods :

  • by importing the class module VBALoggerClass in your VBA project.

    In this case, the class module VBALoggerClass is set to Private and can only be accessed within the project where it is defined or imported, ensuring encapsulation and preventing external code from directly interacting with it. To utilize the logger functionality, the developer must instantiate the class within their own procedures, allowing for controlled access to its methods and properties.

  • by reference the XLAM VBALogger in your VBA project.

    If you want to use the logger into multilples VBA project, you should use the VBA Logger XLAM. In this case, the class module VBALoggerClass is set to PublicNotCreatable and the developer use a factory method VBALogger.Factory.Create to obtain an instance of the logger.

  • by using the installer (Windows setup) - not yet, working in progress

    Use this solution in order to make easy installation and deployment of VBA Logger XLAM.

You can find the detailed instructions for each installation method in the documentation of VBALogger Installation. You should consult it for the simplest setup experience.

About

Want to support me ? Offer me a coffee !

VBA Logger is free and open source under the MIT License, but if you want to support me, you can offer me a coffee here or by scanning this QR code. Thank you in advance for your assistance (and your appreciation) for this work ^^.

Buy me a coffee ?

Want to contribute ?

Bug reports, reports a typo in documentation, comments, pull-request & Github stars are always welcome !

Releases

  • VBA Logger v1.0.0 - 2024.10.18

License

Release under MIT License,
Copyright (c) 2024 by 2o1oo vb20100bv@gmail.com

About

A simple VBA logging utility for tracking messages with customizable log levels and output options.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages