blob: 8cca8cd50dd95de10f5cd5acf1bf3879770c3de2 [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package android.location.cts.asn1.supl2.ver2_ulp_components;
/*
*/
//
//
import android.location.cts.asn1.base.Asn1Enumerated;
import android.location.cts.asn1.base.Asn1Integer;
import android.location.cts.asn1.base.Asn1Null;
import android.location.cts.asn1.base.Asn1Object;
import android.location.cts.asn1.base.Asn1Sequence;
import android.location.cts.asn1.base.Asn1Tag;
import android.location.cts.asn1.base.BitStream;
import android.location.cts.asn1.base.BitStreamReader;
import android.location.cts.asn1.base.SequenceComponent;
import com.google.common.collect.ImmutableList;
import java.util.Collection;
import javax.annotation.Nullable;
/**
*/
public class Coordinate extends Asn1Sequence {
//
private static final Asn1Tag TAG_Coordinate
= Asn1Tag.fromClassAndNumber(-1, -1);
public Coordinate() {
super();
}
@Override
@Nullable
protected Asn1Tag getTag() {
return TAG_Coordinate;
}
@Override
protected boolean isTagImplicit() {
return true;
}
public static Collection<Asn1Tag> getPossibleFirstTags() {
if (TAG_Coordinate != null) {
return ImmutableList.of(TAG_Coordinate);
} else {
return Asn1Sequence.getPossibleFirstTags();
}
}
/**
* Creates a new Coordinate from encoded stream.
*/
public static Coordinate fromPerUnaligned(byte[] encodedBytes) {
Coordinate result = new Coordinate();
result.decodePerUnaligned(new BitStreamReader(encodedBytes));
return result;
}
/**
* Creates a new Coordinate from encoded stream.
*/
public static Coordinate fromPerAligned(byte[] encodedBytes) {
Coordinate result = new Coordinate();
result.decodePerAligned(new BitStreamReader(encodedBytes));
return result;
}
@Override protected boolean isExtensible() {
return false;
}
@Override public boolean containsExtensionValues() {
for (SequenceComponent extensionComponent : getExtensionComponents()) {
if (extensionComponent.isExplicitlySet()) return true;
}
return false;
}
private Coordinate.latitudeSignType latitudeSign_;
public Coordinate.latitudeSignType getLatitudeSign() {
return latitudeSign_;
}
/**
* @throws ClassCastException if value is not a Coordinate.latitudeSignType
*/
public void setLatitudeSign(Asn1Object value) {
this.latitudeSign_ = (Coordinate.latitudeSignType) value;
}
public Coordinate.latitudeSignType setLatitudeSignToNewInstance() {
latitudeSign_ = new Coordinate.latitudeSignType();
return latitudeSign_;
}
private Coordinate.latitudeType latitude_;
public Coordinate.latitudeType getLatitude() {
return latitude_;
}
/**
* @throws ClassCastException if value is not a Coordinate.latitudeType
*/
public void setLatitude(Asn1Object value) {
this.latitude_ = (Coordinate.latitudeType) value;
}
public Coordinate.latitudeType setLatitudeToNewInstance() {
latitude_ = new Coordinate.latitudeType();
return latitude_;
}
private Coordinate.longitudeType longitude_;
public Coordinate.longitudeType getLongitude() {
return longitude_;
}
/**
* @throws ClassCastException if value is not a Coordinate.longitudeType
*/
public void setLongitude(Asn1Object value) {
this.longitude_ = (Coordinate.longitudeType) value;
}
public Coordinate.longitudeType setLongitudeToNewInstance() {
longitude_ = new Coordinate.longitudeType();
return longitude_;
}
@Override public Iterable<? extends SequenceComponent> getComponents() {
ImmutableList.Builder<SequenceComponent> builder = ImmutableList.builder();
builder.add(new SequenceComponent() {
Asn1Tag tag = Asn1Tag.fromClassAndNumber(2, 0);
@Override public boolean isExplicitlySet() {
return getLatitudeSign() != null;
}
@Override public boolean hasDefaultValue() {
return false;
}
@Override public boolean isOptional() {
return false;
}
@Override public Asn1Object getComponentValue() {
return getLatitudeSign();
}
@Override public void setToNewInstance() {
setLatitudeSignToNewInstance();
}
@Override public Collection<Asn1Tag> getPossibleFirstTags() {
return tag == null ? Coordinate.latitudeSignType.getPossibleFirstTags() : ImmutableList.of(tag);
}
@Override
public Asn1Tag getTag() {
return tag;
}
@Override
public boolean isImplicitTagging() {
return true;
}
@Override public String toIndentedString(String indent) {
return "latitudeSign : "
+ getLatitudeSign().toIndentedString(indent);
}
});
builder.add(new SequenceComponent() {
Asn1Tag tag = Asn1Tag.fromClassAndNumber(2, 1);
@Override public boolean isExplicitlySet() {
return getLatitude() != null;
}
@Override public boolean hasDefaultValue() {
return false;
}
@Override public boolean isOptional() {
return false;
}
@Override public Asn1Object getComponentValue() {
return getLatitude();
}
@Override public void setToNewInstance() {
setLatitudeToNewInstance();
}
@Override public Collection<Asn1Tag> getPossibleFirstTags() {
return tag == null ? Coordinate.latitudeType.getPossibleFirstTags() : ImmutableList.of(tag);
}
@Override
public Asn1Tag getTag() {
return tag;
}
@Override
public boolean isImplicitTagging() {
return true;
}
@Override public String toIndentedString(String indent) {
return "latitude : "
+ getLatitude().toIndentedString(indent);
}
});
builder.add(new SequenceComponent() {
Asn1Tag tag = Asn1Tag.fromClassAndNumber(2, 2);
@Override public boolean isExplicitlySet() {
return getLongitude() != null;
}
@Override public boolean hasDefaultValue() {
return false;
}
@Override public boolean isOptional() {
return false;
}
@Override public Asn1Object getComponentValue() {
return getLongitude();
}
@Override public void setToNewInstance() {
setLongitudeToNewInstance();
}
@Override public Collection<Asn1Tag> getPossibleFirstTags() {
return tag == null ? Coordinate.longitudeType.getPossibleFirstTags() : ImmutableList.of(tag);
}
@Override
public Asn1Tag getTag() {
return tag;
}
@Override
public boolean isImplicitTagging() {
return true;
}
@Override public String toIndentedString(String indent) {
return "longitude : "
+ getLongitude().toIndentedString(indent);
}
});
return builder.build();
}
@Override public Iterable<? extends SequenceComponent>
getExtensionComponents() {
ImmutableList.Builder<SequenceComponent> builder = ImmutableList.builder();
return builder.build();
}
/*
*/
//
/**
*/
public static class latitudeSignType extends Asn1Enumerated {
public enum Value implements Asn1Enumerated.Value {
north(0),
south(1),
;
Value(int i) {
value = i;
}
private int value;
public int getAssignedValue() {
return value;
}
@Override public boolean isExtensionValue() {
return false;
}
}
public enum ExtensionValue implements Asn1Enumerated.Value {
;
ExtensionValue(int i) {
value = i;
}
private int value;
@Override public int getAssignedValue() {
return value;
}
@Override public boolean isExtensionValue() {
return true;
}
}
private static final Asn1Tag TAG_latitudeSignType
= Asn1Tag.fromClassAndNumber(-1, -1);
public latitudeSignType() {
super();
}
@Override
@Nullable
protected Asn1Tag getTag() {
return TAG_latitudeSignType;
}
@Override
protected boolean isTagImplicit() {
return true;
}
public static Collection<Asn1Tag> getPossibleFirstTags() {
if (TAG_latitudeSignType != null) {
return ImmutableList.of(TAG_latitudeSignType);
} else {
return Asn1Enumerated.getPossibleFirstTags();
}
}
@Override protected boolean isExtensible() {
return false;
}
@Override protected Asn1Enumerated.Value lookupValue(int ordinal) {
return Value.values()[ordinal];
}
@Override protected Asn1Enumerated.Value lookupExtensionValue(int ordinal) {
return ExtensionValue.values()[ordinal];
}
@Override protected int getValueCount() {
return Value.values().length;
}
/**
* Creates a new latitudeSignType from encoded stream.
*/
public static latitudeSignType fromPerUnaligned(byte[] encodedBytes) {
latitudeSignType result = new latitudeSignType();
result.decodePerUnaligned(new BitStreamReader(encodedBytes));
return result;
}
/**
* Creates a new latitudeSignType from encoded stream.
*/
public static latitudeSignType fromPerAligned(byte[] encodedBytes) {
latitudeSignType result = new latitudeSignType();
result.decodePerAligned(new BitStreamReader(encodedBytes));
return result;
}
@Override public Iterable<BitStream> encodePerUnaligned() {
return super.encodePerUnaligned();
}
@Override public Iterable<BitStream> encodePerAligned() {
return super.encodePerAligned();
}
@Override public void decodePerUnaligned(BitStreamReader reader) {
super.decodePerUnaligned(reader);
}
@Override public void decodePerAligned(BitStreamReader reader) {
super.decodePerAligned(reader);
}
@Override public String toString() {
return toIndentedString("");
}
public String toIndentedString(String indent) {
return "latitudeSignType = " + getValue() + ";\n";
}
}
/*
*/
//
/**
*/
public static class latitudeType extends Asn1Integer {
//
private static final Asn1Tag TAG_latitudeType
= Asn1Tag.fromClassAndNumber(-1, -1);
public latitudeType() {
super();
setValueRange("0", "8388607");
}
@Override
@Nullable
protected Asn1Tag getTag() {
return TAG_latitudeType;
}
@Override
protected boolean isTagImplicit() {
return true;
}
public static Collection<Asn1Tag> getPossibleFirstTags() {
if (TAG_latitudeType != null) {
return ImmutableList.of(TAG_latitudeType);
} else {
return Asn1Integer.getPossibleFirstTags();
}
}
/**
* Creates a new latitudeType from encoded stream.
*/
public static latitudeType fromPerUnaligned(byte[] encodedBytes) {
latitudeType result = new latitudeType();
result.decodePerUnaligned(new BitStreamReader(encodedBytes));
return result;
}
/**
* Creates a new latitudeType from encoded stream.
*/
public static latitudeType fromPerAligned(byte[] encodedBytes) {
latitudeType result = new latitudeType();
result.decodePerAligned(new BitStreamReader(encodedBytes));
return result;
}
@Override public Iterable<BitStream> encodePerUnaligned() {
return super.encodePerUnaligned();
}
@Override public Iterable<BitStream> encodePerAligned() {
return super.encodePerAligned();
}
@Override public void decodePerUnaligned(BitStreamReader reader) {
super.decodePerUnaligned(reader);
}
@Override public void decodePerAligned(BitStreamReader reader) {
super.decodePerAligned(reader);
}
@Override public String toString() {
return toIndentedString("");
}
public String toIndentedString(String indent) {
return "latitudeType = " + getInteger() + ";\n";
}
}
/*
*/
//
/**
*/
public static class longitudeType extends Asn1Integer {
//
private static final Asn1Tag TAG_longitudeType
= Asn1Tag.fromClassAndNumber(-1, -1);
public longitudeType() {
super();
setValueRange("-8388608", "8388607");
}
@Override
@Nullable
protected Asn1Tag getTag() {
return TAG_longitudeType;
}
@Override
protected boolean isTagImplicit() {
return true;
}
public static Collection<Asn1Tag> getPossibleFirstTags() {
if (TAG_longitudeType != null) {
return ImmutableList.of(TAG_longitudeType);
} else {
return Asn1Integer.getPossibleFirstTags();
}
}
/**
* Creates a new longitudeType from encoded stream.
*/
public static longitudeType fromPerUnaligned(byte[] encodedBytes) {
longitudeType result = new longitudeType();
result.decodePerUnaligned(new BitStreamReader(encodedBytes));
return result;
}
/**
* Creates a new longitudeType from encoded stream.
*/
public static longitudeType fromPerAligned(byte[] encodedBytes) {
longitudeType result = new longitudeType();
result.decodePerAligned(new BitStreamReader(encodedBytes));
return result;
}
@Override public Iterable<BitStream> encodePerUnaligned() {
return super.encodePerUnaligned();
}
@Override public Iterable<BitStream> encodePerAligned() {
return super.encodePerAligned();
}
@Override public void decodePerUnaligned(BitStreamReader reader) {
super.decodePerUnaligned(reader);
}
@Override public void decodePerAligned(BitStreamReader reader) {
super.decodePerAligned(reader);
}
@Override public String toString() {
return toIndentedString("");
}
public String toIndentedString(String indent) {
return "longitudeType = " + getInteger() + ";\n";
}
}
@Override public Iterable<BitStream> encodePerUnaligned() {
return super.encodePerUnaligned();
}
@Override public Iterable<BitStream> encodePerAligned() {
return super.encodePerAligned();
}
@Override public void decodePerUnaligned(BitStreamReader reader) {
super.decodePerUnaligned(reader);
}
@Override public void decodePerAligned(BitStreamReader reader) {
super.decodePerAligned(reader);
}
@Override public String toString() {
return toIndentedString("");
}
public String toIndentedString(String indent) {
StringBuilder builder = new StringBuilder();
builder.append("Coordinate = {\n");
final String internalIndent = indent + " ";
for (SequenceComponent component : getComponents()) {
if (component.isExplicitlySet()) {
builder.append(internalIndent)
.append(component.toIndentedString(internalIndent));
}
}
if (isExtensible()) {
builder.append(internalIndent).append("...\n");
for (SequenceComponent component : getExtensionComponents()) {
if (component.isExplicitlySet()) {
builder.append(internalIndent)
.append(component.toIndentedString(internalIndent));
}
}
}
builder.append(indent).append("};\n");
return builder.toString();
}
}