xref: /aosp_15_r20/external/dagger2/java/dagger/internal/MapProviderFactory.java (revision f585d8a307d0621d6060bd7e80091fdcbf94fe27)
1*f585d8a3SJacky Wang /*
2*f585d8a3SJacky Wang  * Copyright (C) 2014 The Dagger Authors.
3*f585d8a3SJacky Wang  *
4*f585d8a3SJacky Wang  * Licensed under the Apache License, Version 2.0 (the "License");
5*f585d8a3SJacky Wang  * you may not use this file except in compliance with the License.
6*f585d8a3SJacky Wang  * You may obtain a copy of the License at
7*f585d8a3SJacky Wang  *
8*f585d8a3SJacky Wang  * http://www.apache.org/licenses/LICENSE-2.0
9*f585d8a3SJacky Wang  *
10*f585d8a3SJacky Wang  * Unless required by applicable law or agreed to in writing, software
11*f585d8a3SJacky Wang  * distributed under the License is distributed on an "AS IS" BASIS,
12*f585d8a3SJacky Wang  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*f585d8a3SJacky Wang  * See the License for the specific language governing permissions and
14*f585d8a3SJacky Wang  * limitations under the License.
15*f585d8a3SJacky Wang  */
16*f585d8a3SJacky Wang 
17*f585d8a3SJacky Wang package dagger.internal;
18*f585d8a3SJacky Wang 
19*f585d8a3SJacky Wang import static dagger.internal.DaggerCollections.newLinkedHashMapWithExpectedSize;
20*f585d8a3SJacky Wang import static dagger.internal.Providers.asDaggerProvider;
21*f585d8a3SJacky Wang 
22*f585d8a3SJacky Wang import dagger.Lazy;
23*f585d8a3SJacky Wang import java.util.Collections;
24*f585d8a3SJacky Wang import java.util.Map;
25*f585d8a3SJacky Wang 
26*f585d8a3SJacky Wang /**
27*f585d8a3SJacky Wang  * A {@link Factory} implementation used to implement {@link Map} bindings. This factory returns a
28*f585d8a3SJacky Wang  * {@code Map<K, Provider<V>>} when calling {@link #get} (as specified by {@link Factory}).
29*f585d8a3SJacky Wang  */
30*f585d8a3SJacky Wang public final class MapProviderFactory<K, V> extends AbstractMapFactory<K, V, Provider<V>>
31*f585d8a3SJacky Wang     implements Lazy<Map<K, Provider<V>>> {
32*f585d8a3SJacky Wang 
33*f585d8a3SJacky Wang   /** Returns a new {@link Builder} */
builder(int size)34*f585d8a3SJacky Wang   public static <K, V> Builder<K, V> builder(int size) {
35*f585d8a3SJacky Wang     return new Builder<>(size);
36*f585d8a3SJacky Wang   }
37*f585d8a3SJacky Wang 
MapProviderFactory(Map<K, Provider<V>> contributingMap)38*f585d8a3SJacky Wang   private MapProviderFactory(Map<K, Provider<V>> contributingMap) {
39*f585d8a3SJacky Wang     super(contributingMap);
40*f585d8a3SJacky Wang   }
41*f585d8a3SJacky Wang 
42*f585d8a3SJacky Wang   /**
43*f585d8a3SJacky Wang    * Returns a {@code Map<K, Provider<V>>} whose iteration order is that of the elements given by
44*f585d8a3SJacky Wang    * each of the providers, which are invoked in the order given at creation.
45*f585d8a3SJacky Wang    */
46*f585d8a3SJacky Wang   @Override
get()47*f585d8a3SJacky Wang   public Map<K, Provider<V>> get() {
48*f585d8a3SJacky Wang     return contributingMap();
49*f585d8a3SJacky Wang   }
50*f585d8a3SJacky Wang 
51*f585d8a3SJacky Wang   /** A builder for {@link MapProviderFactory}. */
52*f585d8a3SJacky Wang   public static final class Builder<K, V> extends AbstractMapFactory.Builder<K, V, Provider<V>> {
Builder(int size)53*f585d8a3SJacky Wang     private Builder(int size) {
54*f585d8a3SJacky Wang       super(size);
55*f585d8a3SJacky Wang     }
56*f585d8a3SJacky Wang 
57*f585d8a3SJacky Wang     @Override
put(K key, Provider<V> providerOfValue)58*f585d8a3SJacky Wang     public Builder<K, V> put(K key, Provider<V> providerOfValue) {
59*f585d8a3SJacky Wang       super.put(key, providerOfValue);
60*f585d8a3SJacky Wang       return this;
61*f585d8a3SJacky Wang     }
62*f585d8a3SJacky Wang 
63*f585d8a3SJacky Wang     /**
64*f585d8a3SJacky Wang      * Legacy javax version of the method to support libraries compiled with an older version of
65*f585d8a3SJacky Wang      * Dagger. Do not use directly.
66*f585d8a3SJacky Wang      */
67*f585d8a3SJacky Wang     @Deprecated
put(K key, javax.inject.Provider<V> providerOfValue)68*f585d8a3SJacky Wang     public Builder<K, V> put(K key, javax.inject.Provider<V> providerOfValue) {
69*f585d8a3SJacky Wang       return put(key, asDaggerProvider(providerOfValue));
70*f585d8a3SJacky Wang     }
71*f585d8a3SJacky Wang 
72*f585d8a3SJacky Wang     @Override
putAll(Provider<Map<K, Provider<V>>> mapProviderFactory)73*f585d8a3SJacky Wang     public Builder<K, V> putAll(Provider<Map<K, Provider<V>>> mapProviderFactory) {
74*f585d8a3SJacky Wang       super.putAll(mapProviderFactory);
75*f585d8a3SJacky Wang       return this;
76*f585d8a3SJacky Wang     }
77*f585d8a3SJacky Wang 
78*f585d8a3SJacky Wang     /**
79*f585d8a3SJacky Wang      * Legacy javax version of the method to support libraries compiled with an older version of
80*f585d8a3SJacky Wang      * Dagger. Do not use directly.
81*f585d8a3SJacky Wang      */
82*f585d8a3SJacky Wang     @Deprecated
putAll( final javax.inject.Provider<Map<K, javax.inject.Provider<V>>> mapProviderFactory)83*f585d8a3SJacky Wang     public Builder<K, V> putAll(
84*f585d8a3SJacky Wang         final javax.inject.Provider<Map<K, javax.inject.Provider<V>>> mapProviderFactory) {
85*f585d8a3SJacky Wang       return putAll(new Provider<Map<K, Provider<V>>>() {
86*f585d8a3SJacky Wang           @Override public Map<K, Provider<V>> get() {
87*f585d8a3SJacky Wang             Map<K, javax.inject.Provider<V>> javaxMap = mapProviderFactory.get();
88*f585d8a3SJacky Wang             if (javaxMap.isEmpty()) {
89*f585d8a3SJacky Wang               return Collections.emptyMap();
90*f585d8a3SJacky Wang             }
91*f585d8a3SJacky Wang             Map<K, Provider<V>> daggerMap = newLinkedHashMapWithExpectedSize(javaxMap.size());
92*f585d8a3SJacky Wang             for (Map.Entry<K, javax.inject.Provider<V>> e : javaxMap.entrySet()) {
93*f585d8a3SJacky Wang               daggerMap.put(e.getKey(), asDaggerProvider(e.getValue()));
94*f585d8a3SJacky Wang             }
95*f585d8a3SJacky Wang             return Collections.unmodifiableMap(daggerMap);
96*f585d8a3SJacky Wang           }
97*f585d8a3SJacky Wang       });
98*f585d8a3SJacky Wang     }
99*f585d8a3SJacky Wang 
100*f585d8a3SJacky Wang     /** Returns a new {@link MapProviderFactory}. */
build()101*f585d8a3SJacky Wang     public MapProviderFactory<K, V> build() {
102*f585d8a3SJacky Wang       return new MapProviderFactory<>(map);
103*f585d8a3SJacky Wang     }
104*f585d8a3SJacky Wang   }
105*f585d8a3SJacky Wang }
106