Skip to content

Latest commit

 

History

History
251 lines (177 loc) · 7.2 KB

File metadata and controls

251 lines (177 loc) · 7.2 KB

obug

npm version npm downloads JSR Unit Test

A lightweight JavaScript debugging utility, forked from debug, featuring TypeScript and ESM support.

Note

obug v1 retains most of the compatibility with debug, but drops support for older browsers and Node.js, making it a drop-in replacement.

obug v2 refactors some API imports and usage for better support of ESM and TypeScript, easier customization, and an even smaller package size.

Key Differences from debug

  • ✨ Minimal footprint
    • 7.7 kB package size
    • 1.4 KB minified + gzipped for browsers
  • 📦 Zero dependencies
  • 📝 Full TypeScript support
  • 🚀 Native ESM compatibility
  • 🌐 Optimized for modern runtimes
    • ES2015+ browsers
    • Modern Node.js versions
  • 🎨 Customizable formatting

Installation

npm install obug

Usage

import { createDebug, disable, enable, enabled, namespaces } from 'obug'

// Get the currently enabled namespaces
console.log(namespaces())

const debug = createDebug('my-namespace', {
  // All options are optional

  useColors: true, // false, true, undefined for auto-detect
  color: 2, // custom color
  // custom formatArgs
  formatArgs(args) {},
  formatters: {},
  // Node.js only
  inspectOpts: {},

  // custom log
  log: console.log,
})

debug('This is a debug message')
console.log(
  debug.namespace, // 'my-namespace'
  debug.enabled, // Check if enabled
  debug.useColors, // true
  debug.color, // 2
  debug.formatArgs, // custom formatArgs
  debug.formatters, // {}
  debug.inspectOpts, // {}
  debug.log, // implemented log function
)

// Create a sub-namespace, and it will inherit options from the parent debugger
const sub = debug.extend('sub-namespace')
sub('This is a sub-namespace debug message')
console.log(sub.namespace) // 'my-namespace:sub-namespace'

How to use

Enabling debug output

obug picks up enabled namespaces from the DEBUG environment variable in Node.js, or from localStorage.debug in browsers.

In Node.js:

DEBUG=app:* node app.js

On Windows (CMD):

set DEBUG=app:* & node app.js

On Windows (PowerShell):

$env:DEBUG='app:*'; node app.js

In the browser, set the value in DevTools and refresh the page:

localStorage.debug = 'app:*'

Wildcards and exclusion

The * character is a wildcard. Suppose your library has debuggers named connect:bodyParser, connect:compress, and connect:session — instead of listing each one, use DEBUG=connect:*. Use DEBUG=* to enable everything.

Exclude namespaces by prefixing them with -:

DEBUG=*,-connect:* node app.js

Namespace conventions

If you're using obug in a library, prefix your namespaces with the library name and use : to separate features (e.g. connect:bodyParser). This lets users opt into the parts they care about without guessing names.

Extending a namespace

Use .extend() to create a sub-namespace that inherits options from its parent:

const log = createDebug('auth')
const logSign = log.extend('sign') // 'auth:sign'
const logLogin = log.extend('login') // 'auth:login'

log('hello') // auth hello
logSign('hello') // auth:sign hello
logLogin('hello') // auth:login hello

Formatters

obug uses printf-style formatting. Built-in formatters:

Formatter Representation
%O Pretty-print an Object on multiple lines.
%o Pretty-print an Object all on a single line.
%% Single percent sign. Does not consume an argument.

Other format specifiers supported by Node's util.format (%s, %d, %j, …) and the browser console pass through to the underlying logger.

Custom formatters

Register custom formatters via the formatters option. For example, to render a Buffer as hex with %h:

const debug = createDebug('foo', {
  formatters: {
    h: (v) => v.toString('hex'),
  },
})

debug('this is hex: %h', Buffer.from('hello world'))
//   foo this is hex: 68656c6c6f20776f726c64 +0ms

Dynamic enable / disable

You can toggle namespaces at runtime:

import { disable, enable, enabled, namespaces } from 'obug'

enable('app:*')
console.log(enabled('app:server')) // true

const previous = disable()
console.log(enabled('app:server')) // false

// Restore later
enable(previous)

namespaces() returns the string of currently enabled namespaces. Note that calling enable() overrides the value initially read from DEBUG.

Checking whether a debugger is enabled

Guard expensive work behind the enabled property:

const debug = createDebug('http')

if (debug.enabled) {
  // expensive computation only when enabled
}

You can also force the state by assigning to debug.enabled directly.

Custom output

By default, obug writes to stderr in Node.js and to the console in browsers. Override the log option to redirect output per-namespace:

const log = createDebug('app:log', {
  log: console.log,
})

const error = createDebug('app:error') // still goes to stderr

Environment variables (Node.js)

Name Purpose
DEBUG Enables/disables specific debugging namespaces.
DEBUG_HIDE_DATE Hide date from debug output (non-TTY).
DEBUG_COLORS Whether to use colors in the debug output.
DEBUG_DEPTH Object inspection depth.
DEBUG_SHOW_HIDDEN Shows hidden properties on inspected objects.

Variables prefixed with DEBUG_ are converted to camelCase keys on the options object passed to Node's util.inspect() for the %o / %O formatters.

Original Authors

As obug is a fork of debug with significant modifications, we would like to acknowledge the original authors:

  • TJ Holowaychuk
  • Nathan Rajlich
  • Andrew Rhyne
  • Josh Junon

Sponsors

License

MIT License © 2025-PRESENT Kevin Deng

The MIT License Copyright (c) 2014-2017 TJ Holowaychuk <tj@vision-media.ca>

The MIT License Copyright (c) 2018-2021 Josh Junon