An-Droid 101
Developing Libraries
Nishant Srivastava
Android Dev/Interaction Designer
Organizer@GDG New Delhi
data:image/s3,"s3://crabby-images/779f9/779f9fda46cd81ecc331171d5003b405ce14763d" alt=""
Goals
WHAT ?
WHY ?
HOW ?
To answer the below with respect to Android Libraries
What is a Software Library ?
data:image/s3,"s3://crabby-images/233f0/233f0750a0a6bd67182434ad81e98df2bda9b8bf" alt=""
A software library generally consists of pre-written code, classes, procedures, scripts, configuration data and more.
It is designed to assist both the programmer and the programming language compiler in building and executing software.
WHY ?
data:image/s3,"s3://crabby-images/5beff/5beffa3b57b2c5ec64ffb7b1b1ec64bb986d1129" alt=""
Developers are lazy
..hence they reuse code.
..because
data:image/s3,"s3://crabby-images/1b52d/1b52df3281626accf476ddce931a82b552545e60" alt=""
- Build modular and independent blocks
- Write better softwares
- Speed up compile time
- Easier implementation
- Make code more testable
..and best of em all being ...
Make people happy..
data:image/s3,"s3://crabby-images/38e08/38e080c3f9661398563049a11df3cd39b9f7fddd" alt=""
.. OK , I guess BATMAN doesn't smile anyways.. :P
Before software can be reusable it first has to be usable.
- Ralph Johnson
Your code depends on Android idioms/resources
1.UI
2.Looper/Handler
3.Resources
4.Native Code
..and many more...
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
Why writing an Android library ?
AAR vs JAR
JAR - Java ARchive
.jar == Java library
Contains
java code
Used for
Functionality such as data handling, data manipulation, service integration
AAR - Android ARchive
.aar == Android library
Contains
java code + android resources + android manifest stub
Used for
Functionality that includes everything a jar can + UI
Finally ...a break ..
data:image/s3,"s3://crabby-images/3864a/3864aa561b631b33fb10ec0106f639f30d353a25" alt=""
HOW ?
data:image/s3,"s3://crabby-images/e05a5/e05a513c2465e3e924d5cabb3861b794478b95e8" alt=""
Step 1 : Gradle
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
..in their own words..
Emerge from Build Hell today through Gradle, the modern open source polyglot build automation system..
Step 2 : Create Project
How hard can it be ?
Fire up your Android Studio and Create a New Project
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
data:image/s3,"s3://crabby-images/6e9cd/6e9cda3e9625916987df672e25d4cad7d1e3bb70" alt=""
data:image/s3,"s3://crabby-images/c613c/c613cedf34f947475d7809d3655ec0cf5d0623eb" alt=""
Step 2 : {Gradle Build in progress}
Step 3 : Create a new module
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
Create a new module
data:image/s3,"s3://crabby-images/1058f/1058f181b2c80077a5a7bd95324b11871b71fdd2" alt=""
Step 3 : Create a new module (..contd)
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
Go on..
data:image/s3,"s3://crabby-images/88da8/88da8f90bdde0f1e9a8ca08ac113ef857d9524a8" alt=""
Step 3 : Create a new module (..contd)
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
We are going to stick to making an AAR module.
Once selected, my suggestion is to rename
- module name to library
- application name to <yourlibraryname>
- Package name to <domain.company.library.yourlibraryname>
Step 3 : Create a new module (..contd)
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
data:image/s3,"s3://crabby-images/b1b07/b1b07af8c917e7954be308e34146560a8319e516" alt=""
Step 4 : Crush Code (..literally)
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
data:image/s3,"s3://crabby-images/93c88/93c8834f700b66ef7b4c4e31fbca72c4096ad777" alt=""
.....and build your awesome library...
data:image/s3,"s3://crabby-images/c613c/c613cedf34f947475d7809d3655ec0cf5d0623eb" alt=""
Step 4 : {Create and Build your library}
- Entity class declaration
- Do
- Don't
- Do
void init(ApiSecret apisecret);
void init(String apikey, int refresh, long interval, String type);
Make Your Libraries
Stable
- Multi-Thread compatibility
- Singleton implementation
- Synchronization
- Immutable Entity
- Lifecycle mangement
- Object lifetime alignment
Make Your Libraries
Stable
Make Your Libraries
- Intuitive
- Consistent
- Easy to use, Hard to misuse
Easy to Use
public boolean hasPermission(Context context, String permission) {
int result = context.checkCallingOrSelfPermission(permission);
return result == PackageManager.PERMISSION_GRANTED;
}
Minimize Permissions
String feature = PackageManager.FEATURE_BLUETOOTH;
public boolean isFeatureAvailable(Context context, String feature) {
return context.getPackageManager().hasSystemFeature(feature);
}
Minimize Requisites
Things to take care of..
public boolean isMarshmallow(){
return Build.VERSION.SDK_INT>= Build.VERSION_CODES.M;
}
Support different versions
Things to take care of..
Make your code Testable
- Mock
- No static methods
- Avoid final classes
// In code
boolean debuggable = false;
MyAwesomeLibrary.init(debuggable);
// In build.gradle
debuggable = true
Donot log in production
Things to take care of..
Do not crash silently - Log all exceptions and print them in the logcat
Handle poor network conditions
Reluctance to include large libraries
dependencies {
provided 'com.squareup.okhttp3:okhttp:3.1.2'
}
Donot require libraries
Things to take care of..
Check in classpath
private boolean hasOKHttpOnClasspath() {
try {
Class.forName("ccom.squareup.okhttp3.OkHttpClient");
return true;
} catch (ClassNotFoundException ex) {
ex.printStackTrace();
}
return false;
}
..simply put follow the rule of SPOIL-ing your Library ..
Simple - Briefly and Clearly expressed
Purposeful - Having or showing resolve
OpenSource - Universal Access, Free license
Idiomatic - Natural to the native environment
Logical - Clear, Sound Reasoning
Step 5 : {Create and Build your library}
$ ./gradle build
or
$ ./gradlew build
Step 6
http://developer.android.com/tools/testing/testing_android.html
Write & Use Unit Tests
Step 7
$ gradle clean connectedCheck
Run Your Tests
...and if you don't ...this is what happens..
data:image/s3,"s3://crabby-images/6dba5/6dba5f0548ad5d4ba1f9b436d9d08b45e84c0b67" alt=""
Step 8
Readme.md
JavaDocs
Example Apps
Document
Step 9
Maven Central / Jcenter
Local/Remote Maven Repositories
Local AAR
Publish
Use your library in another project
data:image/s3,"s3://crabby-images/7ef3a/7ef3a80c17d6d0977a2ebfd010b9be2d42e1f86a" alt=""
....So you have built you awesome library, huh !
So the only thing left now is understanding how to use it in another project, right...
If you are not familiar with the way you include a dependency/library in your project via using gradle then here it is :
dependencies {
compile 'com.company.library:myawesomelibrary:23.1.1'
}
Libraries are a necessary evil
...and thats it for today folks!
data:image/s3,"s3://crabby-images/c1f01/c1f01f5574efb0e672bad940c0077381bcedb093" alt=""
Me after this session..literally :P
Questions ?
data:image/s3,"s3://crabby-images/1d3a1/1d3a117565cad3eb0b9a220ae9debc73729fd96f" alt=""