1 /*
2  * Copyright (C) 2007 Google Inc.
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 
17 package com.google.inject;
18 
19 import com.google.inject.internal.InternalInjectorCreator;
20 import java.util.Arrays;
21 
22 /**
23  * The entry point to the Guice framework. Creates {@link Injector}s from {@link Module}s.
24  *
25  * <p>Guice supports a model of development that draws clear boundaries between APIs,
26  * Implementations of these APIs, Modules which configure these implementations, and finally
27  * Applications which consist of a collection of Modules. It is the Application, which typically
28  * defines your {@code main()} method, that bootstraps the Guice Injector using the {@code Guice}
29  * class, as in this example:
30  *
31  * <pre>
32  *     public class FooApplication {
33  *       public static void main(String[] args) {
34  *         Injector injector = Guice.createInjector(
35  *             new ModuleA(),
36  *             new ModuleB(),
37  *             . . .
38  *             new FooApplicationFlagsModule(args)
39  *         );
40  *
41  *         // Now just bootstrap the application and you're done
42  *         FooStarter starter = injector.getInstance(FooStarter.class);
43  *         starter.runApplication();
44  *       }
45  *     }
46  * </pre>
47  */
48 public final class Guice {
49 
50   private Guice() {}
51 
52   /**
53    * Creates an injector for the given set of modules. This is equivalent to calling {@link
54    * #createInjector(Stage, Module...)} with Stage.DEVELOPMENT.
55    *
56    * @throws CreationException if one or more errors occur during injector construction
57    */
58   public static Injector createInjector(Module... modules) {
59     return createInjector(Arrays.asList(modules));
60   }
61 
62   /**
63    * Creates an injector for the given set of modules. This is equivalent to calling {@link
64    * #createInjector(Stage, Iterable)} with Stage.DEVELOPMENT.
65    *
66    * @throws CreationException if one or more errors occur during injector creation
67    */
68   public static Injector createInjector(Iterable<? extends Module> modules) {
69     return createInjector(Stage.DEVELOPMENT, modules);
70   }
71 
72   /**
73    * Creates an injector for the given set of modules, in a given development stage.
74    *
75    * @throws CreationException if one or more errors occur during injector creation.
76    */
77   public static Injector createInjector(Stage stage, Module... modules) {
78     return createInjector(stage, Arrays.asList(modules));
79   }
80 
81   /**
82    * Creates an injector for the given set of modules, in a given development stage.
83    *
84    * @throws CreationException if one or more errors occur during injector construction
85    */
86   public static Injector createInjector(Stage stage, Iterable<? extends Module> modules) {
87     return new InternalInjectorCreator().stage(stage).addModules(modules).build();
88   }
89 }
90