1 /* 2 * Copyright (C) 2017 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 android.location.cts.asn1.supl2.ver2_ulp_components; 18 19 /* 20 */ 21 22 23 // 24 // 25 import android.location.cts.asn1.base.Asn1Null; 26 import android.location.cts.asn1.base.Asn1SequenceOf; 27 import android.location.cts.asn1.base.Asn1Tag; 28 import android.location.cts.asn1.base.BitStream; 29 import android.location.cts.asn1.base.BitStreamReader; 30 import com.google.common.collect.ImmutableList; 31 import java.util.Collection; 32 import javax.annotation.Nullable; 33 34 35 /** 36 */ 37 public class MCC 38 extends Asn1SequenceOf<MCC_MNC_Digit> { 39 // 40 41 private static final Asn1Tag TAG_MCC 42 = Asn1Tag.fromClassAndNumber(-1, -1); 43 MCC()44 public MCC() { 45 super(); 46 setMinSize(3); 47 setMaxSize(3); 48 49 } 50 51 @Override 52 @Nullable getTag()53 protected Asn1Tag getTag() { 54 return TAG_MCC; 55 } 56 57 @Override isTagImplicit()58 protected boolean isTagImplicit() { 59 return true; 60 } 61 getPossibleFirstTags()62 public static Collection<Asn1Tag> getPossibleFirstTags() { 63 if (TAG_MCC != null) { 64 return ImmutableList.of(TAG_MCC); 65 } else { 66 return Asn1SequenceOf.getPossibleFirstTags(); 67 } 68 } 69 70 /** 71 * Creates a new MCC from encoded stream. 72 */ fromPerUnaligned(byte[] encodedBytes)73 public static MCC fromPerUnaligned(byte[] encodedBytes) { 74 MCC result = new MCC(); 75 result.decodePerUnaligned(new BitStreamReader(encodedBytes)); 76 return result; 77 } 78 79 /** 80 * Creates a new MCC from encoded stream. 81 */ fromPerAligned(byte[] encodedBytes)82 public static MCC fromPerAligned(byte[] encodedBytes) { 83 MCC result = new MCC(); 84 result.decodePerAligned(new BitStreamReader(encodedBytes)); 85 return result; 86 } 87 88 createAndAddValue()89 @Override public MCC_MNC_Digit createAndAddValue() { 90 MCC_MNC_Digit value = new MCC_MNC_Digit(); 91 add(value); 92 return value; 93 } 94 95 96 encodePerUnaligned()97 @Override public Iterable<BitStream> encodePerUnaligned() { 98 return super.encodePerUnaligned(); 99 } 100 encodePerAligned()101 @Override public Iterable<BitStream> encodePerAligned() { 102 return super.encodePerAligned(); 103 } 104 decodePerUnaligned(BitStreamReader reader)105 @Override public void decodePerUnaligned(BitStreamReader reader) { 106 super.decodePerUnaligned(reader); 107 } 108 decodePerAligned(BitStreamReader reader)109 @Override public void decodePerAligned(BitStreamReader reader) { 110 super.decodePerAligned(reader); 111 } 112 toString()113 @Override public String toString() { 114 return toIndentedString(""); 115 } 116 toIndentedString(String indent)117 public String toIndentedString(String indent) { 118 StringBuilder builder = new StringBuilder(); 119 builder.append("MCC = [\n"); 120 final String internalIndent = indent + " "; 121 for (MCC_MNC_Digit value : getValues()) { 122 builder.append(internalIndent) 123 .append(value.toIndentedString(internalIndent)); 124 } 125 builder.append(indent).append("];\n"); 126 return builder.toString(); 127 } 128 } 129