Skip to main content

Common interface to the WakaTime api.

Project description

https://travis-ci.org/wakatime/wakatime.svg https://coveralls.io/repos/wakatime/wakatime/badge.svg?branch=master&service=github

Fully automatic time tracking for programmers.

This is the common interface for the WakaTime api. You shouldn’t need to directly use this package unless you are creating a new plugin or your text editor’s plugin asks you to install the wakatime cli interface.

Go to http://wakatime.com to install the plugin for your text editor.

Usage

Install the plugin for your IDE/editor at https://wakatime.com/plugins

If you are building a plugin using the WakaTime API then follow the Creating a Plugin guide.

Configuring

Options can be passed via command line, or set in the $HOME/.wakatime.cfg config file. Command line arguments take precedence over config file settings. The $HOME/.wakatime.cfg file is in INI format. An example config file looks like:

[settings]
debug = false
api_key = your-api-key
hidefilenames = false
exclude =
    ^COMMIT_EDITMSG$
    ^TAG_EDITMSG$
    ^/var/
    ^/etc/
include =
    .*
offline = true
proxy = https://user:pass@localhost:8080

Installation

Each plugin should install wakatime for you, except for the Emacs WakaTime plugin. If your plugin does not install wakatime cli(this package), install it with:

pip install wakatime

Troubleshooting

WakaTime CLI writes errors to a common log file in your User $HOME directory:

~/.wakatime.log

Set debug=true in ~/.wakatime.cfg for more verbose logging, but don’t forget to set it back to debug=false afterwards or your editor might be laggy while waiting for wakatime cli to finish executing.

Each plugin also has it’s own log file for things outside of the common wakatime cli:

  • Atom writes errors to the developer console (View -> Developer -> Toggle Developer Tools)

  • Brackets errors go to the developer console (Debug -> Show Developer Tools)

  • Eclipse logs can be found in the Eclipse Error Log (Window -> Show View -> Error Log)

  • Emacs messages go to the messages buffer window

  • Jetbrains IDEs (IntelliJ IDEA, PyCharm, RubyMine, PhpStorm, AppCode, AndroidStudio, WebStorm) log to idea.log (locating IDE log files)

  • Komodo logs are written to pystderr.log (Help -> Troubleshooting -> View Log File)

  • Netbeans logs to it’s own log file (View -> IDE Log)

  • Notepad++ errors go to AppData\Roaming\Notepad++\plugins\config\WakaTime.log (this file is only created when an error occurs)

  • Sublime Text logs to the Sublime Console (View -> Show Console)

  • TextMate logs to stderr so run TextMate from Terminal to see any errors (enable logging)

  • Vim errors get displayed in the status line or inline (use :redraw! to clear inline errors)

  • Visual Studio logs to the Output window, but uncaught exceptions go to ActivityLog.xml (more info…)

  • Xcode type sudo tail -f /var/log/system.log in a Terminal to view Xcode errors

Check that heartbeats are received by the WakaTime api with the last_heartbeat and last_plugin attributes from the current user api resource. Saving a file forces a heartbeat to be sent.

Contributing

Before contributing a pull request, make sure tests pass:

virtualenv venv
. venv/bin/activate
pip install tox
tox

Many thanks to all contributors!

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wakatime-4.1.2.tar.gz (1.7 MB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page