[ANN] SkunkWeb 3.0 Released!

Drew Csillag Drew Csillag <drew_csillag@geocities.com>
Thu, 23 Aug 2001 12:29:27 -0400


After a couple of Betas, version 3.0 of The SkunkWeb Web Application
Server has just been released.

The release is available from the SkunkWeb home page at
	http://skunkweb.sourceforge.net

or directly from 
        http://prdownloads.sourceforge.net/skunkweb/skunkweb-3.0.tgz

What's new?
------------------------------
* Fixes to the demo docs due to changes at slashdot and freshmeat
* Fix to remove an erroneous SyntaxWarning
* no longer require GNU xargs, GNU find or GNU bash
* PyDO now should work with Python 2.2
* PyDO PostgreSQL connection fixes
* sessionHandler fixes
* <:sendmail:> tag fixed
* configure cleanups

What is it?
------------------------------
SkunkWeb is (yet another) web application server.  The things that make it
different from other app servers are:

Uses Python
	* Python is easy to learn for both new programmers and experts alike
	* senior programmer types like it too (vs. say tcl)
        * extensible with Python, of course
	* extensible with C/C++ for speed and/or linkage to C/C++ libraries
          via static *or* dynamic linking

Extensible
	* Relatively simple extension API
	* can easily handle authentication, custom url building/parsing 
          schemes and custom tags

Encourages component based design
	* more than just "include"
	* not just another ASP/JSP like thing
	* a powerful templating language 
	* encouraged by caching options (see below)
	* component output can be either HTML or Python objects
	* can write components in either STML or Python
	* can also call components on other skunkweb servers
	
Message Catalogs
	* makes multi-lingual sites much easier
	* support variable substitution in messages

Speed
	* templates are compiled to Python bytecode
	* extensive caching (to disk and optionally memory) of:
		o compiled forms of templates
		o digested message catalogs
		o output of components
		o python modules and python components
	* cache *is* sharable between machines if using a
	  shared filesystem! (can be more than one shared filesystem
          for speed, redundancy and flexibility)
	* caching is flexible and as finite as your disk space
	* components can be rendered after the response is sent if 
	  a slightly stale version is available --- resulting in
	  better response times via deferred components

Documentation
	* extensive documentation available in HTML, PostScript, PDF & text
          --well not yet, but getting there
	* have automatic documentation tools to generate documentation for 
	  STML templates (but don't use the manual stuff, it sucks).

Process Model
        * Uses multi-process, versus multi-threading which makes better
          use of multiple processors (because of the global interpreter
          lock in Python), and is safer in that if one process crashes, 
          it won't kill the entire server.

No magic (zodb <wink>).


Very best wishes to all,

-Drew

-- 
print(lambda(m,d,y):['Sun','Mon','Tues','Wednes','Thurs','Fri','Satur'
][(lambda(m,d,y):(23*m/9+d+4+y/4-y/100+y/400)%7)(m<3and(m,d+y,y-1)or(
m,d+(y-2),y))])(map(int,raw_input('mm/dd/yyyy>').split('/')))+'day'