mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-12 04:18:54 +00:00
76 lines
2.9 KiB
Prolog
76 lines
2.9 KiB
Prolog
# Add project specific ProGuard rules here.
|
|
# You can control the set of applied configuration files using the
|
|
# proguardFiles setting in build.gradle.
|
|
#
|
|
# For more details, see
|
|
# http://developer.android.com/guide/developing/tools/proguard.html
|
|
|
|
# If your project uses WebView with JS, uncomment the following
|
|
# and specify the fully qualified class name to the JavaScript interface
|
|
# class:
|
|
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
|
|
# public *;
|
|
#}
|
|
|
|
# Uncomment this to preserve the line number information for
|
|
# debugging stack traces.
|
|
#-keepattributes SourceFile,LineNumberTable
|
|
|
|
# If you keep the line number information, uncomment this to
|
|
# hide the original source file name.
|
|
#-renamesourcefileattribute SourceFile
|
|
|
|
-keep class com.sun.jna.** { *; }
|
|
-keep class * implements com.sun.jna.** { *; }
|
|
-dontwarn java.awt.Component
|
|
-dontwarn java.awt.GraphicsEnvironment
|
|
-dontwarn java.awt.HeadlessException
|
|
-dontwarn java.awt.Window
|
|
|
|
# Keep `Companion` object fields of serializable classes.
|
|
# This avoids serializer lookup through `getDeclaredClasses` as done for named companion objects.
|
|
-if @kotlinx.serialization.Serializable class **
|
|
-keepclassmembers class <1> {
|
|
static <1>$Companion Companion;
|
|
}
|
|
|
|
# Keep `serializer()` on companion objects (both default and named) of serializable classes.
|
|
-if @kotlinx.serialization.Serializable class ** {
|
|
static **$* *;
|
|
}
|
|
-keepclassmembers class <2>$<3> {
|
|
kotlinx.serialization.KSerializer serializer(...);
|
|
}
|
|
|
|
# Keep `INSTANCE.serializer()` of serializable objects.
|
|
-if @kotlinx.serialization.Serializable class ** {
|
|
public static ** INSTANCE;
|
|
}
|
|
-keepclassmembers class <1> {
|
|
public static <1> INSTANCE;
|
|
kotlinx.serialization.KSerializer serializer(...);
|
|
}
|
|
|
|
# @Serializable and @Polymorphic are used at runtime for polymorphic serialization.
|
|
-keepattributes RuntimeVisibleAnnotations,AnnotationDefault
|
|
|
|
# Don't print notes about potential mistakes or omissions in the configuration for kotlinx-serialization classes
|
|
# See also https://github.com/Kotlin/kotlinx.serialization/issues/1900
|
|
-dontnote kotlinx.serialization.**
|
|
|
|
# Serialization core uses `java.lang.ClassValue` for caching inside these specified classes.
|
|
# If there is no `java.lang.ClassValue` (for example, in Android), then R8/ProGuard will print a warning.
|
|
# However, since in this case they will not be used, we can disable these warnings
|
|
-dontwarn kotlinx.serialization.internal.ClassValueReferences
|
|
|
|
# disable optimisation for descriptor field because in some versions of ProGuard, optimization generates incorrect bytecode that causes a verification error
|
|
# see https://github.com/Kotlin/kotlinx.serialization/issues/2719
|
|
-keepclassmembers public class **$$serializer {
|
|
private ** descriptor;
|
|
}
|
|
|
|
# Keep file names and line numbers.
|
|
-keepattributes SourceFile,LineNumberTable
|
|
# Keep custom exceptions.
|
|
-keep public class * extends java.lang.Exception
|