Git Product home page Git Product logo

charm's Introduction

+---------------------------------------------------------------------------+
|                                                                           |
|    CHARM - A LiveJournal, Atom, and MetaWeb API client for Python
|
|    Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
|                  by Lydia Leong
|    Open Source:  GNU General Public License v2
|                                                                           |
+---------------------------------------------------------------------------+


FEATURES

- Charm is an entirely text-based client. Consequently, its system and
  hardware requirements are negligible; you just need something that
  supports the Python interpreter.

- Charm has equal facility across a broad spectrum of blogging platforms.
  It has full-fledged support for LiveJournal-based sites, but it also
  supports the Atom API (for Blogger) and the MetaWeb API (for Wordpress,
  Movable Type, and so on). Atom support requires that you have the
  Feedparse module from http://feedparser.org/ installed.

- Charm contains four major utilities in a single client: menu-driven
  posting/editing, "quick" command-line posting, archival, and
  friends-checking.

- Normal, menu-driven mode. Charm uses menus of single-letter commands,
  and is thus easy to use. There's a full array of post and edit options.

- "Quick" mode. Command-line-only, reading the body of the post from
  stdin. This allows very fast posting for casual use. But it also
  allows input to be piped to a post or taken from an arbitrary file,
  for filter-like uses. Thus, you could take some text, pipe it to the
  Enchefferizer (the "Swedish chef" text converter), or to a text-to-HTML
  converter like Markdown or Textile, and that pipe that  to Charm for 
  posting to your journal. 

- Friends-checking tool. Background polling mode for friend updates,
  displayed like the Unix 'newmail' utility. It can check all friends,
  or just specific friend groups. Even if you don't use Charm for
  anything else, you might find this useful.

- Mass archiving. This is part of Charm's menu-driven mode. You can
  download and save part or all of your journal or a community. This
  is another useful standalone feature, particularly since you can set
  up your computer to automatically synchronize your offline archive
  with your online journal on a nightly basis.

- Charm handles multiple usernames and shared journal access, including
  handling profiles for non-LiveJournal accounts (like DeadJournal).
  Passwords can optionally be stored/sent as a MD5 hash. It also has the
  ability to quickly cross-post between multiple journals/blogs.

- Charm has a full set of features for editing and posting. Anything you
  can do from the LiveJournal posting and editing Web pages, you can do
  from Charm. Charm can also use an external spellchecker, and it can
  invoke external filters to modify the message body.

- You can select moods, journals, picture keywords, friend groups, tags,
  etc. from menus. Unlike other console-based clients, you don't have to
  type these in; you just pick an option number from a menu.

- Charm supports XMMS-based music detection, if you have the PyXMMS
  module from http://www.via.ecp.fr/~flo/ installed.

- You can save, and later resume working on, an entry-in-progress.
  You can also save an entry while your computer is offline, and then
  quickly post it when you get back online.

- You can set up templates, with default data in each of the fields, along
  with a default message body.

- You can select online entries to edit in a flexible manner: most
  recent, last N entries, and by date. Choosing entries by date brings up
  a calendar of the chosen month, showing the number of posts each day.

- When you post something, there's an option to archive it; you can also
  optionally archive edits made to posts already online. The archive
  organization is configurable; you can put all posts in one directory,
  use subdirectories for each year, and use subdirectories for each
  month (under subdirectories for each year).

- Charm fully supports listing, adding, removing, and editing friends and 
  friends groups.

- Charm supports the LiveJournal administrative console commands, so
  you can use it to manage community membership, manage posting access
  to shared journals, and manage user bans.

- Charm respects Unix environment variables for default programs.

- Charm has proxy support. Python supports proxies transparently; just set
  your HTTP_PROXY environment variable to proxyhost:portnumber.


GETTING STARTED

A manual has been included with this distribution. Read the "charm.html"
file in a browser for extensive details on how to install and use Charm.

For help, type:  charm --help
Normally, type:  charm

Also, look at sample.charmrc and make a .charmrc file in your home
directory.

A minimal .charmrc file for LiveJournal contains the line:
    login = yourusername yourpassword
(Fill in your own LiveJournal username and password.)

A minimal .charmrc file for Blogger contains the line:
    blogger = yourusername yourpassword
(Fill in your own Blogger username and password.)


WHERE TO FIND MORE INFORMATION

Charm's home page is at http://ljcharm.sourceforge.net/

There, you can read the Charm manual and other documentation, download
the latest version, and find links to the Charm LiveJournal community 
and other support resources.


INSTALLATION

If you wish to do so, you can just run Charm directly out of the directory
that you unpacked it into, or wherever else you care to place the
necessary files (charm, and ljcharm.py).

However, if you have access to do so (on Unix systems, this will generally
require root privileges), and you either have at least Python 1.6 or the
Distutils module installed, you can install Charm in your main Python
modules directory, using "python setup.py install".

For more information, see Charm's manual (included as charm.html).


COMPATIBILITY

Charm was written for Python 2.5 on a Unix system.

It should work with later as well as earlier versions of Python, going
back as early as Python 1.5. (If you encounter problems that seem
version-specific, please email the author.)

Because Charm is written in Python, it should be reasonably cross-platform.
It should work on any Unix-based system (including Linux). It is likely to
work on Windows, and it will probably work on the Macintosh. (Again, 
please email the author with portability problems.)

Of course, you will need to have Python installed on your machine.
See http://www.python.org/ to download a copy of Python. (Linux users
will probably have Python installed already.)


+---------------------------------------------------------------------------+
|                                                                           |
|    Please email the author at [email protected] with any
|    comments, suggestions, and bug reports.
|                                                                           |
+---------------------------------------------------------------------------+

charm's People

Contributors

ssavitzky avatar binarymutant avatar

Stargazers

Mark C avatar

Watchers

 avatar Mark C avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.