View Javadoc

1   /**
2    * Copyright (C) 2010 Daniel Manzke <daniel.manzke@googlemail.com>
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    *         http://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  package org.apache.onami.autobind.integrations.example.guicy.jndi;
17  
18  import javax.naming.InitialContext;
19  import javax.naming.NamingException;
20  
21  import org.apache.onami.autobind.annotations.Bind;
22  import org.apache.onami.autobind.annotations.GuiceModule;
23  import org.apache.onami.autobind.configuration.StartupModule;
24  import org.apache.onami.autobind.example.starter.ExampleApplication;
25  import org.apache.onami.autobind.scanner.ClasspathScanner;
26  import org.apache.onami.autobind.scanner.ScannerModule;
27  import org.apache.onami.autobind.scanner.asm.ASMClasspathScanner;
28  
29  
30  /**
31   * Example Application, which creates a new Injector with the help of the
32   * provided {@link StartupModule}. It passes the {@link ASMClasspathScanner}
33   * class for the {@link ClasspathScanner} and the packages (de.devsurf) which
34   * should be scanned. The {@link StartupModule} binds these parameter, so we are
35   * able to create and inject our {@link ScannerModule}. This Module uses the
36   * {@link ClasspathScanner} to explore the Classpath and scans for Annotations.
37   * 
38   * All recognized Classes annotated with {@link GuiceModule} are installed in
39   * the child injector and with {@link Bind} are automatically bound.
40   * 
41   * @author Daniel Manzke
42   * 
43   */
44  @Bind(multiple = true)
45  public class ExampleApp implements ExampleApplication {
46  	@Override
47  	public void run() {
48  		try {
49  			InitialContext context = new InitialContext();
50  			Example example = (Example) context.lookup(Example.class.getName());
51  
52  			System.out.println(example.sayHello());
53  		} catch (NamingException e) {
54  			e.printStackTrace();
55  		}
56  	}
57  
58  	public static void main(String[] args) {
59  		new ExampleApp().run();
60  	}
61  }