Skip to content

Instantly share code, notes, and snippets.

@jed
Created April 28, 2010 22:29
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 3 You must be signed in to fork a gist
  • Save jed/382827 to your computer and use it in GitHub Desktop.
Save jed/382827 to your computer and use it in GitHub Desktop.
// this is an example of what the first pass at native (fab) templates will look like:
with ( require( "fab" ) ) fab
( listen, 0xFAB )
( /\// )
( /1/ )
( "This is a template with no variables: a unary app" )
( /2/ )
( "This is a template with {{1}} variable: a binary app." )
( "one" )
( /3/ )
( "This is a template with {{1}} variables: a {{2}} app." )
( "two" )
( "ternary" )
( /4/ )
( "You can even {{1}} them!" )
( "{{1}} and {{2}}" )
( "mix" )
( "match" )
( "Any feedback appreciated: http://twitter.com/{{1}}" )
( "jedschmidt" )
( 404 );
@isaacs
Copy link

isaacs commented Apr 28, 2010

why the with?

@jed
Copy link
Author

jed commented Apr 29, 2010

the (fab) function acts as a namespace for all built-in apps, and the with just makes them more accessible. only useful for fab.listen in this case, tho.

@isaacs
Copy link

isaacs commented Apr 29, 2010

Yeah... it seems like asking for trouble. It'd be better to do something like this: http://gist.github.com/382936

With is like a disgruntled employee that makes everyone else worse at their jobs.

@jed
Copy link
Author

jed commented Apr 29, 2010

yeah, since in this case it's only exposed at define-time and not run-time, i'm okay with it. once you start inlining functions tho, all bets are off.

@isaacs
Copy link

isaacs commented Apr 29, 2010

The issue is that if you have functions with variables in that block, you'll find that they significantly slow down. with(){} even makes it slower to read local variables. It's not as deadly as eval, but twice as rowdy.

@jed
Copy link
Author

jed commented Apr 29, 2010

that's my point. if you have any functions in there, i would stop using with entirely.

but i think it's fine here, and actually think that with is a good thing; if it encourages you to keep your functions separately, and therefore more reusable, all the better.

(i'm anti-with otherwise, for sure.)

@jed
Copy link
Author

jed commented Apr 29, 2010

maybe i should make a t-shirt:

i'm with (isaacs)

@isaacs
Copy link

isaacs commented Apr 29, 2010

I don't think that making functions slow will be enough to convince people not to use it. They'll just decide that (fab) is slow, and whine about it.

That shirt idea is AWESOME.

@jed
Copy link
Author

jed commented Apr 29, 2010

it's possible, but the good news is that like most overly-indented code, writing inline functions in (fab) gets awkward really fast. hopefully that'll be enough of a deterrent.

with ( isaacs ) i.am(); is probably better tho.

@isaacs
Copy link

isaacs commented Apr 29, 2010

hmm...

Wouldn't that shirt just say that I'm with myself?

Which I guess is true...

@subtleGradient
Copy link

This looks like BS to me. BuildSugar that is. My crazy template experiment.
I'm still not exactly sure if this code style is horrifying or fabulous.

Code: https://gist.github.com/278016/5f3ad4785929905871c4d87826c32bd3f8cff064#file_build_sugar.usage.js
Demo: http://www.jsfiddle.net/c3nxS/1/

@tlrobinson
Copy link

What if you want a template with more than 2 variables?

@jed
Copy link
Author

jed commented May 4, 2010

the template app actually creates an n-ary app, where n = the highest variable number + 1.

@felixge
Copy link

felixge commented May 7, 2010

I'm with (isaacs) too: No with please!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment