From bb6eb09884790297f2157c6f5579aab70ea513ff Mon Sep 17 00:00:00 2001 From: Sami Samhuri Date: Sun, 10 Apr 2011 19:04:39 -0700 Subject: [PATCH] first --- AppController.j | 117 ++++++++++++++++++++++++++++++++++++++++++ Info.plist | 12 +++++ Jakefile | 93 +++++++++++++++++++++++++++++++++ Resources/spinner.gif | Bin 0 -> 1849 bytes index-debug.html | 104 +++++++++++++++++++++++++++++++++++++ index.html | 79 ++++++++++++++++++++++++++++ main.j | 18 +++++++ 7 files changed, 423 insertions(+) create mode 100644 AppController.j create mode 100644 Info.plist create mode 100644 Jakefile create mode 100644 Resources/spinner.gif create mode 100644 index-debug.html create mode 100644 index.html create mode 100644 main.j diff --git a/AppController.j b/AppController.j new file mode 100644 index 0000000..b93dd94 --- /dev/null +++ b/AppController.j @@ -0,0 +1,117 @@ +/* + * AppController.j + * CappuccinoIssue725 + * + * Created by You on June 16, 2010. + * Copyright 2010, Your Company All rights reserved. + */ + +@import + +CPLogRegister(CPLogConsole); + +@implementation Node : CPObject +{ + CPString title @accessors; + CPArray children @accessors; +} +- (id) initWithTitle: (CPString)aTitle children: someChildren +{ + self = [super init]; + if (self) { + title = aTitle; + children = someChildren; + } + return self; +} +@end + + +@implementation AppController : CPObject +{ + CPOutlineView ov; + CPNumber selectedRow; +} + +- (void)applicationDidFinishLaunching:(CPNotification)aNotification +{ + var theWindow = [[CPWindow alloc] initWithContentRect:CGRectMakeZero() styleMask:CPBorderlessBridgeWindowMask], + contentView = [theWindow contentView]; + + ov = [[CPOutlineView alloc] initWithFrame: CGRectMake(0, 0, 300, 800)]; + [ov setDelegate: self]; + [ov setDataSource: self]; + [ov setAutoresizingMask: CPViewHeightSizable]; + + var column = [[CPTableColumn alloc] initWithIdentifier: @"Title"]; + [ov addTableColumn: column]; + [ov setOutlineTableColumn: column]; + + [contentView addSubview:ov]; + + + [theWindow orderFront:self]; + + // Uncomment the following line to turn on the standard menu bar. + //[CPMenu setMenuBarVisible:YES]; +} + +- (id) outlineView: (CPOutlineView)_ child: (int)n ofItem: (id)item +{ + if (item) return [item children][n]; + + var children = [], + i = 1; + for (; i < 6; ++i) + [children addObject: [[Node alloc] initWithTitle: 'Child #' + i children: []]]; + return [[Node alloc] initWithTitle: 'Item #' + (n+1) children: children]; +} + +- (BOOL) outlineView: (CPOutlineView)_ isItemExpandable: (id)item +{ + return item === nil || [[item children] count] > 0; +} + +- (int) outlineView: (CPOutlineView)_ numberOfChildrenOfItem: (id)item +{ + return item ? [[item children] count] : 3; +} + +- (id) outlineView: (CPOutlineView)_ objectValueForTableColumn: (CPTableViewColumn)column byItem: (id)item +{ + return [item title]; +} + +- (void) outlineViewItemWillExpand: (CPNotification)aNotification +{ + if ([ov rowForItem: item] < [ov selectedRow]) { + var item = [[aNotification userInfo] objectForKey: @"CPObject"]; + selectedRow += [[item children] count]; + } +} + +- (void) outlineViewItemDidExpand: (CPNotification)aNotification +{ + if (selectedRow !== [ov selectedRow]) + [ov selectRowIndexes: [CPIndexSet indexSetWithIndex: selectedRow] byExtendingSelection: NO]; +} + +- (void) outlineViewItemWillCollapse: (CPNotification)aNotification +{ + if ([ov rowForItem: item] < [ov selectedRow]) { + var item = [[aNotification userInfo] objectForKey: @"CPObject"]; + selectedRow -= [[item children] count]; + } +} + +- (void) outlineViewItemDidCollapse: (CPNotification)aNotification +{ + [ov selectRowIndexes: [CPIndexSet indexSetWithIndex: selectedRow] byExtendingSelection: NO]; +} + +- (void) outlineViewSelectionDidChange: (CPNotification)aNotification +{ + selectedRow = [ov selectedRow]; +} + +@end diff --git a/Info.plist b/Info.plist new file mode 100644 index 0000000..3a53d0e --- /dev/null +++ b/Info.plist @@ -0,0 +1,12 @@ + + + + + CPApplicationDelegateClass + AppController + CPBundleName + CappuccinoIssue725 + CPPrincipalClass + CPApplication + + diff --git a/Jakefile b/Jakefile new file mode 100644 index 0000000..1f297b2 --- /dev/null +++ b/Jakefile @@ -0,0 +1,93 @@ +/* + * Jakefile + * CappuccinoIssue725 + * + * Created by You on June 16, 2010. + * Copyright 2010, Your Company All rights reserved. + */ + +var ENV = require("system").env, + FILE = require("file"), + JAKE = require("jake"), + task = JAKE.task, + FileList = JAKE.FileList, + app = require("cappuccino/jake").app, + configuration = ENV["CONFIG"] || ENV["CONFIGURATION"] || ENV["c"] || "Debug", + OS = require("os"); + +app ("CappuccinoIssue725", function(task) +{ + task.setBuildIntermediatesPath(FILE.join("Build", "CappuccinoIssue725.build", configuration)); + task.setBuildPath(FILE.join("Build", configuration)); + + task.setProductName("CappuccinoIssue725"); + task.setIdentifier("com.yourcompany.CappuccinoIssue725"); + task.setVersion("1.0"); + task.setAuthor("Your Company"); + task.setEmail("feedback @nospam@ yourcompany.com"); + task.setSummary("CappuccinoIssue725"); + task.setSources((new FileList("**/*.j")).exclude(FILE.join("Build", "**"))); + task.setResources(new FileList("Resources/**")); + task.setIndexFilePath("index.html"); + task.setInfoPlistPath("Info.plist"); + + if (configuration === "Debug") + task.setCompilerFlags("-DDEBUG -g"); + else + task.setCompilerFlags("-O"); +}); + +task ("default", ["CappuccinoIssue725"], function() +{ + printResults(configuration); +}); + +task ("build", ["default"]); + +task ("debug", function() +{ + ENV["CONFIGURATION"] = "Debug"; + JAKE.subjake(["."], "build", ENV); +}); + +task ("release", function() +{ + ENV["CONFIGURATION"] = "Release"; + JAKE.subjake(["."], "build", ENV); +}); + +task ("run", ["debug"], function() +{ + OS.system(["open", FILE.join("Build", "Debug", "CappuccinoIssue725", "index.html")]); +}); + +task ("run-release", ["release"], function() +{ + OS.system(["open", FILE.join("Build", "Release", "CappuccinoIssue725", "index.html")]); +}); + +task ("deploy", ["release"], function() +{ + FILE.mkdirs(FILE.join("Build", "Deployment", "CappuccinoIssue725")); + OS.system(["press", "-f", FILE.join("Build", "Release", "CappuccinoIssue725"), FILE.join("Build", "Deployment", "CappuccinoIssue725")]); + printResults("Deployment") +}); + +task ("desktop", ["release"], function() +{ + FILE.mkdirs(FILE.join("Build", "Desktop", "CappuccinoIssue725")); + require("cappuccino/nativehost").buildNativeHost(FILE.join("Build", "Release", "CappuccinoIssue725"), FILE.join("Build", "Desktop", "CappuccinoIssue725", "CappuccinoIssue725.app")); + printResults("Desktop") +}); + +task ("run-desktop", ["desktop"], function() +{ + OS.system([FILE.join("Build", "Desktop", "CappuccinoIssue725", "CappuccinoIssue725.app", "Contents", "MacOS", "NativeHost"), "-i"]); +}); + +function printResults(configuration) +{ + print("----------------------------"); + print(configuration+" app built at path: "+FILE.join("Build", configuration, "CappuccinoIssue725")); + print("----------------------------"); +} diff --git a/Resources/spinner.gif b/Resources/spinner.gif new file mode 100644 index 0000000000000000000000000000000000000000..06dbc2bc21dddcf0e09b566d5b211aee89570f52 GIT binary patch literal 1849 zcma*odr(tX9tZHtz31lM+(&Y`A`Ou`NeG&R#DrIfV%?hng21vs6v>ooRQQFbk7E_K!V( z{?5!fpZWgIZ%*d6t%i*j24bL}AZUJm9)h6R*;%L4IWse3G#VWaN1#$zSSXcBhlYlH zJ|D}n{r&w2f+Qp)SS*&n?*G4}{}!h?td_mjU6Kad-rW*QwWYCUk7d^e+sjpZAn6kT z5rM;`{~_}-wm+L@%+E;JphLm}C3WzQAQD0wBoY|rOTQX{(@pp-WAA8Iw0HKl|15j) zhGh(SFWu#5zUCw^T!}C~eC}~?{xG-r7ugQC>taC+|L^xr&a%{#cgUOZXIM&v?)k^2 z1i5%0!U00wq)r4vlAwXBA_m5J5WNeuBm-XJQ5pG4GD%vc|K){+TJ{AkHqN@SJKczX zU}QRd9n*_bf^h94)6Ctv{CUfz_;qs#RDuQ$DR%y1&5G-a6rhf*4Y zl+UOD1*GE{GQ7vv;c-tTIMkz0ovO>9j%b5hpa@a*CBJ#W!0@ndSwF|%hMkdFtXiU) z`BEp+yhkt8ZY>tg&uyH@%^%K4jDrbA;et&vnnzZ3z22@e6<27z2Vk13kb7OtISyxv z(XoO-LNQCZe3lfzc%*pNqU<9T+p~teThOEB+~e&U0mC|zS{Q)dJZ)!^1f7L(zg*L> z*vSW%?dR~@@0(}x6-V^A`~ImD;)NaBUnP8;RH=bS2@pk`wp>>8r&jGjmGPy%1BW}v zoPo}ca$~bze@efc3kapuEVW1!%teOZT3j2Tw5=hjiAf02d}7dL0oFC%@=RXp5Ow#% z@a>+AM|YWt$n&e`>sB-32gBcuTi>R>*|8@lp`y6thc7ydyqDsuUn~YzZf|{-R@-3y zL#wx{Ii}xxL_csiW*LBn0-A$>zp4WOmkf6=ilrjlW?-l9+bCd7|i?*b5NTmy<<6NZ0T8$SN@mwdC2f z6jqK=N@bS@!=YSj%>h0}*4p+%0HbTIrE$w7UMT6+AZZ&DAo*qZAAi(OtNbIfl#Dw^ zJWeiCp~zi#&t6x}m9)O^eR4HiLV3QA<<0>HZ8%$^lrSE94Wb}=+MM^!b>n#5&-JQR zkr-CEu9C;_F*7DqDisulV6Pmg$nFL0TPn%~*m^-`Z3^BgU(sNpnx%nW(!eV9A&FvI zHL3X3lw8Wji^6=8KbQDE-e%b?svdFxxdh$8r97@7$ojeI`6AL8Ob6QC$qh&>ZWVDX1F{0vJnT%%mE;GveKWR%C} zM&4d;Jf3s9|HAA)yVUPo`Aq;0do#)uHSXi5*QF*)x@MVVHr+cN)uMZ__F|&Ta#p8d z53TOKtce!PJUuie8UWol-S(`c2nH?UGqJP{!4RR4u$LCfn)q-hj0^f=h(VYy)T6eN zhRO!ja-aDBTcgeyP(8Ua4IdiOog^*CQa?R(cP#9AgL9`j>EX-6Yf1lzX(!~``M1XC zNmM<4<6d~wWZ$Xrk0K}UteTrq@LBBk#MsjkK;pbuVhe)NI7(7Pf(l?lxC7=1Z7Pzl zMbS;nV4NI5_N{1$P)&XC)huOGQ+h^zpYUZfb*1n6>!`#*b3y52LGmi+<4sY5jyD#- zw&$d}DTguLAfnRtjrM*JfqtHqUu6rQoU=g%1E9xk%;)TDm^2<8n-0IhTsQFaek)MY}>PK4;nBk=ow4pF>vzkO& gna%Org-kgQCf=+BeMi^RbuY;YE~rTjend;_cdi8t>i_@% literal 0 HcmV?d00001 diff --git a/index-debug.html b/index-debug.html new file mode 100644 index 0000000..9dfb956 --- /dev/null +++ b/index-debug.html @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + CappuccinoIssue725 + + + + + + + + + + + + + + +
+
+ + + +
+
+ + + diff --git a/index.html b/index.html new file mode 100644 index 0000000..7d08855 --- /dev/null +++ b/index.html @@ -0,0 +1,79 @@ + + + + + + + + + + + + + + + + CappuccinoIssue725 + + + + + + + + + + + + +
+
+ + + +
+
+ + + + diff --git a/main.j b/main.j new file mode 100644 index 0000000..a2e23cf --- /dev/null +++ b/main.j @@ -0,0 +1,18 @@ +/* + * AppController.j + * CappuccinoIssue725 + * + * Created by You on June 16, 2010. + * Copyright 2010, Your Company All rights reserved. + */ + +@import +@import + +@import "AppController.j" + + +function main(args, namedArgs) +{ + CPApplicationMain(args, namedArgs); +}