<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<body link="#355491" alink="#4262a1" vlink="#355491" style="background: #e2e2e2; margin: 0; padding: 20px;">

<div>
        <table cellpadding="0" bgcolor="#FFFFFF" border="0" cellspacing="0" style="border: 1px solid #dadada; margin-bottom: 30px; width: 100%; -moz-border-radius: 6px; -webkit-border-radius: 6px;">
                <tbody>
                        <tr>

                                <td>

                                        <table border="0" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF" style="border: solid 2px #ccc; background: #dadada; width: 100%; -moz-border-radius: 6px; -webkit-border-radius: 6px;">
                                                <tbody>
                                                        <tr>
                                                                <td bgcolor="#000000" valign="middle" height="58px" style="border-bottom: 1px solid #ccc; padding: 20px; -moz-border-radius-topleft: 3px; -moz-border-radius-topright: 3px; -webkit-border-top-right-radius: 5px; -webkit-border-top-left-radius: 5px;">
                                                                        <h1 style="color: #333333; font: bold 22px Arial, Helvetica, sans-serif; margin: 0; display: block !important;">
                                                                        <!-- To have a header image/logo replace the name below with your img tag -->
                                                                        <!-- Email clients will render the images when the message is read so any image -->
                                                                        <!-- must be made available on a public server, so that all recipients can load the image. -->
                                                                        <a href="http://community.jboss.org/index.jspa" style="text-decoration: none; color: #E1E1E1">JBoss Community</a></h1>
                                                                </td>

                                                        </tr>
                                                        <tr>
                                                                <td bgcolor="#FFFFFF" style="font: normal 12px Arial, Helvetica, sans-serif; color:#333333; padding: 20px;  -moz-border-radius-bottomleft: 4px; -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 5px; -webkit-border-bottom-left-radius: 5px;"><h3 style="margin: 10px 0 5px; font-size: 17px; font-weight: normal;">
    Re: META-INF/services for module extensions - question/issue
</h3>
<span style="margin-bottom: 10px;">
    created by <a href="http://community.jboss.org/people/lmcdasi">Dan Sirbu</a> in <i>JBoss AS7 Development</i> - <a href="http://community.jboss.org/message/625780#625780">View the full discussion</a>
</span>
<hr style="margin: 20px 0; border: none; background-color: #dadada; height: 1px;">

<div class="jive-rendered-content"><p>Sorry Brian, but it does not look to me that is working. I did not go too far: ME--&gt;M1 does not work so ....</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>ME: module.xml has dependencies:</p><p>&#160;&#160;&#160;&#160;&#160; &lt;module name="com.module.first"/&gt;&#160;&#160;&#160;&#160;&#160;&#160;&#160; M1<br/>&#160;&#160;&#160;&#160;&#160; &lt;module name="com.module.second"/&gt;&#160;&#160; M2<br/>&#160;&#160;&#160;&#160;&#160; &lt;module name="com.module.third"/&gt;&#160;&#160;&#160;&#160;&#160;&#160; M3</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>Then in the TCCL class:</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p><span style=": ; color: #7f0055; font-size: 2;"><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p></span><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p></p><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p><span style=": ; color: #7f0055; font-size: 2;"><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p></span><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p></p><p><strong style="color: #7f0055; font-size: 10pt;"><strong style="color: #7f0055; font-size: 10pt;"><p align="left">import<span style="color: #000000; font-size: 10pt;"> com.module.first.services.TestServicesIfc;</span></p></strong></strong></p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p><strong style="color: #7f0055; font-size: 10pt;"><strong style="color: #7f0055; font-size: 10pt;"><p>import<span style="color: #000000; font-size: 10pt;"> com.module.first.services.TestServicesImpl;</span></p></strong></strong></p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>.....</p><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p><span style="font-size: 10pt;"><p align="left">module = Module.<em>getCallerModuleLoader</em>().loadModule(myModule.getIdentifier());</p><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><span style="font-size: 10pt;"><span style="font-size: 2;"><p align="left">ServiceLoader&lt;?&gt; serviceLoader = module.loadService(TestServicesIfc.</p></span><strong style="color: #7f0055; font-size: 10pt;"><strong style="color: #7f0055; font-size: 10pt;">class</strong></strong><span style="font-size: 2;">);&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;--- SUCCESS since it is using the jboss-modules api</span></span></span></p><p><span style="font-size: 10pt;"><p><p>Iterator&lt;?&gt; serviceIter = serviceLoader.iterator();</p></p><strong style=": ; color: #7f0055; font-size: 2;"><p align="left">if</p><p align="left"><span style="font-size: 10pt;"><span style="color: #000000;"> (serviceIter.hasNext()) {</span><span style="font-size: 2;"><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p></span></span></p><em><span style=": ; color: #0000c0; font-size: 2;">log</span><span style="font-size: 10pt;">.info(</span><span style="color: #2a00ff; font-size: 10pt;">"TestServicesIfc -------&gt; Found services class"</span><p><span style="font-size: 10pt;">);</span></p><p><p><span style="font-size: 10pt;">......</span></p><p><span style="font-size: 10pt;">ServiceLoader&lt;TestServicesIfc&gt; myService = ServiceLoader.<em>load</em>(TestServicesIfc.</span><strong style="color: #7f0055; font-size: 10pt;"><strong style="color: #7f0055; font-size: 10pt;">class</strong></strong><span style="font-size: 2;">);&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;-- FAILS</span><span style="font-size: 2;"><p><p align="left">Iterator&lt;TestServicesIfc&gt; iter = myService.iterator();</p><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><span style="font-size: 10pt;"><span style="font-size: 2;"><p align="left">} </p></span><strong style="color: #7f0055; font-size: 10pt;"><strong style="color: #7f0055; font-size: 10pt;">else</strong></strong><span style="font-size: 2;"> {</span></span><span style="font-size: 10pt;"><span style="font-size: 2;"><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p></span><em style="color: #0000c0; font-size: 10pt;"><em style="color: #0000c0; font-size: 10pt;">log</em></em><span style="font-size: 10pt;">.info(</span><span style="color: #2a00ff; font-size: 10pt;">"TestServicesIfc -------&gt; NOT Second Found services class"</span><span style="font-size: 2;">);</span></span><span style="font-size: 10pt;"><p>}</p></span></p><p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p></p><p>10:44:57,216 INFO&#160; [org.jboss.as.jmx.JMXConnectorService] (MSC service thread 1-2) Starting remote JMX connector<br/>10:44:57,217 INFO&#160; [org.jboss.as.remoting] (MSC service thread 1-3) Listening on /127.0.0.1:9999<br/>10:44:59,268 INFO&#160; [org.jboss.as.connector] (MSC service thread 1-3) Starting JCA Subsystem (JBoss IronJacamar 1.0.3.Fin<br/>al)<br/>10:44:59,705 INFO&#160; [org.jboss.as.connector.subsystems.datasources] (MSC service thread 1-2) Bound data source [java:jbos<br/>s/datasources/ExampleDS]<br/>10:45:36,561 INFO&#160; [com.modext.dans.services.TCCLSingletonService] (MSC service thread 1-4) TestServicesIfc -------&gt; Fou<br/>nd services class<br/>10:45:38,274 INFO&#160; [com.module.first.services.TestServicesImpl] (MSC service thread 1-4) HELLO<br/>10:45:50,258 INFO&#160; [com.modext.dans.services.TCCLSingletonService] (MSC service thread 1-4) TestServicesIfc -------&gt; NOT<br/> Second Found services class<br/>10:45:55,941 INFO&#160; [org.jboss.as.deployment] (MSC service thread 1-3) Started FileSystemDeploymentService for directory<br/>c:\jboss-as-7.1.0.Alpha1-SNAPSHOT\standalone\deployments<br/>10:45:55,979 INFO&#160; [org.jboss.as] (Controller Boot Thread) JBoss AS 7.1.0.Alpha1-SNAPSHOT "Lightning" started in 69825ms<br/> - Started 94 of 149 services (55 services are passive or on-demand)<br/>10:45:58,719 INFO&#160; [org.jboss.as.osgi] (MSC service thread 1-3) Stopping OSGi Framework<br/>10:45:58,737 INFO&#160; [org.jboss.as.logging] Restored bootstrap log handlers<br/>10:45:58,792 INFO&#160; [com.arjuna.ats.jbossatx] ARJUNA32018: Destroying TransactionManagerService<br/>10:45:58,794 INFO&#160; [com.arjuna.ats.jbossatx] ARJUNA32014: Stopping transaction recovery manager<br/>10:45:58,799 INFO&#160; [org.jboss.as] <span style="text-decoration: underline;"><em><strong>JBoss AS 7.1.0.Alpha1-SNAPSHOT </strong></em></span>"Lightning" stopped in 96ms</p></span><strong style="color: #7f0055; font-size: 10pt;"><strong style="color: #7f0055; font-size: 10pt;">if</strong></strong><span style="font-size: 10pt;"> (iter.hasNext()) {<span style="font-size: 2;"><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p></span><em style="color: #0000c0; font-size: 10pt;"><em style="color: #0000c0; font-size: 10pt;">log</em></em><span style="font-size: 10pt;">.info(</span><span style="color: #2a00ff; font-size: 10pt;">"TestServicesIfc -------&gt; Second trial: Found services class"</span><span style="font-size: 2;">);</span></span></p></p></em></strong></span><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p align="left" style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><div class="mcePaste" id="_mcePaste" style="position: absolute; top: 0px; left: 0px;"></div></p></div>

<div style="background-color: #f4f4f4; padding: 10px; margin-top: 20px;">
    <p style="margin: 0;">Reply to this message by <a href="http://community.jboss.org/message/625780#625780">going to Community</a></p>
        <p style="margin: 0;">Start a new discussion in JBoss AS7 Development at <a href="http://community.jboss.org/choose-container!input.jspa?contentType=1&containerType=14&container=2225">Community</a></p>
</div></td>
                        </tr>
                    </tbody>
                </table>


                </td>
            </tr>
        </tbody>
    </table>

</div>

</body>
</html>