blob: c6ed9efd471be873e79be38961833c2503d6cd86 [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.ulp_components;
/*
*/
//
//
import android.location.cts.asn1.base.Asn1BitString;
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 Horveluncert extends Asn1Sequence {
//
private static final Asn1Tag TAG_Horveluncert
= Asn1Tag.fromClassAndNumber(-1, -1);
public Horveluncert() {
super();
}
@Override
@Nullable
protected Asn1Tag getTag() {
return TAG_Horveluncert;
}
@Override
protected boolean isTagImplicit() {
return true;
}
public static Collection<Asn1Tag> getPossibleFirstTags() {
if (TAG_Horveluncert != null) {
return ImmutableList.of(TAG_Horveluncert);
} else {
return Asn1Sequence.getPossibleFirstTags();
}
}
/**
* Creates a new Horveluncert from encoded stream.
*/
public static Horveluncert fromPerUnaligned(byte[] encodedBytes) {
Horveluncert result = new Horveluncert();
result.decodePerUnaligned(new BitStreamReader(encodedBytes));
return result;
}
/**
* Creates a new Horveluncert from encoded stream.
*/
public static Horveluncert fromPerAligned(byte[] encodedBytes) {
Horveluncert result = new Horveluncert();
result.decodePerAligned(new BitStreamReader(encodedBytes));
return result;
}
@Override protected boolean isExtensible() {
return true;
}
@Override public boolean containsExtensionValues() {
for (SequenceComponent extensionComponent : getExtensionComponents()) {
if (extensionComponent.isExplicitlySet()) return true;
}
return false;
}
private Horveluncert.bearingType bearing_;
public Horveluncert.bearingType getBearing() {
return bearing_;
}
/**
* @throws ClassCastException if value is not a Horveluncert.bearingType
*/
public void setBearing(Asn1Object value) {
this.bearing_ = (Horveluncert.bearingType) value;
}
public Horveluncert.bearingType setBearingToNewInstance() {
bearing_ = new Horveluncert.bearingType();
return bearing_;
}
private Horveluncert.horspeedType horspeed_;
public Horveluncert.horspeedType getHorspeed() {
return horspeed_;
}
/**
* @throws ClassCastException if value is not a Horveluncert.horspeedType
*/
public void setHorspeed(Asn1Object value) {
this.horspeed_ = (Horveluncert.horspeedType) value;
}
public Horveluncert.horspeedType setHorspeedToNewInstance() {
horspeed_ = new Horveluncert.horspeedType();
return horspeed_;
}
private Horveluncert.uncertspeedType uncertspeed_;
public Horveluncert.uncertspeedType getUncertspeed() {
return uncertspeed_;
}
/**
* @throws ClassCastException if value is not a Horveluncert.uncertspeedType
*/
public void setUncertspeed(Asn1Object value) {
this.uncertspeed_ = (Horveluncert.uncertspeedType) value;
}
public Horveluncert.uncertspeedType setUncertspeedToNewInstance() {
uncertspeed_ = new Horveluncert.uncertspeedType();
return uncertspeed_;
}
@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 getBearing() != null;
}
@Override public boolean hasDefaultValue() {
return false;
}
@Override public boolean isOptional() {
return false;
}
@Override public Asn1Object getComponentValue() {
return getBearing();
}
@Override public void setToNewInstance() {
setBearingToNewInstance();
}
@Override public Collection<Asn1Tag> getPossibleFirstTags() {
return tag == null ? Horveluncert.bearingType.getPossibleFirstTags() : ImmutableList.of(tag);
}
@Override
public Asn1Tag getTag() {
return tag;
}
@Override
public boolean isImplicitTagging() {
return true;
}
@Override public String toIndentedString(String indent) {
return "bearing : "
+ getBearing().toIndentedString(indent);
}
});
builder.add(new SequenceComponent() {
Asn1Tag tag = Asn1Tag.fromClassAndNumber(2, 1);
@Override public boolean isExplicitlySet() {
return getHorspeed() != null;
}
@Override public boolean hasDefaultValue() {
return false;
}
@Override public boolean isOptional() {
return false;
}
@Override public Asn1Object getComponentValue() {
return getHorspeed();
}
@Override public void setToNewInstance() {
setHorspeedToNewInstance();
}
@Override public Collection<Asn1Tag> getPossibleFirstTags() {
return tag == null ? Horveluncert.horspeedType.getPossibleFirstTags() : ImmutableList.of(tag);
}
@Override
public Asn1Tag getTag() {
return tag;
}
@Override
public boolean isImplicitTagging() {
return true;
}
@Override public String toIndentedString(String indent) {
return "horspeed : "
+ getHorspeed().toIndentedString(indent);
}
});
builder.add(new SequenceComponent() {
Asn1Tag tag = Asn1Tag.fromClassAndNumber(2, 2);
@Override public boolean isExplicitlySet() {
return getUncertspeed() != null;
}
@Override public boolean hasDefaultValue() {
return false;
}
@Override public boolean isOptional() {
return false;
}
@Override public Asn1Object getComponentValue() {
return getUncertspeed();
}
@Override public void setToNewInstance() {
setUncertspeedToNewInstance();
}
@Override public Collection<Asn1Tag> getPossibleFirstTags() {
return tag == null ? Horveluncert.uncertspeedType.getPossibleFirstTags() : ImmutableList.of(tag);
}
@Override
public Asn1Tag getTag() {
return tag;
}
@Override
public boolean isImplicitTagging() {
return true;
}
@Override public String toIndentedString(String indent) {
return "uncertspeed : "
+ getUncertspeed().toIndentedString(indent);
}
});
return builder.build();
}
@Override public Iterable<? extends SequenceComponent>
getExtensionComponents() {
ImmutableList.Builder<SequenceComponent> builder = ImmutableList.builder();
return builder.build();
}
/*
*/
//
/**
*/
public static class bearingType extends Asn1BitString {
//
private static final Asn1Tag TAG_bearingType
= Asn1Tag.fromClassAndNumber(-1, -1);
public bearingType() {
super();
setMinSize(9);
setMaxSize(9);
}
@Override
@Nullable
protected Asn1Tag getTag() {
return TAG_bearingType;
}
@Override
protected boolean isTagImplicit() {
return true;
}
public static Collection<Asn1Tag> getPossibleFirstTags() {
if (TAG_bearingType != null) {
return ImmutableList.of(TAG_bearingType);
} else {
return Asn1BitString.getPossibleFirstTags();
}
}
/**
* Creates a new bearingType from encoded stream.
*/
public static bearingType fromPerUnaligned(byte[] encodedBytes) {
bearingType result = new bearingType();
result.decodePerUnaligned(new BitStreamReader(encodedBytes));
return result;
}
/**
* Creates a new bearingType from encoded stream.
*/
public static bearingType fromPerAligned(byte[] encodedBytes) {
bearingType result = new bearingType();
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 "bearingType = " + getValue() + ";\n";
}
}
/*
*/
//
/**
*/
public static class horspeedType extends Asn1BitString {
//
private static final Asn1Tag TAG_horspeedType
= Asn1Tag.fromClassAndNumber(-1, -1);
public horspeedType() {
super();
setMinSize(16);
setMaxSize(16);
}
@Override
@Nullable
protected Asn1Tag getTag() {
return TAG_horspeedType;
}
@Override
protected boolean isTagImplicit() {
return true;
}
public static Collection<Asn1Tag> getPossibleFirstTags() {
if (TAG_horspeedType != null) {
return ImmutableList.of(TAG_horspeedType);
} else {
return Asn1BitString.getPossibleFirstTags();
}
}
/**
* Creates a new horspeedType from encoded stream.
*/
public static horspeedType fromPerUnaligned(byte[] encodedBytes) {
horspeedType result = new horspeedType();
result.decodePerUnaligned(new BitStreamReader(encodedBytes));
return result;
}
/**
* Creates a new horspeedType from encoded stream.
*/
public static horspeedType fromPerAligned(byte[] encodedBytes) {
horspeedType result = new horspeedType();
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 "horspeedType = " + getValue() + ";\n";
}
}
/*
*/
//
/**
*/
public static class uncertspeedType extends Asn1BitString {
//
private static final Asn1Tag TAG_uncertspeedType
= Asn1Tag.fromClassAndNumber(-1, -1);
public uncertspeedType() {
super();
setMinSize(8);
setMaxSize(8);
}
@Override
@Nullable
protected Asn1Tag getTag() {
return TAG_uncertspeedType;
}
@Override
protected boolean isTagImplicit() {
return true;
}
public static Collection<Asn1Tag> getPossibleFirstTags() {
if (TAG_uncertspeedType != null) {
return ImmutableList.of(TAG_uncertspeedType);
} else {
return Asn1BitString.getPossibleFirstTags();
}
}
/**
* Creates a new uncertspeedType from encoded stream.
*/
public static uncertspeedType fromPerUnaligned(byte[] encodedBytes) {
uncertspeedType result = new uncertspeedType();
result.decodePerUnaligned(new BitStreamReader(encodedBytes));
return result;
}
/**
* Creates a new uncertspeedType from encoded stream.
*/
public static uncertspeedType fromPerAligned(byte[] encodedBytes) {
uncertspeedType result = new uncertspeedType();
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 "uncertspeedType = " + getValue() + ";\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("Horveluncert = {\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();
}
}