# Add project specific ProGuard rules here.
# By default, the flags in this file are appended to flags specified
# in /Users/amitkumar/sdk/tools/proguard/proguard-android.txt
# You can edit the include path and order by changing the proguardFiles
# directive in build.gradle.
#
# For more details, see
#   http://developer.android.com/guide/developing/tools/proguard.html

# Add any project specific keep options here:

# 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 *;
#}
#
# This ProGuard configuration file illustrates how to process a program
# library, such that it remains usable as a library.
# Usage:
#     java -jar proguard.jar @library.pro
#

# Specify the input jars, output jars, and library jars.
# In this case, the input jar is the program library that we want to process.

#-injars  in.jar
#-outjars out.jar

#-libraryjars  <java.home>/lib/rt.jar

# Save the obfuscation mapping to a file, so we can de-obfuscate any stack
# traces later on. Keep a fixed source file attribute and all line number
# tables to get line numbers in the stack traces.
# You can comment this out if you're not interested in stack traces.

-printmapping out.map
-keepparameternames
-keeppackagenames
-renamesourcefileattribute SourceFile
-keepattributes Exceptions,InnerClasses,Signature,Deprecated,SourceFile,LineNumberTable,EnclosingMethod

# Preserve all annotations.

-keepattributes *Annotation*

# Preserve all public classes, and their public and protected fields and
# methods.

#-keep public class * {
#    public protected *;
#}

-keepclassmembers class **.R$* {
    public static <fields>;
}
# Preserve all .class method names.

-keepclassmembernames class * {
    java.lang.Class class$(java.lang.String);
    java.lang.Class class$(java.lang.String, boolean);
}

# Preserve all native method names and the names of their classes.

-keepclasseswithmembernames class * {
    native <methods>;
}

# Preserve the special static methods that are required in all enumeration
# classes.

-keepclassmembers class * extends java.lang.Enum {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

 -keep public class com.payu.upisdk.Upi{public protected *; }
 -keep public class com.payu.upisdk.UpiWrapper{ public protected *; }
 -keep public class com.payu.upisdk.upi.IValidityCheck{ public protected *; }
 -keep public class com.payu.upisdk.callbacks.**{ public protected *; }
 -keep public class com.payu.upisdk.util.UpiConstant{ public protected *; }
 -keep public class com.payu.upisdk.bean.UpiConfig{ public protected *; }
 -keep public class com.payu.upisdk.PaymentOption{ public protected *; }
 -keep public class com.payu.upisdk.generatepostdata.**{ public protected *; }
   # Keep the BuildConfig
 -keep public class com.payu.upisdk.BuildConfig{ *; }