• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright 2022 Google LLC
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  *      https://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.area120.tables.v1alpha1;
18 
19 import com.google.api.pathtemplate.PathTemplate;
20 import com.google.api.resourcenames.ResourceName;
21 import com.google.common.base.Preconditions;
22 import com.google.common.collect.ImmutableMap;
23 import java.util.ArrayList;
24 import java.util.List;
25 import java.util.Map;
26 import java.util.Objects;
27 import javax.annotation.Generated;
28 
29 // AUTO-GENERATED DOCUMENTATION AND CLASS.
30 @Generated("by gapic-generator-java")
31 public class RowName implements ResourceName {
32   private static final PathTemplate TABLE_ROW =
33       PathTemplate.createWithoutUrlEncoding("tables/{table}/rows/{row}");
34   private volatile Map<String, String> fieldValuesMap;
35   private final String table;
36   private final String row;
37 
38   @Deprecated
RowName()39   protected RowName() {
40     table = null;
41     row = null;
42   }
43 
RowName(Builder builder)44   private RowName(Builder builder) {
45     table = Preconditions.checkNotNull(builder.getTable());
46     row = Preconditions.checkNotNull(builder.getRow());
47   }
48 
getTable()49   public String getTable() {
50     return table;
51   }
52 
getRow()53   public String getRow() {
54     return row;
55   }
56 
newBuilder()57   public static Builder newBuilder() {
58     return new Builder();
59   }
60 
toBuilder()61   public Builder toBuilder() {
62     return new Builder(this);
63   }
64 
of(String table, String row)65   public static RowName of(String table, String row) {
66     return newBuilder().setTable(table).setRow(row).build();
67   }
68 
format(String table, String row)69   public static String format(String table, String row) {
70     return newBuilder().setTable(table).setRow(row).build().toString();
71   }
72 
parse(String formattedString)73   public static RowName parse(String formattedString) {
74     if (formattedString.isEmpty()) {
75       return null;
76     }
77     Map<String, String> matchMap =
78         TABLE_ROW.validatedMatch(
79             formattedString, "RowName.parse: formattedString not in valid format");
80     return of(matchMap.get("table"), matchMap.get("row"));
81   }
82 
parseList(List<String> formattedStrings)83   public static List<RowName> parseList(List<String> formattedStrings) {
84     List<RowName> list = new ArrayList<>(formattedStrings.size());
85     for (String formattedString : formattedStrings) {
86       list.add(parse(formattedString));
87     }
88     return list;
89   }
90 
toStringList(List<RowName> values)91   public static List<String> toStringList(List<RowName> values) {
92     List<String> list = new ArrayList<>(values.size());
93     for (RowName value : values) {
94       if (value == null) {
95         list.add("");
96       } else {
97         list.add(value.toString());
98       }
99     }
100     return list;
101   }
102 
isParsableFrom(String formattedString)103   public static boolean isParsableFrom(String formattedString) {
104     return TABLE_ROW.matches(formattedString);
105   }
106 
107   @Override
getFieldValuesMap()108   public Map<String, String> getFieldValuesMap() {
109     if (fieldValuesMap == null) {
110       synchronized (this) {
111         if (fieldValuesMap == null) {
112           ImmutableMap.Builder<String, String> fieldMapBuilder = ImmutableMap.builder();
113           if (table != null) {
114             fieldMapBuilder.put("table", table);
115           }
116           if (row != null) {
117             fieldMapBuilder.put("row", row);
118           }
119           fieldValuesMap = fieldMapBuilder.build();
120         }
121       }
122     }
123     return fieldValuesMap;
124   }
125 
getFieldValue(String fieldName)126   public String getFieldValue(String fieldName) {
127     return getFieldValuesMap().get(fieldName);
128   }
129 
130   @Override
toString()131   public String toString() {
132     return TABLE_ROW.instantiate("table", table, "row", row);
133   }
134 
135   @Override
equals(Object o)136   public boolean equals(Object o) {
137     if (o == this) {
138       return true;
139     }
140     if (o != null || getClass() == o.getClass()) {
141       RowName that = ((RowName) o);
142       return Objects.equals(this.table, that.table) && Objects.equals(this.row, that.row);
143     }
144     return false;
145   }
146 
147   @Override
hashCode()148   public int hashCode() {
149     int h = 1;
150     h *= 1000003;
151     h ^= Objects.hashCode(table);
152     h *= 1000003;
153     h ^= Objects.hashCode(row);
154     return h;
155   }
156 
157   /** Builder for tables/{table}/rows/{row}. */
158   public static class Builder {
159     private String table;
160     private String row;
161 
Builder()162     protected Builder() {}
163 
getTable()164     public String getTable() {
165       return table;
166     }
167 
getRow()168     public String getRow() {
169       return row;
170     }
171 
setTable(String table)172     public Builder setTable(String table) {
173       this.table = table;
174       return this;
175     }
176 
setRow(String row)177     public Builder setRow(String row) {
178       this.row = row;
179       return this;
180     }
181 
Builder(RowName rowName)182     private Builder(RowName rowName) {
183       this.table = rowName.table;
184       this.row = rowName.row;
185     }
186 
build()187     public RowName build() {
188       return new RowName(this);
189     }
190   }
191 }
192