From: Robert <rsz...@mu...> - 2006-12-11 08:03:13
|
Luke: this would be the obvious solution if it did work (this actually was the first thing I tried), alas no go, at least on 0.7.0 and 0.7.1. Oleg: this gives you no control over actual table names. I forgot to mention this is a must as well, we have tables from an external source (exported from another DBMS) that are used by some other software too. |
From: Oleg B. <ph...@ph...> - 2006-12-12 16:10:15
|
On Mon, Dec 11, 2006 at 09:03:04AM +0100, Robert wrote: > Oleg: this gives you no control over actual table names. I have found the root of the problem: class common_sqlmeta(sqlmeta): idName = "my_id" class Test1_sqlmeta(common_sqlmeta): table = "my_test_11" print common_sqlmeta.idName # => my_id print Test1_sqlmeta.idName # => None That None has been set by sqlmeta.__classinit__(). That's certainly a bug that must be fixed. I'll consult Ian about it. Oleg. -- Oleg Broytmann http://phd.pp.ru/ ph...@ph... Programmers don't die, they just GOSUB without RETURN. |
From: Oleg B. <ph...@ph...> - 2006-12-22 15:52:56
|
On Mon, Dec 11, 2006 at 09:03:04AM +0100, Robert wrote: > Oleg: this gives you no control over actual table names. I forgot to > mention this is a must as well, we have tables from an external source > (exported from another DBMS) that are used by some other software too. I fixed this in the trunk (revision 2247). You can now inherit idName from the parent sqlmeta class: class myid_sqlmeta(sqlmeta): idName = "my_id" class TestSO12(SQLObject): class sqlmeta(myid_sqlmeta): table = "my_test_12" name = StringCol() The test has been added to the test_basic.py. Oleg. -- Oleg Broytmann http://phd.pp.ru/ ph...@ph... Programmers don't die, they just GOSUB without RETURN. |