<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>I don't think that is does break the contract, especially in the case of an abstract class. The javadoc just says :</div><div><br></div><div><span class="Apple-style-span" style="font-family: Times; ">Returns the target instance.</span></div><div><br></div><div>And the instance of the generated proxy is the target instance. Proxy is not really a good word for this, as this is not really a proxy in the design patterns sense, but a proxy in the 'uses JDK proxies' sense. &nbsp;I wish they had called JDK proxies something else.</div><div><br></div><div>Stuart</div><br><div><div>On 14/07/2010, at 10:53 PM, Pete Muir wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div><br>On 13 Jul 2010, at 21:18, Stuart Douglas wrote:<br><br><blockquote type="cite"><br></blockquote><blockquote type="cite">On 14/07/2010, at 3:56 AM, Pete Muir wrote:<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote><blockquote type="cite"><blockquote type="cite">On 13 Jul 2010, at 00:45, Walter White wrote:<br></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">Stuart,<br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">Your idea sounds good as well.<br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">I think my original motivation was when I first started with Spring in 2008, we proxied an abstract DAO if we didn't need custom functionality. &nbsp;If we needed custom functionality, then we extended the abstract DAO making it concrete. &nbsp;There was a configuration in spring that let you do that, but at that point in time, it was useful to avoid writing the same code again and again.<br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">I need to play around with that more to have a better answer.<br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">Walter<br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">On 07/12/2010 06:05 PM, Stuart Douglas wrote:<br></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">On 13/07/2010, at 2:20 AM, Pete Muir wrote:<br></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">We definitely want something like this in WeldX.<br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">However I would argue we should follow the design of interceptors much more closely.<br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">1) The aroundInvoke method should take an InvocationContext, returning null for getTarget (what is the reason for passing the proxy into the method in the design below)?<br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">2) Drop the interface implementation requirement, and use the @AroundInvoke annotation<br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">3) Add an annotation used to find the handlers e.g. @ServiceHandler<br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">4) Add a meta-annotation @ServiceBinding(QueryInvocationHandler.class) @interface QueryService {}<br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">WDYT?<br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">Looks good, I was planning on doing the meta-annotation stuff at some point, and using AroundInvoke rather than implementing InvocationHandler is certainly an improvement.<br></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><blockquote type="cite"><blockquote type="cite">I don't see why getTarget should return null though. Even though having access to the object may not be not particularly useful, I think that most people would find this behaviour surprising. Also they may want to call getClass() or use instanceof on the object to determine the exact type they are dealing with.<br></blockquote></blockquote></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><br></blockquote></blockquote><blockquote type="cite"><blockquote type="cite">What would getTarget return then? By definition there is no proxied object.<br></blockquote></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite">I would have it return the Proxy instance.<br></blockquote><br>In this case, we would need to redefine the InvocationContext interface, as getTarget then has the wrong contract.<br><br>Hmm, I can't see a good path through this. I am loath to add more interfaces that do different things.<br><br>Any ideas?</div></blockquote></div><br></body></html>