Skip to content

Latest commit

 

History

History
53 lines (41 loc) · 1.97 KB

README.markdown

File metadata and controls

53 lines (41 loc) · 1.97 KB

SelfRestraint

About

SelfRestraint is a cross platform version of Steve Lambert's SelfControl, written in Python. It allows you to block distracting sites for a set amount of time, so you can use your computer and access the internet without having to worry about distracting sites.

Credits

SelfRestraint was developed by Parker Kuivila The UI and features were inspired by Steve Lambert

License

SelfRestraint is Free Software under the GPL. You are free to share, modify, and add to the code as you wish.

Installation

If you simply want to use the program, just run the included .exe (Windows) or .app (Mac OS X) (Coming Soon!).

Building

If you want to help with the project and build it yourself here's how:

  1. Download the dependancies

  2. For Windows:

    • In the PyInstaller directory run python pyinstaller.py -F -w --icon=<Path_To_Selfrestraint.ico> \path\to\SelfRestraint.py
  3. If you're on OS X:

    • Navigate to SelfRestraint.app/Contents/Resources and open boot.py
    • Add sys.path = [os.path.join(os.environ['RESOURCEPATH'], 'lib', 'python2.7', 'lib-dynload')] + sys.path above sys.frozen = 'macosx_app'

Known Bugs

  • Mac version requires password, messy workaround
  • Does not work on OS X
  • Quitting means you have to re run the app, and let is finish the countdown
  • Sometimes the timer doesn't end and the block lasts forever (until hosts file is changed)

To Do

  • Add compiled .app
  • Integrate better to use Admin privileges on OSX
  • Increase robustness, and make workarounds harder
  • Add site/config file to prevent constant reentering of sites