Skip to content

Instantly share code, notes, and snippets.

@buunguyen
Created June 10, 2012 20:23
Show Gist options
  • Save buunguyen/2907209 to your computer and use it in GitHub Desktop.
Save buunguyen/2907209 to your computer and use it in GitHub Desktop.
member_missing in Bike
var obj = {
member_missing: func(name) {
return "Member: {0}".with(name);
}
};
println(obj.notExist); # Member: notExist
println(obj.has_member('notExist')); # False
obj = {
member_missing: func(name) {
if (name == "add") {
return func(a, b) { a + b };
}
}
};
println(obj.add(1, 2)); # 3
obj = {
member_missing: func(name) {
if (name == "cache") {
return this.cache = func() {};
}
}
};
obj.cache();
println(obj.has_member('cache')); # True
var db = {
member_missing: func(name) {
if (name.starts('find')) {
return db[name] #! cache it !# = func(obj) {
var sql = 'SELECT * FROM {0}'.with(name.sub(4).upper());
obj.members(false, true).each_with_index(func(name, index) {
sql += (index == 0 ? ' WHERE ' : ' AND ') +
name.upper() +
(obj[name] is Bike.String ? '' : '=') +
obj[name]
});
println('Executing...{0}{1}', NL, sql);
return [#! Suppose I'm a product array, yay! !#];
};
}
}
};
# SELECT * FROM PRODUCTS WHERE CATEGORYID=1 AND PRICE>1000
println(db.findProducts({categoryId: 1, price: '>1000'}));
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment