Saturday, November 7, 2015

Android-So You Want to Write an App?


In this blog, I will try and filter out my learning experience with Android 23. Only what did work for me will be reflected below. And my computer info is:
alec@alec-MS-7623 ~/product $ uname -aLinux alec-MS-7623 3.13.0-24-generic #47-Ubuntu SMP Fri May 2 23:30:00 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux
The first thing to do is to DOWNLOAD ANDROID STUDIO FOR LINUX - hit this button when you see it. Then:
alec@alec-MS-7623 ~ $ cd ~/product/
alec@alec-MS-7623 ~/product $ mv ~/Downloads/android-studio-ide-141.2343393-linux.zip .
alec@alec-MS-7623 ~/product $ unzip android-studio-ide-141.2343393-linux.zip 
...alec@alec-MS-7623 ~/product $ mkdir ~/binalec@alec-MS-7623 ~/product $ cd ~/binalec@alec-MS-7623 ~/bin $ ln -s ~/product/android-studio/bin/studio.sh android-studio
and
alec@alec-MS-7623 ~/bin $ cd ~/project/alec@alec-MS-7623 ~/project $ mkdir androidalec@alec-MS-7623 ~/project $ cd android/alec@alec-MS-7623 ~/project/android $ android-studio &
Now follow the instructions on the Installing Android Studio page. Having launched Standalone SDK Manager, hit the Install... button. Sleep!

Saturday, March 21, 2015

Exporting an existing local Git repository to Github

To do so, I followed the Github documentation:

    https://help.github.com/articles/importing-a-git-repository-using-the-command-line/

. It worked. In this blog, I am trying to understand what exactly I have done.

On a remote computer (IP 192.168.1.5), I did some work that I wanted eventually to go to Github, so that I would be able to access my work from anywhere. I renamed the root directory of the project containing this work to minetats-webapp.git, so that the name would correspond to the empty Github repository I created following the doc mentioned above. On that computer, I created a Git repository with cd minetats-webapp.git && git init.

On the local computer, I cloned that repository with

git clone --bare ssh://192.168.1.5:/home/alec/project/minetats-webapp.git

. Then I did


cd minetats-webapp.git/
git push --mirror https://github.com/amissine/minetats-webapp.git

, and it worked. Before I ran cd .. && rm -rf minetats-webapp.git to clean up,
I took a look at what was inside the directory I was about to remove. The directory contained what a typical .git directory inside a Git repository would contain. So much for understanding. When I cloned my work from Github to test it locally,

git clone https://github.com/amissine/minetats-webapp.git

, it was successfully cloned into minetats-webapp.

Saturday, March 14, 2015

A Node.js Rookie Diary

To run your code in a browser, you write it in javascript these days. With node.js, the server-side code can be written in jabascript too. Both sides need to be configurable, need to support dependency injection. Finally, the server side needs to be an HTTP server. The package.json file below reflects my picks on these dependencies:

{
  "name": "webapp.js",
  "version": "1.0.0",
  "description": "A web application with common dependencies",
  "main": "./lib",
  "scripts": {
    "test": "grunt nodeunit"
  },
  "dependencies": {
    "konfy": "0.1.3",
    "dijon": "0.6.1",
    "flatiron": "0.4.3",
    "director": "1.2.8",
    "http-server": "0.7.5"
  },
  "author": "Alec Missine",
  "license": "MIT"
}

 I created it with npm init, then manually edited the dependencies part. Having installed these dependencies in your $WEBAPP_HOME with npm install, you now can

cd $WEB_HOME
node $WEBAPP_HOME/node_modules/http-server/bin/http-server

The static content of your $WEB_HOME will be served on port 8080. If you do not want to cd $WEB_HOME, you can node $HTTP_SERVER_HOME/bin/http-server $WEB_HOME.

To familiarize myself with http-server, I ran

node-inspector &
node --debug node_modules/http-server/node_modules/union/examples/simple/simple.js

in one terminal window, and

curl -d "data to post" http://localhost:9090/foo

in another, while directing my Chrome browser to http://127.0.0.1:8080/debug?port=5858 .  In the browser, I was able to debug the simple.js code.

Monday, March 9, 2015

Installing HandBrake on Linux Mint

sudo apt-get update
sudo apt-get install subversion yasm build-essential \
  autoconf libtool zlib1g-dev libbz2-dev libogg-dev \
  libtheora-dev libvorbis-dev libsamplerate-dev \
  libxml2-dev libfribidi-dev libfreetype6-dev \
  libfontconfig1-dev libass-dev intltool libglib2.0-dev \
  libdbus-glib-1-dev libgtk2.0-dev libgudev-1.0-dev \
  libwebkit-dev libnotify-dev libgstreamer0.10-dev \
  libgstreamer-plugins-base0.10-dev libappindicator-dev \
  libx264-dev libmp3lame-dev libjansson-dev
./configure --launch --disable-gtk

First use:

cd build/
./HandBrakeCLI -i /home/alec/process/cox/laa/San_Diego_Clip.ts \
  -o /home/alec/process/cox/laa/San_Diego_Clip.mp4