1917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul/* 2917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Copyright (C) 2007 The Android Open Source Project 3917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 4917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Licensed under the Apache License, Version 2.0 (the "License"); 5917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * you may not use this file except in compliance with the License. 6917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * You may obtain a copy of the License at 7917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 8917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * http://www.apache.org/licenses/LICENSE-2.0 9917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 10917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Unless required by applicable law or agreed to in writing, software 11917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * distributed under the License is distributed on an "AS IS" BASIS, 12917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * See the License for the specific language governing permissions and 14917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * limitations under the License. 15917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 16917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 17917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulpackage com.android.dexgen.rop.cst; 18917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 19917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulimport com.android.dexgen.rop.type.Type; 20917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulimport com.android.dexgen.util.Hex; 21917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 22917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul/** 23917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Constants of type {@code char}. 24917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 25917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulpublic final class CstChar 26917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul extends CstLiteral32 { 27917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@code non-null;} the value {@code 0} as an instance of this class */ 28917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public static final CstChar VALUE_0 = make((char) 0); 29917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 30917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 31917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Makes an instance for the given value. This may (but does not 32917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * necessarily) return an already-allocated instance. 33917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 34917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @param value the {@code char} value 35917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 36917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public static CstChar make(char value) { 37917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return new CstChar(value); 38917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 39917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 40917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 41917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Makes an instance for the given {@code int} value. This 42917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * may (but does not necessarily) return an already-allocated 43917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * instance. 44917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 45917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @param value the value, which must be in range for a {@code char} 46917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return {@code non-null;} the appropriate instance 47917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 48917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public static CstChar make(int value) { 49917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul char cast = (char) value; 50917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 51917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul if (cast != value) { 52917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul throw new IllegalArgumentException("bogus char value: " + 53917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul value); 54917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 55917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 56917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return make(cast); 57917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 58917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 59917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 60917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Constructs an instance. This constructor is private; use {@link #make}. 61917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 62917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @param value the {@code char} value 63917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 64917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul private CstChar(char value) { 65917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul super(value); 66917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 67917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 68917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 69917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul @Override 70917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public String toString() { 71917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul int value = getIntBits(); 72917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return "char{0x" + Hex.u2(value) + " / " + value + '}'; 73917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 74917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 75917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 76917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public Type getType() { 77917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return Type.CHAR; 78917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 79917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 80917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 81917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul @Override 82917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public String typeName() { 83917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return "char"; 84917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 85917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 86917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 87917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public String toHuman() { 88917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return Integer.toString(getIntBits()); 89917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 90917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 91917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 92917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Gets the {@code char} value. 93917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 94917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return the value 95917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 96917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public char getValue() { 97917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return (char) getIntBits(); 98917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 99917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul} 100