14
Feb 08

A Future Web Development Framework – Template View

Path: mv.asterisco.pt!mvalente
From: mvale…@ruido-visual.pt (Mario Valente)
Newsgroups: mv
Subject: A Future Web Development Framework – Template View
Date: Wed, 13 Feb 07 18:43:21 GMT

I should start this post (hopefully the last detail before
going into a synthesis post) by remembering some words from
my initial post in this series:

“Meanwhile, lots of stuff has come up: Django, Pylons,
TurboGears, Ruby on Rails, you name it… I dont want to
go over extensively why I dont like any of them, but let
me just state this: if the “framework” allows for the
mixing of layout/design/HTML with code/programming, for
me is enough of a disqualifier.”

The problem, as I stated before, is that current frameworks
stuff a lot of power into the templating languague. And that
is not only unnecessary but its a bad, bad thing.

If you dont understand why 1) embedding Python/PHP/Ruby/etc
in HTML is bad or 2) outputting HTML from Python/PHP/Ruby/etc
is worse, I’m not even going to try and explain. Not only
because that means you are clueless but also because someone
else has done it better that me:

http://www.stringtemplate.org/about.html
http://www.cs.usfca.edu/~parrt/papers/mvc.templates.pdf

Now the problem is that although I agree with this paper and
the rules set forth in it, I disagree with the implementation.
Allowing for “$var” statements in the templates is still, in
my view, some form of entanglement and breakup of the MVC pattern.

What would be the best way to do it? Well look no further than
some already existent template engines:

PyMeld
http://entrian.com/PyMeld/

HTMLTemplate
http://freespace.virgin.net/hamish.sanderson/htmltemplate.html

Meld3
http://www.plope.com/software/meld3

They allow for the insertion of values (data binding) through
the use of HTML element attributes. Both HTMLTemplate and Meld3
create new attributes (“node” and “meld:id” respectively) but
PyMeld does it better: it simply uses the “id” attribute to do
value replacement. This is, in my opinion, the best way to do
a templating system. And there’s no need to make it “powerful”
through the introduction of loop control and other stuff like
Genshi or Zope Page Templates.

Does this mean that I have found my perfect templating engine?
No. You see, these are serverside templating engines and the
template/view should be implemented at the client level, if you
want to adhere to the MVC pattern.

What I would like is something like these templating engines:

Ajax Pages
http://ajax-pages.sourceforge.net/

Javascript Templates
http://www.fishwasher.com/jst/

Trimpath Junction Javascript Templates
http://code.google.com/p/trimpath/

Unfortunately all of these engines make the usual mistake of
introducing new syntax to HTML (the “$var” problem or variants
thereof instead of relying on the existing HTML markup, namely
the “id” element markup.

To sum it up, what I would rely like is a Javascript implementation
of Meld.

Aditional templating functionalities that might not be provided
through the use of the “id” attribute (although I think that it
would be all that is needed) could be added through the use of
aditional semantic potential to existing HTML markup with Javascript.
See for example Inc, for JS code include (although I would prefer
for this to be done through the implementation of the “src=” attribute
for DIVs.

http://johannburkard.de/blog/programming/javascript/inc-a-super-tiny-client-side-include-javascript-jquery-plugin.html

— MV


12
Feb 08

The Wealth of Networks

Path: mv.asterisco.pt!mvalente
From: mvale…@ruido-visual.pt (Mario Valente)
Newsgroups: mv
Subject: The Wealth of Networks
Date: Tue, 12 Fev 08 22:26:21 GMT

Great book to read, freely available with a CC license.

The Wealth of Networks: How Social Production Transforms Markets and Freedom

http://www.amazon.co.uk/Wealth-Networks-Production-Transforms-Markets/dp/0300125771/
http://www.benkler.org/wealth_of_networks/

WARNING: this book, although advocating open source, creative
commons and collaborative (not colectivist) endeavours, is an
individualist, capitalist and neoliberal political manifesto. Do
not read if your collectivist mindset (right or left wing) cannot
be challenged and doing so would put at risk what mum and dad taught
you about politics (probably together with collectivist religion dogmas).

— MV


12
Feb 08

Board Games

Path: mv.asterisco.pt!mvalente
From: mvale…@ruido-visual.pt (Mario Valente)
Newsgroups: mv
Subject: Board Games
Date: Tue, 12 Fev 08 16:18:21 GMT

Ah, the wonders of the academic world and free time
on your hands…

Board Game Studies Colloquium XI
Museum of Science of the University of Lisbon, 23-26 April 2008
http://ludicum.org/bgs08/

You can count me in! I’ve registered :-)…

— MV


09
Feb 08

Fun Stuff Back in 2002

Path: mv.asterisco.pt!mvalente
From: mvale…@ruido-visual.pt (Mario Valente)
Newsgroups: mv
Subject: Fun Stuff Back in 2002
Date: Sat, 09 Fev 08 06:23:21 GMT

http://mv.asterisco.pt/2002/

Resposta Aberta a Comunidade Gildot
http://mv.asterisco.pt/2002/cat.cgi?Resposta%20Aberta%20a%20Comunidade%20Gildot

http://www.gildot.org/articles/02/02/20/1148202.shtml

La para o fim:

“Ah e fiquei bastante preocupado com os teus comentarios, tou lixado
isto vindo de uma pessoa que acha que o python tem futuro, e de preocupar
realmente.”

Este caramelo hoje em dia quase que aposto que ou e um zelota do
Python ou entao, para nao engolir o sapo, e um fanatico de Ruby (on Rails,
claro). Um gajo cospe para o ar e depois a forca da gravidade…

— MV


07
Feb 08

I Will Remember

Path: mv.asterisco.pt!mvalente
From: mvale…@ruido-visual.pt (Mario Valente)
Newsgroups: mv
Subject: I Will Remember
Date: Thu, 07 Feb 08 14:09:21 GMT

“And we wonder how machines
Can steal each others dreams
From points that are unseen”

http://www.youtube.com/watch?v=GZ3iR6RWOR4

— MV