Stitch

Additional

Language
Java
Version
v1.0.1 (May 26, 2017)
Created
May 23, 2017
Updated
May 26, 2017 (Retired)
Owner
Amit Kumar (amitkma)
Contributor
Amit Kumar (amitkma)
1
Activity
Badge
Generate
Download
Source code

Stitch

Simple threading library using annotations for Android

Download

dependencies {
  compile 'com.github.amitkma:stitch-lib:1.0.1'
  annotationProcessor 'com.github.amitkma:compiler:1.0.1'
}

Usage

Using this library is as simple as creating Hello World Android app. Currently, there are three types of annotations which we support.

  • @CallOnAnyThread : This annotation annotates a method to execute on any thread from thread pool. This library create a fixed size thread pool on the basis of availbale processors. If all threads of the thread pool are busy, the task will be added to the task queue wait until a thread is available to process that task.
  • @CallOnNewThread : A method which is annotated with @CallOnNewThread will always execute on a new thread. So the task will never have to wait and always start executing immediately.
  • @CallOnUiThread : Want to do some ui changes like setting text, starting animation or anything else, simply annotate the method with @CallOnUiThread.

Any method which you want to execute on any particular thread, simply annotate that method like below.

class ExampleClass {
    
    public ExampleClass() {
    }

    @CallOnAnyThread
    public Bitmap getBitmapFromURL(String src) {
        try {
            URL url = new URL(src);
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();
            connection.setDoInput(true);
            connection.connect();
            InputStream input = connection.getInputStream();
            return BitmapFactory.decodeStream(input);
        } catch (IOException e) {
            // Log exception
            return null;
        }
    }
}

Now, build the project using terminal or by Build -> Rebuild Project in android studio. StitchCompiler will generate a new class file for the class in which annotated methods are. The name of generated class will be the name of existing class + "Stitch". For example in above case, name of generated file will be "ExampleClassStitch".

Next is to get the instance of the generated class (for calling the methods). So to get the instance of generated class, you need to stitch generated class and the required class like below :

// If getting instance in other class.
ExampleClassStitch exampleClassStitch = ExampleClassStitch.stitch(new ExampleClass()); 

// Or if getting instance in same class
ExampleClassStitch exampleClassStitch = ExampleClassStitch.stitch(this);.

After that, you can call the method as usual and the method will execute upon the annotated thread.

exampleClassStitch.getBitmapFromURL("https://image.freepik.com/free-vector/android-boot-logo_634639.jpg");

This is it.

Performance Issue

The answer is NO. This is because this library uses compile time processing and generates the code at compile time. So no reflection, No perf issue.

Remember - Don't make any change/update UI using @CallOnAnyThread or @CallOnNewThread otherwise android will throw an exception.

Contribution

For contribution guidelines, read Contribution guidelines for this project

License

Copyright 2017 Amit Kumar

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.