-----Original Message----- From: Jeff Hobbs [mailto:jeffh@ActiveState.com] Sent: Sunday, October 17, 2004 6:22 PM To: Schofield, Bryan (GE Transportation); xotcl@alice.wu-wien.ac.at Subject: RE: [Xotcl] xotcllib?
xow - A megawidget framework. This is a package that allows xotcl objects to be megawidgets.
Does this handle the option db correctly, do composition of megawidgets, handle focus and events right, etc.?
No, currently doesn't handle the option db. This is a tricky area of building megawidgets. An xow widget can be based off of any other existing widget or megawidget. That can make things a little more complicated since xow widgets can & will pick up option db settings for base widgets and the -class option isn't available for most widgets. Personally, I am aware of this shortcoming and work around it. I'd rather not have this feature than have one that works partially and is unpredictable. Since I haven't had the time to devote to writing a complete implementation, I haven't done anything with it.
There is no special code to handle composition of megawidgets, focus, or event processing.
xcentuate - a theme engine for tk. This isn't all that important on windows, but on unix tk often needs a little help looking good. This package provides a very simple method of defining and changing the look of tk apps. It can even do it on the fly.
I would not propagate this in favor of Tile. There is also already the 'style' package in tklib (which again may be abortive when Tile becomes part of 8.5). What features does xcentuate really provide? Should they not just go into 'style'?
I'm not sure what "style" package you are refering to. I see none in the docs for TkLib, but maybe I missed them or it's not in the latest official release. I did manage to google up a "as::style" package that you appear to have written. So I'll assume that's the package to which you refer.
xcentuate provides the common things like colors and borderwidth for widgets. It also provides some named colors and eventually named fonts. I have some good font generation routines already, I just need to convert them to xotcl and integrate them. The widget classes and options applied to those classes are not hard coded in xcentuate. It can be trained to apply style to new widget classes or change what options are applied. Finally, xcentuate is OO. I like objects, I like them alot. This package works well for me but I look forward to Tile being part of 8.5 so I can declare this obsolete.
Below is an example of a LookAndFeel that shows what xcentuate can control right now. This particuler LookAndFeel gets applied by default on unix. Xcentuate will also learn what tk looks like by default so there is always a "default" LookAndFeel that can be applied. Oh, xcentuate can change styles (LookAndFeels) on the fly.
LookAndFeel lightgrey \ -name "Light Grey" \ -description "A simple light grey palette" \ -activebackground grey90 \ -activeforeground red \ -background grey80 \ -disabledbackground grey85 \ -disabledforeground grey40 \ -foreground black \ -highlightbackground grey80 \ -highlightcolor red \ -insertbackground red \ -readonlybackground grey90 \ -selectbackground skyblue \ -selectcolor red \ -selectforeground black \ -textbackground white \ -textforeground black \ -troughcolor grey75 \ -borderwidth 1 \ -labelframepad 4 \ -labelframebd 2 \ -texterrorbg #fee \ -texterrorfg red3 \ -textwarnbg PeachPuff \ -textwarnfg orange2 \ -textokbg #dfd \ -textokfg green3 \ -textnotebg #ffd \ -textnotefg yellow3 \ -textinfobg #def \ -textinfofg blue2 lightgrey apply
xout - a unit testing framework. I know, I know, tcl already provides one, tcltest. But I found tcltest to be too cumbersome and clunky. I'd write some tests, but maintaining those tests often was neglected because of the amount of programming overhead needed to write complex test cases. xout
Did you compare against tcltest v1 or v2?
Version 2. Tcltest is more powerful, no question about that. But for testing complex scenarios, I like to build on the success of one test later. For example, consider the following distinct events that I can test, where later tests use something from previous tests.
1. Can I create object X? 2. Can object X do something? 3. Can object X do something else? 4. Can I delete object X and it clean up properly?
Thing can get way more complicated than that, too. Imagine trying to test db or remote server interaction. With tcltest, I'd have to create object X or connect to a db or server in the setup of every test. I can appreciate isolating tests from one another so that one test doesn't impact another, which is what tcltest does. To achieve that, I have two level in my test hierachy. One is the TestSuite. No two suites can interact with each other. They run in their own iterpreter from scratch. A TestSuite has one or more Tests that *can* interact with each other. Also, on a side note, I hate having to specify a test name with tcltest.
test example-1.1 {test file existence} -setup { set file [makeFile {} test] } -body { file exists $file } -cleanup { removeFile test } -result 1
It's fine until you realize next month that you need a new test, and that it make more sense from a readability viewpoint to stick it in between example-1.1 and example-1.2. Do I call it example-1.1.5 or renumber the other tests below? The test name doesn't add much to me, the tester. It's the description that matters. For comparison purposes, xout test file would be structured as follows:
TestSuite foo \ -description "blah" \ -setup {set file [makeFile {} test]} \ -cleanup {removeFile test} foo test \ -description "test file existence" -result 1 \ -script {file exists $file}
Finally, xout is only a framework. It can be embedded into other applications such as an IDE. That can easily find and query TestSuite objects to run and get their results. Just so happens that the GUI can also be embedded in or run standalone.
I mention all of this because if other have some handy xotcl packages, I'd be interested in creating a formal xotcllib project. Perhaps something at sourceforge. I'll be making these available soon either way.
I think that would be a handy thing as an addon.
Jeff Hobbs, The Tcl Guy http://www.ActiveState.com/, a division of Sophos
I threw some screen shots of xcentuate & xout in action on my (unfinished) website if anyone wants to take a look. http://www.abschofield.com/code/ss/
Sorry for being long winded.
-- bryan
xow - A megawidget framework. This is a package that allows xotcl objects to be megawidgets.
Does this handle the option db correctly, do composition of megawidgets, handle focus and events right, etc.?
No, currently doesn't handle the option db. This is a tricky area of building megawidgets. An xow widget can be based off of any other existing widget or megawidget. That can make
...
There is no special code to handle composition of megawidgets, focus, or event processing.
While I don't want to discourage good coding exercises, I do want to encourage others to use code based on all the best practices. We don't have a perfect megawidget framework to rely on yet, but hopefully you'll be willing to take part when we get around to it, or maybe work on yours until it is that system. ;)
xcentuate - a theme engine for tk. This isn't all that
I would not propagate this in favor of Tile. There is
I'm not sure what "style" package you are refering to. I see none in the docs for TkLib, but maybe I missed them or it's not in the latest official release. I did manage to google up a "as::style" package that you appear to have written. So I'll assume that's the package to which you refer.
Yes, that's a variant that was included.
xcentuate provides the common things like colors and borderwidth for widgets. It also provides some named colors and eventually named fonts. I have some good font generation
Hmmmm ... ok, you have created something more for users to define their own themes, whereas 'style' says "these are better overall alternate themes". I must say that I personally encourage the latter. It's a pity you couldn't make it to Tcl'2004 last week, because I had a tutorial and talk on these points. I don't mean to pick on you, I just want to give my ideas and how they may affect your current efforts.
The whole idea of themeing, which will be core in 8.5, is to enable a better look for Tk. However, it is not intended for the user (in the common case) to change this theme. The functionality is there merely for Tk to better adapt to current styles. Thus, the 'style' code defines styles for users to just use, rather than providing a framework to create their own.
I look forward to Tile being part of 8.5 so I can declare this obsolete.
Note that tile works perfectly well with 8.4. ActiveState will actually be shipping an app RSN that uses tile. What is now a testbed will soon be a core feature, but that doesn't mean you can't use it now.
interact with each other. Also, on a side note, I hate having to specify a test name with tcltest.
...
It's fine until you realize next month that you need a new test, and that it make more sense from a readability viewpoint to stick it in between example-1.1 and example-1.2. Do I call it example-1.1.5 or renumber the other tests below? The test name doesn't add much to me, the tester. It's the description that matters. For comparison purposes, xout test
OK, I've dealt with this before. There is nothing in the naming of that test that requires it be numbers, that is just convention. It makes it easier for grouping and such, and is handy when searching through the test suite after failures. In your example below:
file would be structured as follows:
TestSuite foo \
-description "blah" \ -setup {set file [makeFile {} test]} \ -cleanup {removeFile test} foo test \ -description "test file existence" -result 1 \ -script {file exists $file}
What happens when you don't provide a description? This should be a required field, as it is in tcltest, so why have it an option? Otherwise, I see the structure you have chosen could make it easier to build tests.
Finally, xout is only a framework. It can be embedded into other applications such as an IDE. That can easily find and query TestSuite objects to run and get their results. Just so happens that the GUI can also be embedded in or run standalone.
I like the UI you added to it.
I threw some screen shots of xcentuate & xout in action on my (unfinished) website if anyone wants to take a look. http://www.abschofield.com/code/ss/
Very nice.
Sorry for being long winded.
No problem, and I don't want to sound negative. I'm just trying to assist constructively. As I've told Gustaf and Uwe before, xotcl (or some close variant) could be the OO for the core, if it provided 100% itcl compatability (for the many many folks that rely on itcl).
Jeff