| 
 | 
Brad, in line with my previous post, you basically need three classes:
FieldDefinition (which defines the static characteristics of the field)
FieldData (which holds the actual data object and any runtime attribues)
FieldFormatter (which takes a FieldDefinition and a FieldData object, and 
returns the appropriate representation)
You do NOT create a separate decorator for each field type; you instead make 
your FieldDefinition very flexible and your FieldFormatter very smart.
Joe
---------- Original Message ----------------------------------
From: "Stone, Brad V (TC)" <bvstone@taylorcorp.com>
Reply-To: JAVA400-L@midrange.com
Date: Wed, 14 Mar 2001 08:39:29 -0600
>> >String outputstuff = otherstuff +
> >    (new XMLTDWrapper(myClassList.getField(i).status.alignment,
> >                      myClassList.getField(i).status.width,
> >                      
> myClassList.getField(i).status.data)).toString();
> 
> Hmm.  I think I have lead you seriously astray here.  There 
> is a kind of
> "meta-rule" of O-O that
> I find helpful; if you're passing around a lot of parameters, 
> something is
> wrong with the O-O design.
> Here, that would be my design, not yours.
Well, now that I look at it, it could have been:
    new XMLTDWrapper(myClassList.getField(i).status).toString();
This way Joes rules of using an abstract data type would come into play.  I
could get the data, alignement, and other attributes in the XMLTDWrapper
class.  No reason to pass each one seperately when I could pass the entire
object itself.  This way you have an abstract data type with the general
attributes, then you can extend them for any special attributes you may
need.  If I'm off here, let me know.  
 
> In other words, you really want to see something like:
> 
>   outstring = outstring +   (new 
> address1ToHTML(address1_ref)).toString();
To me, this really seems like a fancy way of hardcoding.  :)   If we make a
decorator object for every field in our system that's a lot of decorators.
Now, multiply that number by every *ML tag we want to use.  Yikes.
Again, let me know if I'm off.  
Sorry if I'm being annoying.  I hope others are reading this too and
hopefully gaining something.
Brad
+---
| This is the JAVA/400 Mailing List!
| To submit a new message, send your mail to JAVA400-L@midrange.com.
| To subscribe to this list send email to JAVA400-L-SUB@midrange.com.
| To unsubscribe from this list send email to JAVA400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner: joe@zappie.net
+---
+---
| This is the JAVA/400 Mailing List!
| To submit a new message, send your mail to JAVA400-L@midrange.com.
| To subscribe to this list send email to JAVA400-L-SUB@midrange.com.
| To unsubscribe from this list send email to JAVA400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner: joe@zappie.net
+---
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.