What's on my mind

Enable Bitcode in library file (.a)

After enable bit code in Xcode 7 , I couldn’t build .a file with embed-bitcode. Same problem for the zbar library , too. So, I cannot use my own library with .a file or cannot use the zbar for production. After searching from google , I found a way to build. We need to use the command line with xcodebuild.

I wrote the like following and same folder with myproject.xcodeproj


xcodebuild OTHER_CFLAGS="-fembed-bitcode" -target $project_name build
xcodebuild OTHER_CFLAGS="-fembed-bitcode" -sdk iphonesimulator -target $project_name build
rm -r build/Production-SDK
cp -r build/$folder-iphoneos build/Production-SDK
cp build/$folder-iphonesimulator/$lib_name.a build/Production-SDK/$name_simulator.a
mv build/Production-SDK/$lib_name.a build/Production-SDK/$name_device.a
cd build/Production-SDK/
lipo -create $name_simulator.a $name_device.a -output $lib_name.a
rm $name_device.a
rm $name_simulator.a
file $lib_name.a
open .

In the , folder is your release folder name. zbar is using Distribution-iphoneos and Distribution-iphonesimulator .

If you using your own , it may be Release-iphoneos and Release-iphonesimulator. lib_name is your .a library name. In Zbar , it’s using libzbar . project_name is your traget to build. Sometime , lib_name and project_name is different in the project.

After chasing this two, you can run in terminal like

sh ./

Need to wait until finishing the build and then it will show your lib.a file. In the terminal , you can check , it’s showing what platform are supporting.

If it doesn’t support i386,x86_64,armv7,arm64 , you need to open your project. Go to Build Settings -> Valid Archtectures. Add all architectures like following

  • armv7
  • armv7s
  • i386
  • arm64
  • x86_64

Don’t forget to change Build Active Architecture Only to NO

Install Intl in PHP , Mac

To install Intl library for PHP in Mac , you need to install brew first.

Install Brew For ICU

First , update the brew

brew update

Search the ice package name.

 brew search icu

You will find like icu4c and install it.

brew install icu4c

Your icu4c path is


Version may not be same. You can check director at /usr/local/Cellar/icu4c/

After we got icu4c , we can install intl from peel.


Unsplash Wall

You may know the It is Free (do whatever you want) high-resolution photos. It has a lot of photos and great for using as wallpaper for my iPhone and iPad. So, I created the unsplash wall. It’s using for backend API.

Unsplash Wall is simple and beautiful and showing the all images from

cover image

You can get the full screen image when you click the photo and you can save or share.




It was writting in Swift and nothing special. Very simple project and focus on clear and simple. So, I didn’t put so many function in there. I just want to see all images and save the photos. That all for now.

You can download Unsplash Wall From App Store , now.

Google Play Service With Genymotion

First you need to download following files.

If you want to know Android version from CyanogenMod , you can check at following.

  • Cyanogen 9.1 , Android 4.0.x
  • Cyanogen 10.0.0 , Android 4.1.x
  • Cyanogen 10.1.3 , Android 4.2.x
  • Cyanogen 10.2.1 , Android 4.3.x
  • Cyanogen 11.0 , Android 4.4.x


  • Open Genymotion
  • Drag and Drop the ARM Translation Installer v1.1 zip file Genymotion Virtual Device
  • Reboot The Genymotion Virtual Device
  • After reboot , Drag and Drop the Google Apps zip file to Genymotion Virtual Device
  • Reboot the Genymotion Virtual Device

After reboot you can find the Google Play Store in application list. Open play store and update all the google apps. After updating and downloading the apps, pull down the Notification bar. You can find to update google play store in notification.

ref: stackoverflow

Number padding with decimal

You may see some personal fincial app , you need to put the number like calculator.

Example : First it show 0.00

You enter 1

it will be like 0.01. And then press 5 , it will be 0.15. And then press 3 , it will be 1.53 .

So, how to write this one ?

Normal thinking way it, you need to check

  1. Append the string at the end
  2. Check first number is zero or not.
  3. If zero , remove it.
  4. Move the decimal posiotion.

A bit complicate. Actually it’s not hard like that.

Very simple way is

  1. Append the string at the end.
  2. remove .
  3. dvided by 100

That all. Very simple step.

Example with objective-c , it will be like

NSString* str = [NSString stringWithFormat:@"%@%@", txtAmount.text,string];
str = [str stringByReplacingOccurrencesOfString:@"." withString:@""]; 
txtAmount.text = [@"" stringByAppendingFormat:@"%0.2f", [str doubleValue]/100.0];

Custom Wintersmith Helper

Today , I was trying to add twitter card in my blog. It have a problem for twitter card description. Wintersmith didn’t support plain text for blog post. Blog intro already using the HTML code. So, I need to remove.

So, I create the custom helper like following.

Create a wintersmith-custom-helper folder under node_modules

In the wintersmith-custom-helper , it have 2 file. index.js and package.json .

In the package.json

  "name": "wintersmith-customhelper",
  "version": "1.0.0",
  "description": "Custom Helper For My Blog",
  "author": "saturngod",
  "license": "MIT",
  "keywords": [
  "main": "index.js",
  "dependencies": {
  "devDependencies": {
    "vows": "0.7.x",
    "wintersmith": "2.x"
  "peerDependencies": {
    "wintersmith": "2.x"

I gave the module name is wintersmith-customhelper.

In the index.html

module.exports = function(env, callback) {
  env.helpers.getDescription = function(htmlcode) {
    var code;
    code = htmlcode.replace(/(<([^>]+)>)/g, "");
    code = code.substring(0, 255);
    code = code.replace("\n", " ");
    code = code.replace("\"", "");
    return code = code + " ... ";
  return callback();

I create the getDescription helper for description.

After finish that, need to update the config.json

In the config.json , we need to put the plugin. So, it will be like

"plugins": [

Done. So, we can call env.helpers.getDescription in our template.

- var plain = env.helpers.getDescription(page.intro)
meta(name='twitter:description', content="#{plain}")

It easy to create helper and you can also use .coffce instead of .js file for plugin.

Decimal Format In Android

Yesterday , I found a bug in the app that I working on. If it’s a indonesia language in phone , my app can’t work properly. Because Android didn’t return the decimal if we are using indonesia language setting.

Example :

String amt = String.format("%.2f",20.05);
Log.i("test","Amount is " + amt); //if indo language , it will return 20,00 instead of 20.05

I tested with DecimalFormat but same result.

DecimalFormat f = new DecimalFormat("##.00");
String atm = f.format(d); 
Log.i("test","Amount is " + amt); //if indo language , it will return 20,00 instead of 20.05

So, I am using like following for now.

String amt = String.format("%.2f",20.05);

if(atm.indexOf(",") != -1)
    atm = atm.replace(",", ".");

Log.i("test","Amount is " + amt);

Redmi Note With adb in mac

  • Enable Developer Options.
  • Enable USB Debugging.

In terminal,

$ echo "0x2717" > ~/.android/adb_usb.ini
$ ./adb kill-server
$ ./adb devices

Unable To Downloaded Application with Testflight

Yesterday , I got a problem with Testflight. I gave them the app with testflight for testing. However, they can’t install and always got “Unable to Download Application”.

I found the article on testflight .

  • Device storage is full
  • The provisioning profile is a developer provisioning profile
  • The ad hoc distribution provisioning profile is corrupted and the device is having an issue with it (this can happen for multiple reasons. Including issues with 3rd party dev tools that could be causing a conflict).
  • The device was restored from a backup and is causing a conflict for over-the-air distribution
  • There was a network timeout
  • Architecture settings of the build and the device are incompatible ( can sometimes happen when “Build Active Architecture Only” is on when building).
  • The target minimum iOS version for the app is greater than the iOS version installed on the device.
  • Not Using Mobile Safari.

Everthing is correct. But I forget to check Architecture settings. I am using Build Active Architecture Only . So, it’s a problem. Ater I change to the Build Active Architecture Only to NO and it’s working fine.

Swift Is Fast Now

Today, I update the Xcode 6 Beta 3 and retest the bubble sort that I wrote yesterday. In Beta 3, bubble sort is done in 11 miliseconds in Debug Mode. Before it done in 14 miliseconds. After that I changed to the Release Mode and run it. It done in the 0.15 miliseconds. Yes, this time swift is faster than Objective-C now. In objective-C , it done in 0.28 miliseconds.

Swift Programming Language book has been updated and you need to update it.

Changes in Xcode 6 beta 3 for Swift are

  • Array in Swift has been completely redesigned to have full value semantics like Dictionary and String have always had in Swift. This resolves various mutability problems – now a ‘let’ array is completely immutable, and a ‘var’ array is completely mutable – composes properly with Dictionary and String, and solves other deeper problems. Value semantics may be surprising if you are used to NSArray or C arrays: a copy of the array now produces a full and independent copy of all of the elements using an efficient lazy copy implementation. This is a major change for Array, and there are still some performance issues to be addressed. Please see the Swift Programming Language for more information. (17192555)!
  • The Array and Dictionary “sugar” syntax has been redesigned: You now declare arrays as [Int] instead of as Int[], as shorthand for Array. The old syntax made sense when arrays had semantics closer to C arrays, but would be misleading with the new value semantics approach. Along with this, Dictionary syntax has improved so that [Key:Value] is treated as sugar for Dictionary. Both of these are now consistent with each other and with the literal syntax used to build an array or dictionary. Please see the Swift Programming Language for more information.!
  • NSDictionary* is now imported from Objective-C APIs as [NSObject : AnyObject]. (16870626)!
  • The half-closed range operator has been changed from .. to ..< to reduce confusion and ambiguity. Now the two range operators are ..< and … for half-closed and closed ranges, respectively (17203527).!
  • nil is now a literal in the language, not a global constant of _Nil type. This change resolved a number of problems with nil; e.g. nil in a collection, nil converting to Any, etc. Types can now indicate that they are nil compatible by conforming to the NilLiteralConvertible protocol. (16951729)!
  • APIs imported from C no longer use type aliases like CInt or CFloat, which obfuscated the underlying type. They are now imported as Int32 and Float, etc.!
  • APIs imported from C that use C pointers are now imported with a much simpler API type structure which is more predictable, preserves const mutability in more cases, and preserves __autoreleased pointer information. Now you will see UnsafePointer, ConstUnsafePointer, AutoreleasingUnsafePointer, etc. Function pointers are also imported now, and can be referenced and passed around. However, you cannot call a C function pointer or convert a closure to C function pointer type.!

You can read more at here