<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta content="text/html;charset=ISO-8859-1" http-equiv="Content-Type">
</head>
<body bgcolor="#ffffff" text="#000000">
Gavin King wrote:
<blockquote
cite="mid:db199550910191221q79ed4599l96c7b2bf69f40d4d@mail.gmail.com"
type="cite">
<pre wrap="">On Mon, Oct 19, 2009 at 1:58 PM, Roberto Chinnici
<a class="moz-txt-link-rfc2396E" href="mailto:Roberto.Chinnici@sun.com"><Roberto.Chinnici@sun.com></a> wrote:
</pre>
<blockquote type="cite">
<pre wrap="">OK, but the issue is that the class was not already a bean, because it was
placed (deliberately, I assume) in an archive that is not a bean deployment
archive.
</pre>
</blockquote>
<pre wrap=""><!---->
It is certainly NOT true that beans placed in archives that are not
"bean deployment archives" are not beans. A class annotated
@ManagedBean or @Stateless is a bean whether or not its archive has a
beans.xml file.
</pre>
</blockquote>
<br>
Of course. But neither applied to the case being discussed.<br>
<br>
<blockquote
cite="mid:db199550910191221q79ed4599l96c7b2bf69f40d4d@mail.gmail.com"
type="cite">
<blockquote type="cite">
<pre wrap="">While I understand that the SPI is powerful enough to create a bean out of a
plain class -- after all, that's what it was created for -- I'd rather not
have an existing annotation with other legitimate applications, like @New,
be re-purposed to do that job.
</pre>
</blockquote>
<pre wrap=""><!---->
@New has not been re-purposed even one little bit. This is precisely
what @New is supposed to be used for: getting a "new", "clean"
instance of a class inside a producer method, so that the producer
method can define its scope and qualifiers.
</pre>
</blockquote>
<br>
I'm not arguing with the formulation "getting a new instance of a
class". It's when you<br>
say "bean" instead of "class" that I start seeing some
issues/inconsistencies.<br>
<br>
<blockquote
cite="mid:db199550910191221q79ed4599l96c7b2bf69f40d4d@mail.gmail.com"
type="cite">
<pre wrap="">Really, what happened was that we discovered an unacceptable
limitation affecting @New (well, really the limitation was not
explicit, it was something the spec was unclear on). In fact, earlier
versions of JSR-299 which defined @New differently did *not* have this
limitation. It slipped through into the RI because of the lack of
clarity in the spec.
</pre>
<blockquote type="cite">
<pre wrap="">But they are not already beans.
</pre>
</blockquote>
<pre wrap=""><!---->
Yes they are.
@Stateless class Foo {}
is a bean. Even if there is no beans.xml file.
@ManagedBean class Foo {}
is a bean. Even if there is no beans.xml file.</pre>
</blockquote>
<br>
I'm not arguing with that at all.<br>
<br>
<blockquote
cite="mid:db199550910191221q79ed4599l96c7b2bf69f40d4d@mail.gmail.com"
type="cite">
<pre wrap=""> Even
class Foo { @Inject Bar bar; }
will be treated by JSR-330 as a bean even if there is no beans.xml file.
</pre>
</blockquote>
<br>
JSR-330 doesn't treat anything as a bean, because it only defines DI
annotations.<br>
The platform spec (EE.5.19) says that "support for JSR-330 annotations<br>
is conditional to their being used by a class which is part of a bean
deployment<br>
archive". So there is a conflict.<br>
<br>
<blockquote
cite="mid:db199550910191221q79ed4599l96c7b2bf69f40d4d@mail.gmail.com"
type="cite">
<blockquote type="cite">
<pre wrap="">They are classes which might reasonably have
been beans *if* the developer had wanted them to be.
</pre>
</blockquote>
<pre wrap=""><!---->
They are classes that *are* beans, but that just happen to be deployed
in an archive that is not being scanned by the 299 implementation.
</pre>
</blockquote>
<br>
Well, I can tell you there is an issue. If they were managed beans, for
consistency<br>
you should be able to use @Resource and friends with them, but I don't
think the<br>
specs (plural) today imply that.<br>
<br>
<blockquote
cite="mid:db199550910191221q79ed4599l96c7b2bf69f40d4d@mail.gmail.com"
type="cite">
<blockquote type="cite">
<pre wrap="">And even if they were
managed beans thanks to the @ManagedBean annotation, since they lie outside
a bean deployment archive, they should not be directly accessible using 299
means. So you could create an instance using JNDI (if the bean had a name),
but not with the 299 API or SPI.
</pre>
</blockquote>
<pre wrap=""><!---->
That's not a limitation that JSR-330 imposes, and it therefore would
affect the 330 -> 299 migration scenario, as pointed out by Jim.
</pre>
</blockquote>
<br>
JSR-330 doesn't talk about packaging at all.<br>
<br>
<blockquote
cite="mid:db199550910191221q79ed4599l96c7b2bf69f40d4d@mail.gmail.com"
type="cite">
<pre wrap="">Again, this limitation was not there by design. Recent versions of the
spec were unclear about this issue. Earlier versions of the spec
actually were clear, and did not have the limitation.
</pre>
<blockquote type="cite">
<pre wrap="">I'm trying to recall what the code using NonContextual looked like -- wasn't
NonContextual similar to Provider?
</pre>
</blockquote>
<pre wrap=""><!---->
No. It was a workaround that called the metamodel API. Jim and I and
others all agree that 299 should not need to use the metamodel API in
order to pass the 330 TCK.
</pre>
</blockquote>
<br>
Can you show me the code that org.jboss.weld.atinject.tck.Producers
used in its previous version,<br>
with @BeanTypes but without @New? For some reason I can't get at it
with viewvc.jboss.org.<br>
<br>
</body>
</html>