Blizzard is the Enemy of Rails
Posted by rad in Uncategorized on July 28, 2010
Not Django, not Java, but Blizzard. They’re actively working to reduce Rails3 adoption.
Take a look at these dates:
Rails3 beta1 release date: Feb 5, 2010
Starcraft 2 beta release date: Feb 17, 2010
Rails 3 RC release date: July 26, 2010
Starcraft 2 release: July 27, 2010
Corona SDK
Posted by rad in Game Development, Programming, iPhone on June 16, 2010
It seems I can develop some games much, much faster with the Corona SDK. It will cost me $99, and it’s not as macho as mastering Objective-C, but I think I’ll end up saving hundreds of hours with this kit.
I think Corona is a great kit for writing games in general, especially arcade games and board games. There’s no built-in support yet for tiled maps, and it looks like Cocos2D will have that built-in first. But even with that disadvantage, developing on Lua is so much more productive than developing on Objective-C that I’ll still come out ahead.
Some apps aren’t a good fit, though:
- those that extensively use the CocoaTouch UI controls. In Corona, you have to create your own buttons, text fields, etc. There’s the ui library, but it only covers a few controls.
- those that access APIs that aren’t wrapped yet by Corona. For example, access to the address book seems to be missing.
There’s the worry that Corona SDK will violate section 3.3.1. Folks from Corona gave some reassuring messages, but of course, with Apple, you can’t have absolute uncertainty. My take is that even if Apple gives Corona the boot, Corona will become Android-only, and Corona SDK is worth $99 even as an Android
I’m taking the $99 plunge. If nothing else, I think Lua will give me a refreshing break from my day-to-day Ruby and Javascript coding.
work.sh
Posted by rad in Programming on June 10, 2010
From a cold boot, to start working on one of my Rails projects, I need to do the following:
That’s a lot of keystrokes and mouse actions. No wonder I end up playing games most of the time, because Age of Empires III takes just one click.
I can configure MySQL and PostgreSQL to run on startup, but that’s wasteful. That’ll slow down the machine’s startup time, and sometimes I use just MySQL, on other projects I use PostgreSQL, and on other projects I use neither but instead use MongoDB. And that will just take away one step in this 5-step process to get from cold bootup to work bliss.
Ideally, there’s a one-click work button, a sideproject1 button, a sideproject2 button, etc. Press the right button and the Mac will be transformed into a mode optimized for the work to be done: run the needed apps, close unneeded apps, play music from the “work playlist”, change the desktop background, etc.
I have decided to learn AppleScript to build those magic buttons. Here’s what I’ve come up with so far:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#!/bin/sh
# From: http://stackoverflow.com/questions/1589114/opening-a-new-terminal-tab-in-osxsnow-leopard-with-the-opening-terminal-windows/1590818#1590818
# (See answer by i0n that says "courtesy of Dan Benjamin" http://twitter.com/danbenjamin)
# Sets up my Infinitely terminal windows
# 1. Run MongoDB
# 2. Run redis in a new terminal tab
# 3. cd to the project
# 4. Launch Evernote
# 5. Launch Firefox
# 6. Launch GitX
# 1. Run MongoDB in a new terminal
/usr/bin/osascript <<mongo
activate application "Terminal"
tell application "System Events"
keystroke "t" using {command down}
end tell
tell application "Terminal"
repeat with win in windows
try
if get frontmost of win is true then
do script "cd ~; ./mongo.sh" in (selected tab of win)
end if
end try
end repeat
end tell
mongo
# 2. Run redis in a new terminal
/usr/bin/osascript <<redis
activate application "Terminal"
tell application "System Events"
keystroke "t" using {command down}
end tell
tell application "Terminal"
repeat with win in windows
try
if get frontmost of win is true then
do script "cd ~; ./redis.sh" in (selected tab of win)
end if
end try
end repeat
end tell
redis
# 3. cd to the workers project
/usr/bin/osascript <<workers
activate application "Terminal"
tell application "System Events"
keystroke "t" using {command down}
end tell
tell application "Terminal"
repeat with win in windows
try
if get frontmost of win is true then
do script "cd ~/Documents/projects/infinitely/workers; mate ." in (selected tab of win)
end if
end try
end repeat
end tell
workers
sleep 1
# 4. Launch Evernote
open /Applications/Evernote.app
# 5. Launch Firefox
open /Applications/Firefox.app
clear
There’s still no “Open iTunes and play songs in my ‘work’ playlist” section, but I’m working on it. And here’s something to make it more interesting: AppleScripting with Ruby!
This script borrowed heavily from the ideas of the people in this Stackoverflow thread.
iPhone SDK TOS 3.3.1: One Month later
Posted by rad in Game Development, iPhone on May 8, 2010
If you’ve been living in a cave, “3.3.1″ refers to section 3.3.1 of the iPhone Developer Program License Agreement. Section 3.3.1 for the iPhone 4.0SDK beta reads:
3.3.1 — Applications may only use Documented APIs in the manner prescribed by Apple and must not use or call any private APIs. Applications must be originally written in Objective-C, C, C++, or JavaScript as executed by the iPhone OS WebKit engine, and only code written in C, C++, and Objective-C may compile and directly link against the Documented APIs (e.g., Applications that link to Documented APIs through an intermediary translation or compatibility layer or tool are prohibited).
It’s been about a month since 3.3.1 came out. The most obvious impact of this is on Adobe Flash CS5. Prior to 3.3.1, Adobe has announced that Flash CS5 will include a Flash-to-iPhone compiler. Now, Adobe has cancelled that feature.
Here’s a roundup of how the other iPhone development tool providers have reacted to 3.3.1. Except for funkaster, writer of shinycocos, most of them seem to be optimistic that they’re in the clear.
AnscaMobile (Corona SDK):
http://blog.anscamobile.com/2010/04/corona-and-iphone-os-4-0/
Torque (iTorque):
http://www.torquepowered.com/community/blogs/view/19715
Unity:
http://blogs.unity3d.com/2010/04/10/unity-and-the-iphone-os-4-0/
funkaster (shinycocos):
http://github.com/funkaster/shinycocos/commit/9ebda7fcfc853db266b4b49c01bdbc5fa5a9be42#comments
(see the comments below the git commit)
Rhomobile:
http://rhomobile.com/2010/04/09/iphone-4-0-sdk-rules/
Me? I’ll stick to learning plain XCode, Objective-C, plus the Cocos2d Library.
(CONSTANT == var) vs. (var == CONSTANT)
Posted by rad in Programming on February 19, 2010
I’ve been programming for quite some time now, but until now I never understood why some programmers prefer
CONSTANT == var over var == CONSTANT
It’s to avoid a common C coding mistake of using = instead of ==. If you use the former form, and you inadvertently use = instead of ==, the compiler will catch your mistake because you’d be trying to assign a value to a constant.
I never really needed this convention because I have always been careful with my ==’s. One of the earliest C lessons I’ve learned. Still, it’s helpful to understand why some veterans prefer one form over the other.
CS193P Study Group: Session 2
Posted by rad in Programming, iPhone on February 19, 2010
Session 2 was conducted on the same venue as, and right after the PhRUG meetup.
Attendees:
topher
rad
eumir
buddy
tin
nico
There were two new attendees, tin and nico, who promised to catch up with the previous assignments.
We discussed memory management. The following questions were raised:
When should you call release on an object?
When you’re the one who did the alloc for the object.
When should you not call release?
When you did not do the alloc for the object.
Why bother with alloc and init at all, when, for example, you can use class methods that do it for you?
For example, why use:
NSString *my_string = [[NSString alloc] initWithFormat:@"format"];
when you can instead the format below?
NSString *my_string = [NSString stringWithFormat:@"format"];
Answer: The stringWithFormat call returns an autoreleased object. On the Mac OS X desktop, there’re practically no difference. On the iPhone, you want to limit the number of objects in the autorelease pool and use alloc/init most of the time so that you can be explicit (and optimize) on when you call release.
As before, let’s try to do Week 3 in one week. That means lectures 5 (Views, Animation, OpenGL) and 6 (View Controllers), and assignment 3 (HelloPoly II). Let’s aim to view the lectures and finish the assignment by next week and have a meetup Thursday next week, February 25.
For those that are catching up and still working on previous assignments, feel free to post questions about them, both on the forum and on meetups.
Free Cocos2D course
Posted by rad in Game Development, Programming, iPhone on February 11, 2010
The folks at web-geeks.com have organized a free class for Cocos2d and iPhone SDK 3.1.2:
http://web-geeks.com/uncategorized/cocos2d-course/
It starts on Feb.15. Even if you don’t know anything about Objective-C and Cocoa, you still have some time to cram. You can actually get by with what you’ll learn from the first three chapters of this book: Beginning iPhone Development: Exploring the iPhone SDK.
See you in the class!
Er, the class is virtual, so see you in the class forum instead.
CS193P Study Group: Session 1
Posted by rad in Programming, iPhone on February 5, 2010
We had our first session last night, February 4. Johann of Sagada Solutions was kind enough to host the meet-up.
Attendees:
paul
topher
rad
johann
eumir
buddy (cakey)
We skipped discussion of assginment 1A as it was really very simple and no one had problems with it.
Assignment 1B has four sections, so we took turns in discussing our solutions. Paul discussed section 1, Topher section 2, Rad section 3 and Eumir section 4.
Topher mentioned some confusion in creating the project under XCode 3.2/Snow Leopard. The screenshot provided by the handout was for XCode 3.1/Leopard. If you’re on XCode 3.2/SL, see the screenshot below on how the New Project dialog should look like.

Everyone was excited and wanted to try a bit faster pace. Tentatively, the next meetup is on Thursday, February 11. It will cover Lectures 3-4 and assignments 2A and 2B. We’ll check our progress over the weekend, and if this pace doesn’t seem workable, people should cry chicken as early as Monday, February 8.
Lastly, the off-topic discussions were also productive. Here are the links to the tools mentioned in passing during last night’s meetup:
Topher’s framework of choice for building iPhone apps:
http://github.com/blog/389-three20-iphone-ui-goodness
Rad’s framework of choice for building iPhone games:
http://www.cocos2d-iphone.org/
Rad’s framework of choice for Flash games:
http://flixel.org/
Interesting paper prototyping tools:
http://apress.com/book/view/9781430228233
http://www.appsketchbook.com/
The CS193P Study Group is starting next week
Posted by rad in Programming, iPhone on January 23, 2010
The CS193P study group is starting. Some changes in the mechanics:
- The study group will move at half the pace of the CS193P class. This means two lectures and 1-2 assignments every two weeks. There will be one meetup every week.
Week 1 starts on January 25, 2010. Everyone views the lectures and works on the assignments on her own. There will be a meetup on February 4 to discuss concepts and assignment solutions.
CS193P Study Group
Posted by rad in Programming, iPhone on January 16, 2010
I’m organizing a iPhone programming study group, based around the online materials available for Stanford CS193P (see my previous blog post).
The mechanics are still being ironed out, but here’s what I’m envisioning:
- The study group will move at the same pace as the CS193P class. This means two one-hour lectures a week, and one assignment a week.
- Each participant will view the lecture videos on her own
- Each participant will work on the assignments on her own
- There will be an optional once-a-week meet-up to work on assignments together. Everyone still work on the assignment solution individually – the assignments have been designed that way – but the meet-up is an opportunity to have a high-bandwidth discussion on difficult concepts.
- There will be once-a-week meet-ups to “submit” assignments and discuss solutions.
The meet-ups will from 8pm to 9pm and will be held in the Ortigas office of Sagada Solutions.
If you’re interested in joining the group, please join this Google group.