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