This is the start of a series on the work we're doing upgrading BandRadar's components. BandRadar's development started in 2006, and used the default components of TurboGears at the time: SQLObject for ORM, kid for templating, tgwidgets for widgeting, mochikit for js library, and CherryPy as appserver.
Basically all of these components are now obsolete, or at least no longer recommended for new TG/TG2 projects. But they still work fine, so why change?
Good question. I'm hoping that re-examining the choices we made in implementing BandRadar version 1 will bear dividends in terms of simplifying the code or making it easier to add new functionality, but honestly it's not clear at this point whether time spent on this work will have more value than spending it on extending the current code. It also depends on how hard moving to the new components is. Thankfully, TurboGears will let us transition to new components in stages, instead of all at once.
The plan:
Basically all of these components are now obsolete, or at least no longer recommended for new TG/TG2 projects. But they still work fine, so why change?
Good question. I'm hoping that re-examining the choices we made in implementing BandRadar version 1 will bear dividends in terms of simplifying the code or making it easier to add new functionality, but honestly it's not clear at this point whether time spent on this work will have more value than spending it on extending the current code. It also depends on how hard moving to the new components is. Thankfully, TurboGears will let us transition to new components in stages, instead of all at once.
The plan:
- SQLObject to SQLAlchemy (Elixir)
- kid to Genshi
- tg.widgets to ToscaWidgets
- CherryPy to Pylons/mod_wsgi
2 comments:
This is indeed a great start to a series that will be exceptionally valuable to the TG community. To answer your blog question about logging your entries: One way to solve the problem is with mapper extensions. Here is a link for you:
http://www.sqlalchemy.org/docs/05/reference/orm/interfaces.html#sqlalchemy.orm.interfaces.MapperExtension
hope that helps.
-chris
Really nice we sure need more examples like this. Some comments on your migration.
1- I'll suggest going to TG1.1 first, this will take care of SO-SA and kid-genshi.
2- JS and toscawidgets next.
3- TG2 code base (IE pylons)
From all those steps you are probably starting with the most complex one SO->SA
As a side note you may way to check out SA declaratives (default as 0.5) IMO it's as good as Elixir for the most common cases so it should cover 80% of the use cases without the extra dependency.
Post a Comment