All Downloads are FREE. Search and download functionalities are using the official Maven repository.

proguard.classfile.util.kotlin.KotlinNameUtil Maven / Gradle / Ivy

Go to download

ProGuardCORE is a free library to read, analyze, modify, and write Java class files.

There is a newer version: 9.1.6
Show newest version
/*
 * ProGuardCORE -- library to process Java bytecode.
 *
 * Copyright (c) 2002-2020 Guardsquare NV
 *
 * 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 proguard.classfile.util.kotlin;

import static proguard.classfile.util.kotlin.KotlinStringUtil.*;

/**
 * Kotlin utility methods to help with Kotlin naming conventions.
 *
 * 

See, for example, * https://github.com/JetBrains/kotlin/blob/master/core/descriptors.jvm/src/org/jetbrains/kotlin/load/java/JvmAbi.java * * @author James Hamilton */ public class KotlinNameUtil { public static final String GET_PREFIX = "get"; public static final String SET_PREFIX = "set"; public static final String IS_PREFIX = "is"; private KotlinNameUtil() {} public static String generateGetterName(String name) { return startsWithIsPrefix(name) ? name : prefixName(GET_PREFIX, name); } public static String generateSetterName(String name) { return prefixName( SET_PREFIX, startsWithIsPrefix(name) ? name.substring(IS_PREFIX.length()) : name); } public static boolean isGetterName(String name) { // Note: this does not call startsWithIsPrefix, so // e.g. isfalse is a getter name but does not start with "is" according // to startsWithIsPrefix - see org.jetbrains.kotlin.load.java.JvmAbi. return name.startsWith(GET_PREFIX) || name.startsWith(IS_PREFIX); } public static boolean isSetterName(String name) { return name.startsWith(SET_PREFIX); } /** * See Kotlin code: * https://github.com/JetBrains/kotlin/blob/a1569dfbf0b924eb717ce75069eb294fe3ea1c59/core/descriptors.jvm/src/org/jetbrains/kotlin/load/java/JvmAbi.java#L89 * * @param name name * @return true if the name starts with the "is" prefix. */ private static boolean startsWithIsPrefix(String name) { // It must start with "is" but cannot be just "is" if (!name.startsWith(IS_PREFIX) || name.equals(IS_PREFIX)) { return false; } // Only if the first char after the "is" prefix is not lower-case ASCII. // e.g. isfalse DOES NOT start with the "is" prefix. // isπροβοσκιδα DOES start with the "is" prefix (lower-case "π") char firstCharAfterIsPrefix = name.charAt(IS_PREFIX.length()); return !('a' <= firstCharAfterIsPrefix && firstCharAfterIsPrefix <= 'z'); } private static String prefixName(String prefix, String name) { if (name.length() == 0) { return name; } return prefix + capitializeFirstCharacterAsciiOnly(name); } /** * See propertiesConventionUtil.kt * *

For example: * *

getMyProperty -> myProperty isProperty -> property isfalse -> isfalse * * @param name the property getter name e.g. getMyProperty * @param stripAfterDollar strip any extra info added by the compiler * @return the property name */ public static String getterNameToPropertyName(String name, boolean stripAfterDollar) { if (stripAfterDollar && name.contains("$")) { name = name.substring(0, name.indexOf("$")); } if (isGetterName(name)) { if (name.startsWith(GET_PREFIX)) { return decapitializeForKotlinCompiler(name.substring(GET_PREFIX.length())); } else { // Don't strip "is" prefix. return name; } } else if (isSetterName(name)) { return decapitializeForKotlinCompiler(name.substring(SET_PREFIX.length())); } else { return name; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy