1 /* 2 * Copyright (C) 2019 The Android Open Source Project 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.android.codegentest; 18 19 import android.annotation.NonNull; 20 import android.os.Parcel; 21 import android.os.Parcelable; 22 import android.os.SystemClock; 23 24 import com.android.internal.util.DataClass; 25 26 import java.util.concurrent.TimeUnit; 27 28 @DataClass(genBuilder = true, genAidl = false, genToString = true) 29 public class SampleWithCustomBuilder implements Parcelable { 30 31 long delayAmount = 0; 32 @NonNull 33 TimeUnit delayUnit = TimeUnit.MILLISECONDS; 34 35 long creationTimestamp = SystemClock.uptimeMillis(); 36 37 /** 38 * You can declare a class named {@code BaseBuilder} to have the generated builder extend from 39 * it instead. 40 * 41 * Same rules apply where defining a non-abstract method will suppress the generation of a 42 * method with the same signature. 43 * 44 * For abstract generatable methods, implementations are generated as normal, but original 45 * visibility is used, allowing you to hide methods. 46 * 47 * Here for example, we hide {@link #setDelayUnit} and {@link #setDelayAmount} from public API, 48 * replacing it with {@link #setDelay} instead. 49 */ 50 // Suppress setter generation for a field that is not supposed to come from user input. 51 @DataClass.Suppress("setCreationTimestamp") 52 static abstract class BaseBuilder { 53 54 /** 55 * Hide methods by declaring them with reduced (package-private) visibility. 56 */ setDelayAmount(long value)57 abstract Builder setDelayAmount(long value); 58 59 /** 60 * Alternatively, hide methods by using @hide, to hide them from public API only. 61 * 62 * @hide 63 */ setDelayUnit(TimeUnit value)64 public abstract Builder setDelayUnit(TimeUnit value); 65 66 /** 67 * Can provide additional method on the builder, e.g. as a replacement for the ones we've 68 * just hidden. 69 */ setDelay(long amount, TimeUnit unit)70 public Builder setDelay(long amount, TimeUnit unit) { 71 setDelayAmount(amount); 72 setDelayUnit(unit); 73 return (Builder) this; 74 } 75 } 76 77 unparcelDelayUnit(Parcel p)78 private static TimeUnit unparcelDelayUnit(Parcel p) { 79 return TimeUnit.values()[p.readInt()]; 80 } 81 parcelDelayUnit(Parcel p, int flags)82 private void parcelDelayUnit(Parcel p, int flags) { 83 p.writeInt(delayUnit.ordinal()); 84 } 85 86 87 88 // Code below generated by codegen v1.0.15. 89 // 90 // DO NOT MODIFY! 91 // CHECKSTYLE:OFF Generated code 92 // 93 // To regenerate run: 94 // $ codegen $ANDROID_BUILD_TOP/frameworks/base/tests/Codegen/src/com/android/codegentest/SampleWithCustomBuilder.java 95 // 96 // To exclude the generated code from IntelliJ auto-formatting enable (one-time): 97 // Settings > Editor > Code Style > Formatter Control 98 //@formatter:off 99 100 101 @DataClass.Generated.Member SampleWithCustomBuilder( long delayAmount, @NonNull TimeUnit delayUnit, long creationTimestamp)102 /* package-private */ SampleWithCustomBuilder( 103 long delayAmount, 104 @NonNull TimeUnit delayUnit, 105 long creationTimestamp) { 106 this.delayAmount = delayAmount; 107 this.delayUnit = delayUnit; 108 com.android.internal.util.AnnotationValidations.validate( 109 NonNull.class, null, delayUnit); 110 this.creationTimestamp = creationTimestamp; 111 112 // onConstructed(); // You can define this method to get a callback 113 } 114 115 @DataClass.Generated.Member getDelayAmount()116 public long getDelayAmount() { 117 return delayAmount; 118 } 119 120 @DataClass.Generated.Member getDelayUnit()121 public @NonNull TimeUnit getDelayUnit() { 122 return delayUnit; 123 } 124 125 @DataClass.Generated.Member getCreationTimestamp()126 public long getCreationTimestamp() { 127 return creationTimestamp; 128 } 129 130 @Override 131 @DataClass.Generated.Member toString()132 public String toString() { 133 // You can override field toString logic by defining methods like: 134 // String fieldNameToString() { ... } 135 136 return "SampleWithCustomBuilder { " + 137 "delayAmount = " + delayAmount + ", " + 138 "delayUnit = " + delayUnit + ", " + 139 "creationTimestamp = " + creationTimestamp + 140 " }"; 141 } 142 143 @Override 144 @DataClass.Generated.Member writeToParcel(@onNull Parcel dest, int flags)145 public void writeToParcel(@NonNull Parcel dest, int flags) { 146 // You can override field parcelling by defining methods like: 147 // void parcelFieldName(Parcel dest, int flags) { ... } 148 149 dest.writeLong(delayAmount); 150 parcelDelayUnit(dest, flags); 151 dest.writeLong(creationTimestamp); 152 } 153 154 @Override 155 @DataClass.Generated.Member describeContents()156 public int describeContents() { return 0; } 157 158 /** @hide */ 159 @SuppressWarnings({"unchecked", "RedundantCast"}) 160 @DataClass.Generated.Member SampleWithCustomBuilder(@onNull Parcel in)161 protected SampleWithCustomBuilder(@NonNull Parcel in) { 162 // You can override field unparcelling by defining methods like: 163 // static FieldType unparcelFieldName(Parcel in) { ... } 164 165 long _delayAmount = in.readLong(); 166 TimeUnit _delayUnit = unparcelDelayUnit(in); 167 long _creationTimestamp = in.readLong(); 168 169 this.delayAmount = _delayAmount; 170 this.delayUnit = _delayUnit; 171 com.android.internal.util.AnnotationValidations.validate( 172 NonNull.class, null, delayUnit); 173 this.creationTimestamp = _creationTimestamp; 174 175 // onConstructed(); // You can define this method to get a callback 176 } 177 178 @DataClass.Generated.Member 179 public static final @NonNull Parcelable.Creator<SampleWithCustomBuilder> CREATOR 180 = new Parcelable.Creator<SampleWithCustomBuilder>() { 181 @Override 182 public SampleWithCustomBuilder[] newArray(int size) { 183 return new SampleWithCustomBuilder[size]; 184 } 185 186 @Override 187 public SampleWithCustomBuilder createFromParcel(@NonNull Parcel in) { 188 return new SampleWithCustomBuilder(in); 189 } 190 }; 191 192 /** 193 * A builder for {@link SampleWithCustomBuilder} 194 */ 195 @SuppressWarnings("WeakerAccess") 196 @DataClass.Generated.Member 197 public static class Builder extends BaseBuilder { 198 199 private long delayAmount; 200 private @NonNull TimeUnit delayUnit; 201 private long creationTimestamp; 202 203 private long mBuilderFieldsSet = 0L; 204 Builder()205 public Builder() { 206 } 207 208 @DataClass.Generated.Member 209 @Override setDelayAmount(long value)210 @NonNull Builder setDelayAmount(long value) { 211 checkNotUsed(); 212 mBuilderFieldsSet |= 0x1; 213 delayAmount = value; 214 return this; 215 } 216 217 @DataClass.Generated.Member 218 @Override setDelayUnit(@onNull TimeUnit value)219 public @NonNull Builder setDelayUnit(@NonNull TimeUnit value) { 220 checkNotUsed(); 221 mBuilderFieldsSet |= 0x2; 222 delayUnit = value; 223 return this; 224 } 225 226 /** Builds the instance. This builder should not be touched after calling this! */ build()227 public @NonNull SampleWithCustomBuilder build() { 228 checkNotUsed(); 229 mBuilderFieldsSet |= 0x8; // Mark builder used 230 231 if ((mBuilderFieldsSet & 0x1) == 0) { 232 delayAmount = 0; 233 } 234 if ((mBuilderFieldsSet & 0x2) == 0) { 235 delayUnit = TimeUnit.MILLISECONDS; 236 } 237 if ((mBuilderFieldsSet & 0x4) == 0) { 238 creationTimestamp = SystemClock.uptimeMillis(); 239 } 240 SampleWithCustomBuilder o = new SampleWithCustomBuilder( 241 delayAmount, 242 delayUnit, 243 creationTimestamp); 244 return o; 245 } 246 checkNotUsed()247 private void checkNotUsed() { 248 if ((mBuilderFieldsSet & 0x8) != 0) { 249 throw new IllegalStateException( 250 "This Builder should not be reused. Use a new Builder instance instead"); 251 } 252 } 253 } 254 255 @DataClass.Generated( 256 time = 1582685648622L, 257 codegenVersion = "1.0.15", 258 sourceFile = "frameworks/base/tests/Codegen/src/com/android/codegentest/SampleWithCustomBuilder.java", 259 inputSignatures = " long delayAmount\n @android.annotation.NonNull java.util.concurrent.TimeUnit delayUnit\n long creationTimestamp\nprivate static java.util.concurrent.TimeUnit unparcelDelayUnit(android.os.Parcel)\nprivate void parcelDelayUnit(android.os.Parcel,int)\nclass SampleWithCustomBuilder extends java.lang.Object implements [android.os.Parcelable]\n@com.android.internal.util.DataClass(genBuilder=true, genAidl=false, genToString=true)\nabstract com.android.codegentest.SampleWithCustomBuilder.Builder setDelayAmount(long)\npublic abstract com.android.codegentest.SampleWithCustomBuilder.Builder setDelayUnit(java.util.concurrent.TimeUnit)\npublic com.android.codegentest.SampleWithCustomBuilder.Builder setDelay(long,java.util.concurrent.TimeUnit)\nclass BaseBuilder extends java.lang.Object implements []") 260 @Deprecated __metadata()261 private void __metadata() {} 262 263 264 //@formatter:on 265 // End of generated code 266 267 } 268