<div dir="ltr"><div><div><div><div><div><div><div>The confusion between the existing BeanManager.fireEvent() <br></div>(JIRA comments sometimes just call it &quot;fire&quot;) and this newly proposed method should be avoided.<br></div>Backward-compatibility means the existing ones should still work as they do of course.<br><br></div>What&#39;s the rationale behind just wanting to call it &quot;event&quot;. It would return an Event object. All but the void methods (including fireEvent) follow certain conventions like<br></div>- get*<br></div>- create*<br></div>- is*<br></div>- are*<br><div><div><div><div><div><div><div><div><div><div><div class="gmail_extra">depending on what they return.<br><br></div><div class="gmail_extra">Why would a non-void non-static method of an existing interface that returns something suddenly break with these conventions? If the existing fireEvent method did not exist, it may be less problematic, though other than the static accessor method current() in the CDI class, I am not aware of interfaces doing that so far.<br><br></div><div class="gmail_extra">However having fireEvent in the same interface, just calling a &quot;getter&quot; method event() makes that even more ambiguous and easy to misinterpret.<br></div><div class="gmail_extra"><br clear="all"></div><div class="gmail_extra"><div><div class="gmail_signature" data-smartmail="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><p style="margin:0px;border-collapse:collapse"><font size="1" face="arial, helvetica, sans-serif"><span lang="EN-US">Werner </span></font><br></p><span lang="EN-GB"><div style="font-family:arial,helvetica,sans-serif"><br></div></span></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div>
<br><div class="gmail_quote">On Fri, Oct 7, 2016 at 1:59 PM,  <span dir="ltr">&lt;<a href="mailto:cdi-dev-request@lists.jboss.org" target="_blank">cdi-dev-request@lists.jboss.org</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Send cdi-dev mailing list submissions to<br>
        <a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
<br>
To subscribe or unsubscribe via the World Wide Web, visit<br>
        <a href="https://lists.jboss.org/mailman/listinfo/cdi-dev" rel="noreferrer" target="_blank">https://lists.jboss.org/<wbr>mailman/listinfo/cdi-dev</a><br>
or, via email, send a message with subject or body &#39;help&#39; to<br>
        <a href="mailto:cdi-dev-request@lists.jboss.org">cdi-dev-request@lists.jboss.<wbr>org</a><br>
<br>
You can reach the person managing the list at<br>
        <a href="mailto:cdi-dev-owner@lists.jboss.org">cdi-dev-owner@lists.jboss.org</a><br>
<br>
When replying, please edit your Subject line so it is more specific<br>
than &quot;Re: Contents of cdi-dev digest...&quot;<br>
<br>
<br>
Today&#39;s Topics:<br>
<br>
   1. [JBoss JIRA] (CDI-224) Support Decoration of no interface<br>
      beans (Antoine Sabot-Durand (JIRA))<br>
   2. [JBoss JIRA] (CDI-526) Include filters<br>
      (Antoine Sabot-Durand (JIRA))<br>
   3. [JBoss JIRA] (CDI-613) Container should be able to receive<br>
      information about the context in which it was bootstraped<br>
      (Antoine Sabot-Durand (JIRA))<br>
   4. [JBoss JIRA] (CDI-633) Intoroduce BeanManager.event()<br>
      (Antoine Sabot-Durand (JIRA))<br>
   5. [JBoss JIRA] (CDI-613) Container should be able to receive<br>
      information about the context in which it was bootstraped<br>
      (Antoine Sabot-Durand (JIRA))<br>
   6. [JBoss JIRA] (CDI-612)<br>
      ObserverMethodConfigurator.<wbr>notifyWith() should probably accept a<br>
      functional interface whose method throws java.lang.Exception<br>
      (Antoine Sabot-Durand (JIRA))<br>
   7. [JBoss JIRA] (CDI-601) Add container lifecycle event fired<br>
      before container destroys all contexts (Antoine Sabot-Durand (JIRA))<br>
   8. [JBoss JIRA] (CDI-593) Mention<br>
      javax.enterprise.inject.spi.<wbr>Prioritized in spec text and improve<br>
      its javadoc (Antoine Sabot-Durand (JIRA))<br>
   9. [JBoss JIRA] (CDI-592) Consider adding<br>
      ObserverMethod.notify() method which also accepts EventMetadata<br>
      (Antoine Sabot-Durand (JIRA))<br>
  10. [JBoss JIRA] (CDI-561) Add the possibility to unmanage a bean<br>
      instance (Antoine Sabot-Durand (JIRA))<br>
<br>
<br>
------------------------------<wbr>------------------------------<wbr>----------<br>
<br>
Message: 4<br>
Date: Fri, 7 Oct 2016 07:33:00 -0400 (EDT)<br>
From: &quot;Antoine Sabot-Durand (JIRA)&quot; &lt;<a href="mailto:issues@jboss.org">issues@jboss.org</a>&gt;<br>
Subject: [cdi-dev] [JBoss JIRA] (CDI-633) Intoroduce<br>
        BeanManager.event()<br>
To: <a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
Message-ID:<br>
        &lt;JIRA.12650965.1474369800000.<wbr>72245.1475839980420@Atlassian.<wbr>JIRA&gt;<br>
Content-Type: text/plain; charset=UTF-8<br>
<br>
<br>
     [ <a href="https://issues.jboss.org/browse/CDI-633?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-633?page=com.<wbr>atlassian.jira.plugin.system.<wbr>issuetabpanels:all-tabpanel</a> ]<br>
<br>
Antoine Sabot-Durand updated CDI-633:<br>
------------------------------<wbr>-------<br>
    Fix Version/s: 2.0 .Final<br>
                       (was: 2.0 (discussion))<br>
<br>
<br>
&gt; Intoroduce BeanManager.event()<br>
&gt; ------------------------------<br>
&gt;<br>
&gt;                 Key: CDI-633<br>
&gt;                 URL: <a href="https://issues.jboss.org/browse/CDI-633" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-633</a><br>
&gt;             Project: CDI Specification Issues<br>
&gt;          Issue Type: Feature Request<br>
&gt;            Reporter: Martin Kouba<br>
&gt;             Fix For: 2.0 .Final<br>
&gt;<br>
&gt;<br>
&gt; * this would allow to define the _specified type_ - the container may use the specified type to infer the parameterized type of the event types<br>
&gt; * the method should return {{javax.enterprise.event.<wbr>Event&lt;Object&gt;}} with no qualifiers<br>
<br>
<br>
<br>
--<br>
This message was sent by Atlassian JIRA<br>
(v6.4.11#64026)<br>
<br>
<br>
------------------------------<br>
<br>
Message: 5<br>
Date: Fri, 7 Oct 2016 07:47:00 -0400 (EDT)<br>
From: &quot;Antoine Sabot-Durand (JIRA)&quot; &lt;<a href="mailto:issues@jboss.org">issues@jboss.org</a>&gt;<br>
Subject: [cdi-dev] [JBoss JIRA] (CDI-613) Container should be able to<br>
        receive information about the context in which it was bootstraped<br>
To: <a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
Message-ID:<br>
        &lt;JIRA.12629498.1464972649000.<wbr>72322.1475840820239@Atlassian.<wbr>JIRA&gt;<br>
Content-Type: text/plain; charset=UTF-8<br>
<br>
<br>
     [ <a href="https://issues.jboss.org/browse/CDI-613?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-613?page=com.<wbr>atlassian.jira.plugin.system.<wbr>issuetabpanels:all-tabpanel</a> ]<br>
<br>
Antoine Sabot-Durand updated CDI-613:<br>
------------------------------<wbr>-------<br>
    Fix Version/s: TBD<br>
                       (was: 2.0 (discussion))<br>
<br>
<br>
&gt; Container should be able to receive information about the context in which it was bootstraped<br>
&gt; ------------------------------<wbr>------------------------------<wbr>------------------------------<wbr>---<br>
&gt;<br>
&gt;                 Key: CDI-613<br>
&gt;                 URL: <a href="https://issues.jboss.org/browse/CDI-613" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-613</a><br>
&gt;             Project: CDI Specification Issues<br>
&gt;          Issue Type: Feature Request<br>
&gt;          Components: Java EE integration<br>
&gt;            Reporter: Antoine Sabot-Durand<br>
&gt;             Fix For: TBD<br>
&gt;<br>
&gt;<br>
&gt; Today it&#39;s impossible to know what is the outside context of the CDI container (i.e what is the application or EE module it belongs to).<br>
&gt; This is problematic for other spec like JPA who needs to retrieve their information (persistence units) from a portable extension.<br>
&gt; This would help solving issues like WFLY-2387 in a portable way.<br>
<br>
<br>
<br>
--<br>
This message was sent by Atlassian JIRA<br>
(v6.4.11#64026)<br>
<br>
<br>
------------------------------<br>
<br>
Message: 6<br>
Date: Fri, 7 Oct 2016 07:47:00 -0400 (EDT)<br>
From: &quot;Antoine Sabot-Durand (JIRA)&quot; &lt;<a href="mailto:issues@jboss.org">issues@jboss.org</a>&gt;<br>
Subject: [cdi-dev] [JBoss JIRA] (CDI-612)<br>
        ObserverMethodConfigurator.<wbr>notifyWith() should probably accept a<br>
        functional interface whose method throws java.lang.Exception<br>
To: <a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
Message-ID:<br>
        &lt;JIRA.12629421.1464951703000.<wbr>72324.1475840820290@Atlassian.<wbr>JIRA&gt;<br>
Content-Type: text/plain; charset=UTF-8<br>
<br>
<br>
     [ <a href="https://issues.jboss.org/browse/CDI-612?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-612?page=com.<wbr>atlassian.jira.plugin.system.<wbr>issuetabpanels:all-tabpanel</a> ]<br>
<br>
Antoine Sabot-Durand updated CDI-612:<br>
------------------------------<wbr>-------<br>
    Fix Version/s: 2.0 .Final<br>
                       (was: 2.0 (discussion))<br>
<br>
<br>
&gt; ObserverMethodConfigurator.<wbr>notifyWith() should probably accept a functional interface whose method throws java.lang.Exception<br>
&gt; ------------------------------<wbr>------------------------------<wbr>------------------------------<wbr>------------------------------<wbr>-----<br>
&gt;<br>
&gt;                 Key: CDI-612<br>
&gt;                 URL: <a href="https://issues.jboss.org/browse/CDI-612" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-612</a><br>
&gt;             Project: CDI Specification Issues<br>
&gt;          Issue Type: Clarification<br>
&gt;    Affects Versions: 2.0-EDR1<br>
&gt;            Reporter: Martin Kouba<br>
&gt;             Fix For: 2.0 .Final<br>
&gt;<br>
&gt;<br>
&gt; The regular observer methods may also throw checked exceptions (wrapped and rethrown as an (unchecked) {{ObserverException}}).<br>
<br>
<br>
<br>
--<br>
This message was sent by Atlassian JIRA<br>
(v6.4.11#64026)<br>
<br>
<br>
------------------------------<br>
<br>
Message: 7<br>
Date: Fri, 7 Oct 2016 07:52:01 -0400 (EDT)<br>
From: &quot;Antoine Sabot-Durand (JIRA)&quot; &lt;<a href="mailto:issues@jboss.org">issues@jboss.org</a>&gt;<br>
Subject: [cdi-dev] [JBoss JIRA] (CDI-601) Add container lifecycle<br>
        event fired before container destroys all contexts<br>
To: <a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
Message-ID:<br>
        &lt;JIRA.12626142.1463386462000.<wbr>72386.1475841121230@Atlassian.<wbr>JIRA&gt;<br>
Content-Type: text/plain; charset=UTF-8<br>
<br>
<br>
     [ <a href="https://issues.jboss.org/browse/CDI-601?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-601?page=com.<wbr>atlassian.jira.plugin.system.<wbr>issuetabpanels:all-tabpanel</a> ]<br>
<br>
Antoine Sabot-Durand resolved CDI-601.<br>
------------------------------<wbr>--------<br>
    Resolution: Duplicate Issue<br>
<br>
<br>
Duplicates CDI-625<br>
<br>
&gt; Add container lifecycle event fired before container destroys all contexts<br>
&gt; ------------------------------<wbr>------------------------------<wbr>--------------<br>
&gt;<br>
&gt;                 Key: CDI-601<br>
&gt;                 URL: <a href="https://issues.jboss.org/browse/CDI-601" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-601</a><br>
&gt;             Project: CDI Specification Issues<br>
&gt;          Issue Type: Feature Request<br>
&gt;            Reporter: Martin Kouba<br>
&gt;             Fix For: 2.0 (discussion)<br>
&gt;<br>
&gt;<br>
&gt; The name might be something like {{BeforeContainerShutdown}}. Note that we probably cannot change the name or semantics of {{BeforeShutdown}}, which is fired after container destroys all contexts. The motivation is to allow the beans to perform some kind of cleanup before dependencies could be disposed (the ordering of destruction is not defined).<br>
<br>
<br>
<br>
--<br>
This message was sent by Atlassian JIRA<br>
(v6.4.11#64026)<br>
<br>
<br>
------------------------------<br>
<br>
Message: 8<br>
Date: Fri, 7 Oct 2016 07:54:01 -0400 (EDT)<br>
From: &quot;Antoine Sabot-Durand (JIRA)&quot; &lt;<a href="mailto:issues@jboss.org">issues@jboss.org</a>&gt;<br>
Subject: [cdi-dev] [JBoss JIRA] (CDI-593) Mention<br>
        javax.enterprise.inject.spi.<wbr>Prioritized in spec text and improve its<br>
        javadoc<br>
To: <a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
Message-ID:<br>
        &lt;JIRA.12611926.1458825009000.<wbr>72430.1475841241255@Atlassian.<wbr>JIRA&gt;<br>
Content-Type: text/plain; charset=UTF-8<br>
<br>
<br>
     [ <a href="https://issues.jboss.org/browse/CDI-593?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-593?page=com.<wbr>atlassian.jira.plugin.system.<wbr>issuetabpanels:all-tabpanel</a> ]<br>
<br>
Antoine Sabot-Durand updated CDI-593:<br>
------------------------------<wbr>-------<br>
    Fix Version/s: 2.0 .Final<br>
                       (was: 2.0 (discussion))<br>
<br>
<br>
&gt; Mention javax.enterprise.inject.spi.<wbr>Prioritized in spec text and improve its javadoc<br>
&gt; ------------------------------<wbr>------------------------------<wbr>------------------------<br>
&gt;<br>
&gt;                 Key: CDI-593<br>
&gt;                 URL: <a href="https://issues.jboss.org/browse/CDI-593" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-593</a><br>
&gt;             Project: CDI Specification Issues<br>
&gt;          Issue Type: Clarification<br>
&gt;            Reporter: Martin Kouba<br>
&gt;             Fix For: 2.0 .Final<br>
&gt;<br>
&gt;<br>
&gt; * javadoc would definitely deserve some more info<br>
&gt; * the spec text should mention this interface as well and describe basic use cases (e.g. an interceptor passed to {{AfterBeanDiscovery.addBean()<wbr>}} and  implementing this interface is globally enabled)<br>
<br>
<br>
<br>
--<br>
This message was sent by Atlassian JIRA<br>
(v6.4.11#64026)<br>
<br>
<br>
------------------------------<br>
<br>
Message: 9<br>
Date: Fri, 7 Oct 2016 07:55:00 -0400 (EDT)<br>
From: &quot;Antoine Sabot-Durand (JIRA)&quot; &lt;<a href="mailto:issues@jboss.org">issues@jboss.org</a>&gt;<br>
Subject: [cdi-dev] [JBoss JIRA] (CDI-592) Consider adding<br>
        ObserverMethod.notify() method which also accepts EventMetadata<br>
To: <a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
Message-ID:<br>
        &lt;JIRA.12611754.1458745510000.<wbr>72436.1475841300410@Atlassian.<wbr>JIRA&gt;<br>
Content-Type: text/plain; charset=UTF-8<br>
<br>
<br>
     [ <a href="https://issues.jboss.org/browse/CDI-592?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-592?page=com.<wbr>atlassian.jira.plugin.system.<wbr>issuetabpanels:all-tabpanel</a> ]<br>
<br>
Antoine Sabot-Durand updated CDI-592:<br>
------------------------------<wbr>-------<br>
    Fix Version/s: 2.0 .Final<br>
                       (was: 2.0 (discussion))<br>
<br>
<br>
&gt; Consider adding ObserverMethod.notify() method which also accepts EventMetadata<br>
&gt; ------------------------------<wbr>------------------------------<wbr>-------------------<br>
&gt;<br>
&gt;                 Key: CDI-592<br>
&gt;                 URL: <a href="https://issues.jboss.org/browse/CDI-592" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-592</a><br>
&gt;             Project: CDI Specification Issues<br>
&gt;          Issue Type: Feature Request<br>
&gt;          Components: Events<br>
&gt;            Reporter: Martin Kouba<br>
&gt;             Fix For: 2.0 .Final<br>
&gt;<br>
&gt;<br>
&gt; {code:java}<br>
&gt; // Make the original method also default so that new impls don&#39;t need to implement two methods<br>
&gt; default void notify(T event) {<br>
&gt;   // No-op<br>
&gt; }<br>
&gt; // The container should always call this method...<br>
&gt; default void notify(T event, EventMetadata metadata) {<br>
&gt;   notify(event);<br>
&gt; }<br>
&gt; {code}<br>
&gt; This should not break existing implementations. The truth is a custom impl will not be forced to implement any {{notify()}} method. But I think the benefits are worth it.<br>
<br>
<br>
<br>
--<br>
This message was sent by Atlassian JIRA<br>
(v6.4.11#64026)<br>
<br>
<br>
------------------------------<br>
<br>
Message: 10<br>
Date: Fri, 7 Oct 2016 07:59:00 -0400 (EDT)<br>
From: &quot;Antoine Sabot-Durand (JIRA)&quot; &lt;<a href="mailto:issues@jboss.org">issues@jboss.org</a>&gt;<br>
Subject: [cdi-dev] [JBoss JIRA] (CDI-561) Add the possibility to<br>
        unmanage a bean instance<br>
To: <a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
Message-ID:<br>
        &lt;JIRA.12584980.1442331236000.<wbr>72464.1475841540189@Atlassian.<wbr>JIRA&gt;<br>
Content-Type: text/plain; charset=UTF-8<br>
<br>
<br>
     [ <a href="https://issues.jboss.org/browse/CDI-561?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-561?page=com.<wbr>atlassian.jira.plugin.system.<wbr>issuetabpanels:all-tabpanel</a> ]<br>
<br>
Antoine Sabot-Durand updated CDI-561:<br>
------------------------------<wbr>-------<br>
    Fix Version/s: TBD<br>
                       (was: 2.0 (discussion))<br>
<br>
<br>
&gt; Add the possibility to unmanage a bean instance<br>
&gt; ------------------------------<wbr>-----------------<br>
&gt;<br>
&gt;                 Key: CDI-561<br>
&gt;                 URL: <a href="https://issues.jboss.org/browse/CDI-561" rel="noreferrer" target="_blank">https://issues.jboss.org/<wbr>browse/CDI-561</a><br>
&gt;             Project: CDI Specification Issues<br>
&gt;          Issue Type: Feature Request<br>
&gt;          Components: Beans<br>
&gt;    Affects Versions: 1.2.Final, 1.1.Final, 2.0-EDR1<br>
&gt;            Reporter: Antoine Sabot-Durand<br>
&gt;             Fix For: TBD<br>
&gt;<br>
&gt;<br>
&gt; CDI implementations make heavy uses of proxies to support normal scope and interceptor decorators. There are use case where being able to have a bean instance without its proxy could be useful<br>
&gt; * Accessing the true class of the instance in a clean way<br>
&gt; * Being able to capture an instance state to use its information outside CDI or as an event payload<br>
&gt; The limitation we have  on Async event is probably a good example. As we don&#39;t propagate active normal context at firing time, it&#39;s not possible to inject a bean with such a scope (except {{@ApplicationScoped}} since Application context is shared), it could be useful to give the possibility to copy such a bean instance to a standard pojo instance so it could be used as event payload for instance.<br>
&gt; We could even imagine that the mechanism could be transparently activated if an asynchronous observer inject a {{@RequestScoped}} or {{@SessionScoped}} bean.<br>
<br>
<br>
<br>
--<br>
This message was sent by Atlassian JIRA<br>
(v6.4.11#64026)<br>
<br>
<br>
------------------------------<br>
<br>
______________________________<wbr>_________________<br>
cdi-dev mailing list<br>
<a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/cdi-dev" rel="noreferrer" target="_blank">https://lists.jboss.org/<wbr>mailman/listinfo/cdi-dev</a><br>
<br>
Note that for all code provided on this list, the provider licenses the code under the Apache License, Version 2 (<a href="http://www.apache.org/licenses/LICENSE-2.0.html" rel="noreferrer" target="_blank">http://www.apache.org/<wbr>licenses/LICENSE-2.0.html</a>).  For all other ideas provided on this list, the provider waives all patent and other intellectual property rights inherent in such information.<br>
<br>
End of cdi-dev Digest, Vol 71, Issue 8<br>
******************************<wbr>********<br>
</blockquote></div><br></div></div></div></div></div></div></div></div></div></div></div></div>