Re: [Mav-user] Using decorator pattern on controllers

2002-08-09 Thread jim moore

This shouldn't be too difficult. Just have your decorator implement
ControllerSingleton, then you will get an init method in which the
controller node from maverick.xml is passed in.

If you had a controller node that looked like:

controller class=com.foo.bar.MyControllerDecorator
decorated class=com.foo.bar.SomeExistingController
/controller

Your decorator could hold an internal controller. When the decorator's go
method was called, it could call go on the decorated controller, read the
result and the model, and still do its own thing. This is actually similar
to what I just sent as the CompositeController.

--jim

- Original Message -
From: Roy Truelove [EMAIL PROTECTED]
To: [EMAIL PROTECTED]
Sent: Friday, August 09, 2002 12:04 PM
Subject: [Mav-user] Using decorator pattern on controllers


 Hey all,

 I'm looking into the feasablity of using the Decorator pattern* to
 create Controllers.  In the friendbook example, each controller inherits
 from another controller which inherits from another controller, each one
 adding a little functionality.  The problem with this is that you can't
pick
 and choose which controllers you want to use, you have to use extentions
of
 extentions.  This would certainly help with the composite view issues that
 are being discussed, as well as securing controllers, etc.

 The problem is .. how can this be done while keeping Maverick backwards
 compatable *and* keeping configuration to a minimum?  Any ideas?  Since
 controllers are instantiated using reflections and not explicitly, is the
 Decorator pattern even possible?

 *Decorator pattern info :
 http://www.javaworld.com/javaworld/jw-12-2001/jw-1214-designpatterns.html

 -Roy



 ---
 This sf.net email is sponsored by:ThinkGeek
 Welcome to geek heaven.
 http://thinkgeek.com/sf
 ___
 Mav-user mailing list
 [EMAIL PROTECTED]
 https://lists.sourceforge.net/lists/listinfo/mav-user
 Archives are available at http://www.mail-archive.com/



---
This sf.net email is sponsored by:ThinkGeek
Welcome to geek heaven.
http://thinkgeek.com/sf
___
Mav-user mailing list
[EMAIL PROTECTED]
https://lists.sourceforge.net/lists/listinfo/mav-user
Archives are available at http://www.mail-archive.com/



Re: [Mav-user] Using decorator pattern on controllers

2002-08-09 Thread jim moore

On a related note, I'm wondering if we should make ControllerFactory a
public class. That way decorators would be free to use it's
createController() method. There's a lot of good functionality in there, and
I don't really see a reason to hide it away. What do you think Jeff?

--jim

- Original Message -
From: jim moore [EMAIL PROTECTED]
To: [EMAIL PROTECTED]
Sent: Friday, August 09, 2002 12:23 PM
Subject: Re: [Mav-user] Using decorator pattern on controllers


 This shouldn't be too difficult. Just have your decorator implement
 ControllerSingleton, then you will get an init method in which the
 controller node from maverick.xml is passed in.

 If you had a controller node that looked like:

 controller class=com.foo.bar.MyControllerDecorator
 decorated class=com.foo.bar.SomeExistingController
 /controller

 Your decorator could hold an internal controller. When the decorator's go
 method was called, it could call go on the decorated controller, read the
 result and the model, and still do its own thing. This is actually similar
 to what I just sent as the CompositeController.

 --jim

 - Original Message -
 From: Roy Truelove [EMAIL PROTECTED]
 To: [EMAIL PROTECTED]
 Sent: Friday, August 09, 2002 12:04 PM
 Subject: [Mav-user] Using decorator pattern on controllers


  Hey all,
 
  I'm looking into the feasablity of using the Decorator pattern* to
  create Controllers.  In the friendbook example, each controller inherits
  from another controller which inherits from another controller, each one
  adding a little functionality.  The problem with this is that you can't
 pick
  and choose which controllers you want to use, you have to use extentions
 of
  extentions.  This would certainly help with the composite view issues
that
  are being discussed, as well as securing controllers, etc.
 
  The problem is .. how can this be done while keeping Maverick backwards
  compatable *and* keeping configuration to a minimum?  Any ideas?  Since
  controllers are instantiated using reflections and not explicitly, is
the
  Decorator pattern even possible?
 
  *Decorator pattern info :
 
http://www.javaworld.com/javaworld/jw-12-2001/jw-1214-designpatterns.html
 
  -Roy
 
 
 
  ---
  This sf.net email is sponsored by:ThinkGeek
  Welcome to geek heaven.
  http://thinkgeek.com/sf
  ___
  Mav-user mailing list
  [EMAIL PROTECTED]
  https://lists.sourceforge.net/lists/listinfo/mav-user
  Archives are available at http://www.mail-archive.com/



 ---
 This sf.net email is sponsored by:ThinkGeek
 Welcome to geek heaven.
 http://thinkgeek.com/sf
 ___
 Mav-user mailing list
 [EMAIL PROTECTED]
 https://lists.sourceforge.net/lists/listinfo/mav-user
 Archives are available at http://www.mail-archive.com/




---
This sf.net email is sponsored by:ThinkGeek
Welcome to geek heaven.
http://thinkgeek.com/sf
___
Mav-user mailing list
[EMAIL PROTECTED]
https://lists.sourceforge.net/lists/listinfo/mav-user
Archives are available at http://www.mail-archive.com/



Re: [Mav-user] Using decorator pattern on controllers

2002-08-09 Thread Roy Truelove

Actually I just found the ControllerWithParams class in the Javadoc which is
defined as a a Decorator pattern, adding params defined for a controller.
Are they any examples of how this is used?

-Roy

- Original Message -
From: jim moore [EMAIL PROTECTED]
To: [EMAIL PROTECTED]
Sent: Friday, August 09, 2002 12:23 PM
Subject: Re: [Mav-user] Using decorator pattern on controllers


 This shouldn't be too difficult. Just have your decorator implement
 ControllerSingleton, then you will get an init method in which the
 controller node from maverick.xml is passed in.

 If you had a controller node that looked like:

 controller class=com.foo.bar.MyControllerDecorator
 decorated class=com.foo.bar.SomeExistingController
 /controller

 Your decorator could hold an internal controller. When the decorator's go
 method was called, it could call go on the decorated controller, read the
 result and the model, and still do its own thing. This is actually similar
 to what I just sent as the CompositeController.

 --jim

 - Original Message -
 From: Roy Truelove [EMAIL PROTECTED]
 To: [EMAIL PROTECTED]
 Sent: Friday, August 09, 2002 12:04 PM
 Subject: [Mav-user] Using decorator pattern on controllers


  Hey all,
 
  I'm looking into the feasablity of using the Decorator pattern* to
  create Controllers.  In the friendbook example, each controller inherits
  from another controller which inherits from another controller, each one
  adding a little functionality.  The problem with this is that you can't
 pick
  and choose which controllers you want to use, you have to use extentions
 of
  extentions.  This would certainly help with the composite view issues
that
  are being discussed, as well as securing controllers, etc.
 
  The problem is .. how can this be done while keeping Maverick backwards
  compatable *and* keeping configuration to a minimum?  Any ideas?  Since
  controllers are instantiated using reflections and not explicitly, is
the
  Decorator pattern even possible?
 
  *Decorator pattern info :
 
http://www.javaworld.com/javaworld/jw-12-2001/jw-1214-designpatterns.html
 
  -Roy
 
 
 
  ---
  This sf.net email is sponsored by:ThinkGeek
  Welcome to geek heaven.
  http://thinkgeek.com/sf
  ___
  Mav-user mailing list
  [EMAIL PROTECTED]
  https://lists.sourceforge.net/lists/listinfo/mav-user
  Archives are available at http://www.mail-archive.com/



 ---
 This sf.net email is sponsored by:ThinkGeek
 Welcome to geek heaven.
 http://thinkgeek.com/sf
 ___
 Mav-user mailing list
 [EMAIL PROTECTED]
 https://lists.sourceforge.net/lists/listinfo/mav-user
 Archives are available at http://www.mail-archive.com/



---
This sf.net email is sponsored by:ThinkGeek
Welcome to geek heaven.
http://thinkgeek.com/sf
___
Mav-user mailing list
[EMAIL PROTECTED]
https://lists.sourceforge.net/lists/listinfo/mav-user
Archives are available at http://www.mail-archive.com/



RE: [Mav-user] Using decorator pattern on controllers

2002-08-09 Thread Schnitzer, Jeff

There have been discussions about modularizing the ControllerFactory in
the past but there was just never a compelling reason to do it.  Maybe
it's time.

I should have DSL in a week or two and can do some experimentation then.
Otherwise, if someone else wants to take a stab at it, feel free.  I
imagine that ControllerFactories would be configured very much like the
other factories. 

As you mentioned, the framework does already allow for some amount of
controller composition.  If the flexibility of controller factories is
meant to address the needs of portal developers, maybe we should focus
on that subject first.

Jeff Schnitzer
[EMAIL PROTECTED]

 -Original Message-
 From: jim moore [mailto:[EMAIL PROTECTED]]
 Sent: Friday, August 09, 2002 9:33 AM
 To: [EMAIL PROTECTED]
 Subject: Re: [Mav-user] Using decorator pattern on controllers
 
 On a related note, I'm wondering if we should make ControllerFactory a
 public class. That way decorators would be free to use it's
 createController() method. There's a lot of good functionality in
there,
 and
 I don't really see a reason to hide it away. What do you think Jeff?
 
 --jim
 
 - Original Message -
 From: jim moore [EMAIL PROTECTED]
 To: [EMAIL PROTECTED]
 Sent: Friday, August 09, 2002 12:23 PM
 Subject: Re: [Mav-user] Using decorator pattern on controllers
 
 
  This shouldn't be too difficult. Just have your decorator implement
  ControllerSingleton, then you will get an init method in which the
  controller node from maverick.xml is passed in.
 
  If you had a controller node that looked like:
 
  controller class=com.foo.bar.MyControllerDecorator
  decorated class=com.foo.bar.SomeExistingController
  /controller
 
  Your decorator could hold an internal controller. When the
decorator's
 go
  method was called, it could call go on the decorated controller,
read
 the
  result and the model, and still do its own thing. This is actually
 similar
  to what I just sent as the CompositeController.
 
  --jim
 
  - Original Message -
  From: Roy Truelove [EMAIL PROTECTED]
  To: [EMAIL PROTECTED]
  Sent: Friday, August 09, 2002 12:04 PM
  Subject: [Mav-user] Using decorator pattern on controllers
 
 
   Hey all,
  
   I'm looking into the feasablity of using the Decorator
pattern* to
   create Controllers.  In the friendbook example, each controller
 inherits
   from another controller which inherits from another controller,
each
 one
   adding a little functionality.  The problem with this is that you
 can't
  pick
   and choose which controllers you want to use, you have to use
 extentions
  of
   extentions.  This would certainly help with the composite view
issues
 that
   are being discussed, as well as securing controllers, etc.
  
   The problem is .. how can this be done while keeping Maverick
 backwards
   compatable *and* keeping configuration to a minimum?  Any ideas?
 Since
   controllers are instantiated using reflections and not explicitly,
is
 the
   Decorator pattern even possible?
  
   *Decorator pattern info :
  

http://www.javaworld.com/javaworld/jw-12-2001/jw-1214-designpatterns.htm
l
  
   -Roy
  
  
  
   ---
   This sf.net email is sponsored by:ThinkGeek
   Welcome to geek heaven.
   http://thinkgeek.com/sf
   ___
   Mav-user mailing list
   [EMAIL PROTECTED]
   https://lists.sourceforge.net/lists/listinfo/mav-user
   Archives are available at http://www.mail-archive.com/
 
 
 
  ---
  This sf.net email is sponsored by:ThinkGeek
  Welcome to geek heaven.
  http://thinkgeek.com/sf
  ___
  Mav-user mailing list
  [EMAIL PROTECTED]
  https://lists.sourceforge.net/lists/listinfo/mav-user
  Archives are available at http://www.mail-archive.com/
 
 
 
 
 ---
 This sf.net email is sponsored by:ThinkGeek
 Welcome to geek heaven.
 http://thinkgeek.com/sf
 ___
 Mav-user mailing list
 [EMAIL PROTECTED]
 https://lists.sourceforge.net/lists/listinfo/mav-user
 Archives are available at http://www.mail-archive.com/


---
This sf.net email is sponsored by:ThinkGeek
Welcome to geek heaven.
http://thinkgeek.com/sf
___
Mav-user mailing list
[EMAIL PROTECTED]
https://lists.sourceforge.net/lists/listinfo/mav-user
Archives are available at http://www.mail-archive.com/



RE: [Mav-user] Using decorator pattern on controllers

2002-08-09 Thread Schnitzer, Jeff

It's used internally right now, but the mechanism could be surfaced by
configurable controller factories.

On the other hand, since singleton controllers are passed the XML of
their configuration, you can always compose layers of decoration
yourself.

Jeff Schnitzer
[EMAIL PROTECTED]

 -Original Message-
 From: Roy Truelove [mailto:[EMAIL PROTECTED]]
 Sent: Friday, August 09, 2002 11:46 AM
 To: [EMAIL PROTECTED]
 Subject: Re: [Mav-user] Using decorator pattern on controllers
 
 Actually I just found the ControllerWithParams class in the Javadoc
which
 is
 defined as a a Decorator pattern, adding params defined for a
 controller.
 Are they any examples of how this is used?
 
 -Roy
 
 - Original Message -
 From: jim moore [EMAIL PROTECTED]
 To: [EMAIL PROTECTED]
 Sent: Friday, August 09, 2002 12:23 PM
 Subject: Re: [Mav-user] Using decorator pattern on controllers
 
 
  This shouldn't be too difficult. Just have your decorator implement
  ControllerSingleton, then you will get an init method in which the
  controller node from maverick.xml is passed in.
 
  If you had a controller node that looked like:
 
  controller class=com.foo.bar.MyControllerDecorator
  decorated class=com.foo.bar.SomeExistingController
  /controller
 
  Your decorator could hold an internal controller. When the
decorator's
 go
  method was called, it could call go on the decorated controller,
read
 the
  result and the model, and still do its own thing. This is actually
 similar
  to what I just sent as the CompositeController.
 
  --jim
 
  - Original Message -
  From: Roy Truelove [EMAIL PROTECTED]
  To: [EMAIL PROTECTED]
  Sent: Friday, August 09, 2002 12:04 PM
  Subject: [Mav-user] Using decorator pattern on controllers
 
 
   Hey all,
  
   I'm looking into the feasablity of using the Decorator
pattern* to
   create Controllers.  In the friendbook example, each controller
 inherits
   from another controller which inherits from another controller,
each
 one
   adding a little functionality.  The problem with this is that you
 can't
  pick
   and choose which controllers you want to use, you have to use
 extentions
  of
   extentions.  This would certainly help with the composite view
issues
 that
   are being discussed, as well as securing controllers, etc.
  
   The problem is .. how can this be done while keeping Maverick
 backwards
   compatable *and* keeping configuration to a minimum?  Any ideas?
 Since
   controllers are instantiated using reflections and not explicitly,
is
 the
   Decorator pattern even possible?
  
   *Decorator pattern info :
  

http://www.javaworld.com/javaworld/jw-12-2001/jw-1214-designpatterns.htm
l
  
   -Roy
  
  
  
   ---
   This sf.net email is sponsored by:ThinkGeek
   Welcome to geek heaven.
   http://thinkgeek.com/sf
   ___
   Mav-user mailing list
   [EMAIL PROTECTED]
   https://lists.sourceforge.net/lists/listinfo/mav-user
   Archives are available at http://www.mail-archive.com/
 
 
 
  ---
  This sf.net email is sponsored by:ThinkGeek
  Welcome to geek heaven.
  http://thinkgeek.com/sf
  ___
  Mav-user mailing list
  [EMAIL PROTECTED]
  https://lists.sourceforge.net/lists/listinfo/mav-user
  Archives are available at http://www.mail-archive.com/
 
 
 
 ---
 This sf.net email is sponsored by:ThinkGeek
 Welcome to geek heaven.
 http://thinkgeek.com/sf
 ___
 Mav-user mailing list
 [EMAIL PROTECTED]
 https://lists.sourceforge.net/lists/listinfo/mav-user
 Archives are available at http://www.mail-archive.com/


---
This sf.net email is sponsored by:ThinkGeek
Welcome to geek heaven.
http://thinkgeek.com/sf
___
Mav-user mailing list
[EMAIL PROTECTED]
https://lists.sourceforge.net/lists/listinfo/mav-user
Archives are available at http://www.mail-archive.com/