Rocksolid Light

News from da outaworlds

mail  files  register  groups  login

Message-ID:  

Always do right. This will gratify some people and astonish the rest. -- Mark Twain


comp / comp.lang.tcl / Re: OOP design choices

SubjectAuthor
* OOP design choicesLuc
`- Re: OOP design choicesRich

1
Subject: OOP design choices
From: Luc
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Sun, 29 Sep 2024 13:12 UTC
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: luc@sep.invalid (Luc)
Newsgroups: comp.lang.tcl
Subject: OOP design choices
Date: Sun, 29 Sep 2024 10:12:32 -0300
Organization: A noiseless patient Spider
Lines: 23
Message-ID: <20240929101232.6a49c00b@lud1.home>
MIME-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit
Injection-Date: Sun, 29 Sep 2024 15:12:32 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="a993be8ecddfe96ea6be6a8a851cb88f";
logging-data="1859591"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18szXGZ0gP3yd6KJzM5IWIam6uCizIbb5k="
Cancel-Lock: sha1:INdAr204yGZwRRuyL29IHFRG+vQ=
View all headers

I am rewriting my application which has tabs.

Now I hesitate. Which is better?

1. Create the overall GUI and code as procedural and the tabs as
objects/a class.

2. Create the overall GUI as a big object (superclass) with tabs as
subclasses.

3. Create the overall GUI as an object/class with tabs as separate
classes.

4. Create the overall GUI as a big object (superclass) with tabs as
methods.

Thank you for any ideas.

--
Luc
>>

Subject: Re: OOP design choices
From: Rich
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Sun, 29 Sep 2024 16:29 UTC
References: 1
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: rich@example.invalid (Rich)
Newsgroups: comp.lang.tcl
Subject: Re: OOP design choices
Date: Sun, 29 Sep 2024 16:29:24 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 51
Message-ID: <vdbv94$1q78c$1@dont-email.me>
References: <20240929101232.6a49c00b@lud1.home>
Injection-Date: Sun, 29 Sep 2024 18:29:24 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="04222d8a39e29353224196a247647397";
logging-data="1907980"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18tFqN/4gPKUbWtQqZcnCYu"
User-Agent: tin/2.6.1-20211226 ("Convalmore") (Linux/5.15.139 (x86_64))
Cancel-Lock: sha1:b6aODaPhNLue8WgzkwwPEZzRSa4=
View all headers

Luc <luc@sep.invalid> wrote:
> I am rewriting my application which has tabs.
>
> Now I hesitate. Which is better?
>
> 1. Create the overall GUI and code as procedural and the tabs as
> objects/a class.

If by "has tabs" you are referring to the project you posted about here
some months ago, then this layout (with each tab being backed by an
object) would be most similar to what you have now. Your 'namespaces'
per tab were becoming very "home-made object" like as you progressed.

> 2. Create the overall GUI as a big object (superclass) with tabs as
> subclasses.

Here I suspect you may be getting confused by the implementation detail
in TclOO that classes are themselves 'objects'. While TclOO would
allow you to use the 'superclass' itself as an object for the overall
GUI, such usage is not the typical usage of classes/superclasses. The
class/superclass concept is traditionally used to create a templating
system for creating the end objects that are used by the code. A class
groups together all the common aspects (variables/methods) of a set of
objects (i.e., that mammals all have hair) so you can define the
commonality once, and then use the template (the class) to stamp out
objects that differ only in things specific to that object (i.e., that
one has blue eyes, the other brown eyes). Superclasses then are
typically used to stamp out similar classes by grouping all the
commonality into one place, and then each stamped out class is tweaked
just a little for the small difference it has from other classes
stamped out from that superclass.

> 3. Create the overall GUI as an object/class with tabs as separate
> classes.

This is also another way, although the conventional description would
be the GUI as one object, and each tab as its own object.

But do you have gui aspects that are independent of each tab? If yes,
then this (or #1) would be a somewhat conventional design, provided you
used objects for the tabs rather than TclOO classes. You can have a
'class' that holds all the common aspects of a tab, but you'd stamp out
an object from the class to be the backing handler of a given tab.

> 4. Create the overall GUI as a big object (superclass) with tabs as
> methods.

Not really object oriented in the conventional sense. This is simply
taking your existing procedural code, wrapping it in a thin veil of
"OO" and calling the result "OO". This just gives you OO in name only
with everything simply being procedural inside.

1

rocksolid light 0.9.8
clearnet tor