Initial import.
Initial.
This commit is contained in:
commit
0b4a7841f7
71 changed files with 11984 additions and 0 deletions
34
CIDGrowl-Info.plist
Normal file
34
CIDGrowl-Info.plist
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>LSUIElement</key>
|
||||||
|
<true/>
|
||||||
|
<key>CFBundleDevelopmentRegion</key>
|
||||||
|
<string>English</string>
|
||||||
|
<key>CFBundleExecutable</key>
|
||||||
|
<string>${EXECUTABLE_NAME}</string>
|
||||||
|
<key>CFBundleIconFile</key>
|
||||||
|
<string>CIDGrowlIcon.icns</string>
|
||||||
|
<key>CFBundleIdentifier</key>
|
||||||
|
<string>net.theamigan.${PRODUCT_NAME:rfc1034identifier}</string>
|
||||||
|
<key>CFBundleInfoDictionaryVersion</key>
|
||||||
|
<string>6.0</string>
|
||||||
|
<key>CFBundleName</key>
|
||||||
|
<string>${PRODUCT_NAME}</string>
|
||||||
|
<key>CFBundlePackageType</key>
|
||||||
|
<string>APPL</string>
|
||||||
|
<key>CFBundleSignature</key>
|
||||||
|
<string>????</string>
|
||||||
|
<key>CFBundleShortVersionString</key>
|
||||||
|
<string>0.1</string>
|
||||||
|
<key>LSMinimumSystemVersion</key>
|
||||||
|
<string>${MACOSX_DEPLOYMENT_TARGET}</string>
|
||||||
|
<key>CFBundleVersion</key>
|
||||||
|
<string>1</string>
|
||||||
|
<key>NSMainNibFile</key>
|
||||||
|
<string>MainMenu</string>
|
||||||
|
<key>NSPrincipalClass</key>
|
||||||
|
<string>NSApplication</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
1447
CIDGrowl.xcodeproj/dcp1990.mode1v3
Normal file
1447
CIDGrowl.xcodeproj/dcp1990.mode1v3
Normal file
File diff suppressed because it is too large
Load diff
342
CIDGrowl.xcodeproj/dcp1990.pbxuser
Normal file
342
CIDGrowl.xcodeproj/dcp1990.pbxuser
Normal file
|
@ -0,0 +1,342 @@
|
||||||
|
// !$*UTF8*$!
|
||||||
|
{
|
||||||
|
089C165DFE840E0CC02AAC07 /* English */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavIntBoundsRect = "{{0, 0}, {1171, 503}}";
|
||||||
|
sepNavSelRange = "{0, 0}";
|
||||||
|
sepNavVisRange = "{0, 45}";
|
||||||
|
sepNavWindowFrame = "{{268, 87}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
256AC3D80F4B6AC300CF3369 /* CIDGrowlAppDelegate.h */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavIntBoundsRect = "{{0, 0}, {1379, 416}}";
|
||||||
|
sepNavSelRange = "{169, 0}";
|
||||||
|
sepNavVisRange = "{0, 600}";
|
||||||
|
sepNavWindowFrame = "{{160, 96}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
256AC3D90F4B6AC300CF3369 /* CIDGrowlAppDelegate.m */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavIntBoundsRect = "{{0, 0}, {691, 3133}}";
|
||||||
|
sepNavSelRange = "{851, 0}";
|
||||||
|
sepNavVisRange = "{579, 749}";
|
||||||
|
sepNavWindowFrame = "{{209, 226}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
256AC3F00F4B6AF500CF3369 /* CIDGrowl_Prefix.pch */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavIntBoundsRect = "{{0, 0}, {628, 245}}";
|
||||||
|
sepNavSelRange = "{0, 0}";
|
||||||
|
sepNavVisRange = "{0, 147}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
29B97313FDCFA39411CA2CEA /* Project object */ = {
|
||||||
|
activeBuildConfigurationName = Release;
|
||||||
|
activeExecutable = A9316E9C1114C35F00AE4561 /* CIDGrowl */;
|
||||||
|
activeTarget = 8D1107260486CEB800E47090 /* CIDGrowl */;
|
||||||
|
addToTargets = (
|
||||||
|
8D1107260486CEB800E47090 /* CIDGrowl */,
|
||||||
|
);
|
||||||
|
breakpoints = (
|
||||||
|
);
|
||||||
|
codeSenseManager = A9316EA81114C36800AE4561 /* Code sense */;
|
||||||
|
executables = (
|
||||||
|
A9316E9C1114C35F00AE4561 /* CIDGrowl */,
|
||||||
|
);
|
||||||
|
perUserDictionary = {
|
||||||
|
PBXConfiguration.PBXFileTableDataSource3.PBXFileTableDataSource = {
|
||||||
|
PBXFileTableDataSourceColumnSortingDirectionKey = "-1";
|
||||||
|
PBXFileTableDataSourceColumnSortingKey = PBXFileDataSource_Filename_ColumnID;
|
||||||
|
PBXFileTableDataSourceColumnWidthsKey = (
|
||||||
|
20,
|
||||||
|
993,
|
||||||
|
20,
|
||||||
|
48,
|
||||||
|
43,
|
||||||
|
43,
|
||||||
|
20,
|
||||||
|
);
|
||||||
|
PBXFileTableDataSourceColumnsKey = (
|
||||||
|
PBXFileDataSource_FiletypeID,
|
||||||
|
PBXFileDataSource_Filename_ColumnID,
|
||||||
|
PBXFileDataSource_Built_ColumnID,
|
||||||
|
PBXFileDataSource_ObjectSize_ColumnID,
|
||||||
|
PBXFileDataSource_Errors_ColumnID,
|
||||||
|
PBXFileDataSource_Warnings_ColumnID,
|
||||||
|
PBXFileDataSource_Target_ColumnID,
|
||||||
|
);
|
||||||
|
};
|
||||||
|
PBXConfiguration.PBXTargetDataSource.PBXTargetDataSource = {
|
||||||
|
PBXFileTableDataSourceColumnSortingDirectionKey = "-1";
|
||||||
|
PBXFileTableDataSourceColumnSortingKey = PBXFileDataSource_Filename_ColumnID;
|
||||||
|
PBXFileTableDataSourceColumnWidthsKey = (
|
||||||
|
20,
|
||||||
|
953,
|
||||||
|
60,
|
||||||
|
20,
|
||||||
|
48,
|
||||||
|
43,
|
||||||
|
43,
|
||||||
|
);
|
||||||
|
PBXFileTableDataSourceColumnsKey = (
|
||||||
|
PBXFileDataSource_FiletypeID,
|
||||||
|
PBXFileDataSource_Filename_ColumnID,
|
||||||
|
PBXTargetDataSource_PrimaryAttribute,
|
||||||
|
PBXFileDataSource_Built_ColumnID,
|
||||||
|
PBXFileDataSource_ObjectSize_ColumnID,
|
||||||
|
PBXFileDataSource_Errors_ColumnID,
|
||||||
|
PBXFileDataSource_Warnings_ColumnID,
|
||||||
|
);
|
||||||
|
};
|
||||||
|
PBXPerProjectTemplateStateSaveDate = 342283250;
|
||||||
|
PBXWorkspaceStateSaveDate = 342283250;
|
||||||
|
};
|
||||||
|
perUserProjectItems = {
|
||||||
|
A9316F631114C96100AE4561 /* PBXTextBookmark */ = A9316F631114C96100AE4561 /* PBXTextBookmark */;
|
||||||
|
A93170381114DBAC00AE4561 /* PBXBookmark */ = A93170381114DBAC00AE4561 /* PBXBookmark */;
|
||||||
|
A93170391114DBAC00AE4561 /* PBXTextBookmark */ = A93170391114DBAC00AE4561 /* PBXTextBookmark */;
|
||||||
|
A93170DF1114E98100AE4561 /* PBXBookmark */ = A93170DF1114E98100AE4561 /* PBXBookmark */;
|
||||||
|
A93170ED1114E9D700AE4561 /* PBXBookmark */ = A93170ED1114E9D700AE4561 /* PBXBookmark */;
|
||||||
|
A93170EE1114E9D700AE4561 /* PBXBookmark */ = A93170EE1114E9D700AE4561 /* PBXBookmark */;
|
||||||
|
A93171001114EAA100AE4561 /* PBXTextBookmark */ = A93171001114EAA100AE4561 /* PBXTextBookmark */;
|
||||||
|
A93E61AB11F82BC20066EB15 /* PBXTextBookmark */ = A93E61AB11F82BC20066EB15 /* PBXTextBookmark */;
|
||||||
|
A93E61E711F82CF20066EB15 /* PBXBookmark */ = A93E61E711F82CF20066EB15 /* PBXBookmark */;
|
||||||
|
A93E621011F82E0A0066EB15 /* PBXTextBookmark */ = A93E621011F82E0A0066EB15 /* PBXTextBookmark */;
|
||||||
|
A93E621111F82E0A0066EB15 /* PBXTextBookmark */ = A93E621111F82E0A0066EB15 /* PBXTextBookmark */;
|
||||||
|
A976839D112487AF00A3F369 /* PlistBookmark */ = A976839D112487AF00A3F369 /* PlistBookmark */;
|
||||||
|
A9E83795111A9E4C00D217B0 /* PBXTextBookmark */ = A9E83795111A9E4C00D217B0 /* PBXTextBookmark */;
|
||||||
|
A9F852881466D40F00337FFD /* PBXTextBookmark */ = A9F852881466D40F00337FFD /* PBXTextBookmark */;
|
||||||
|
A9F852891466D40F00337FFD /* PBXTextBookmark */ = A9F852891466D40F00337FFD /* PBXTextBookmark */;
|
||||||
|
};
|
||||||
|
sourceControlManager = A9316EA71114C36800AE4561 /* Source Control */;
|
||||||
|
userBuildSettings = {
|
||||||
|
};
|
||||||
|
};
|
||||||
|
29B97316FDCFA39411CA2CEA /* main.m */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavIntBoundsRect = "{{0, 0}, {1080, 427}}";
|
||||||
|
sepNavSelRange = "{0, 0}";
|
||||||
|
sepNavVisRange = "{0, 251}";
|
||||||
|
sepNavWindowFrame = "{{15, 318}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
8D1107260486CEB800E47090 /* CIDGrowl */ = {
|
||||||
|
activeExec = 0;
|
||||||
|
executables = (
|
||||||
|
A9316E9C1114C35F00AE4561 /* CIDGrowl */,
|
||||||
|
);
|
||||||
|
};
|
||||||
|
8D1107310486CEB800E47090 /* CIDGrowl-Info.plist */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavWindowFrame = "{{199, 150}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A9316E9C1114C35F00AE4561 /* CIDGrowl */ = {
|
||||||
|
isa = PBXExecutable;
|
||||||
|
activeArgIndices = (
|
||||||
|
);
|
||||||
|
argumentStrings = (
|
||||||
|
);
|
||||||
|
autoAttachOnCrash = 1;
|
||||||
|
breakpointsEnabled = 1;
|
||||||
|
configStateDict = {
|
||||||
|
};
|
||||||
|
customDataFormattersEnabled = 1;
|
||||||
|
dataTipCustomDataFormattersEnabled = 1;
|
||||||
|
dataTipShowTypeColumn = 1;
|
||||||
|
dataTipSortType = 0;
|
||||||
|
debuggerPlugin = GDBDebugging;
|
||||||
|
disassemblyDisplayState = 0;
|
||||||
|
dylibVariantSuffix = "";
|
||||||
|
enableDebugStr = 1;
|
||||||
|
environmentEntries = (
|
||||||
|
);
|
||||||
|
executableSystemSymbolLevel = 0;
|
||||||
|
executableUserSymbolLevel = 0;
|
||||||
|
libgmallocEnabled = 0;
|
||||||
|
name = CIDGrowl;
|
||||||
|
savedGlobals = {
|
||||||
|
};
|
||||||
|
showTypeColumn = 0;
|
||||||
|
sourceDirectories = (
|
||||||
|
);
|
||||||
|
variableFormatDictionary = {
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A9316EA71114C36800AE4561 /* Source Control */ = {
|
||||||
|
isa = PBXSourceControlManager;
|
||||||
|
fallbackIsa = XCSourceControlManager;
|
||||||
|
isSCMEnabled = 0;
|
||||||
|
scmConfiguration = {
|
||||||
|
repositoryNamesForRoots = {
|
||||||
|
"" = "";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A9316EA81114C36800AE4561 /* Code sense */ = {
|
||||||
|
isa = PBXCodeSenseManager;
|
||||||
|
indexTemplatePath = "";
|
||||||
|
};
|
||||||
|
A9316EB71114C45100AE4561 /* Growl Registration Ticket.growlRegDict */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavIntBoundsRect = "{{0, 0}, {1171, 513}}";
|
||||||
|
sepNavSelRange = "{445, 0}";
|
||||||
|
sepNavVisRange = "{0, 486}";
|
||||||
|
sepNavWindowFrame = "{{61, 276}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A9316F631114C96100AE4561 /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = 256AC3F00F4B6AF500CF3369 /* CIDGrowl_Prefix.pch */;
|
||||||
|
name = "CIDGrowl_Prefix.pch: 1";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 0;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 147;
|
||||||
|
vrLoc = 0;
|
||||||
|
};
|
||||||
|
A93170001114D40700AE4561 /* menuic.png */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavWindowFrame = "{{222, 129}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A93170381114DBAC00AE4561 /* PBXBookmark */ = {
|
||||||
|
isa = PBXBookmark;
|
||||||
|
fRef = A93170281114DADB00AE4561 /* menu22.tif */;
|
||||||
|
};
|
||||||
|
A93170391114DBAC00AE4561 /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = 29B97316FDCFA39411CA2CEA /* main.m */;
|
||||||
|
name = "main.m: 1";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 0;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 251;
|
||||||
|
vrLoc = 0;
|
||||||
|
};
|
||||||
|
A93170401114DD0700AE4561 /* menuic.png */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavWindowFrame = "{{222, 129}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A93170971114E48000AE4561 /* bigicon.png */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavWindowFrame = "{{15, 318}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A93170991114E4BB00AE4561 /* CIDGrowlIcon.icns */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavWindowFrame = "{{291, 66}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A93170CB1114E7CB00AE4561 /* growlicon.tif */ = {
|
||||||
|
uiCtxt = {
|
||||||
|
sepNavWindowFrame = "{{38, 297}, {1139, 555}}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
A93170DF1114E98100AE4561 /* PBXBookmark */ = {
|
||||||
|
isa = PBXBookmark;
|
||||||
|
fRef = A93170CB1114E7CB00AE4561 /* growlicon.tif */;
|
||||||
|
};
|
||||||
|
A93170ED1114E9D700AE4561 /* PBXBookmark */ = {
|
||||||
|
isa = PBXBookmark;
|
||||||
|
fRef = A93170971114E48000AE4561 /* bigicon.png */;
|
||||||
|
};
|
||||||
|
A93170EE1114E9D700AE4561 /* PBXBookmark */ = {
|
||||||
|
isa = PBXBookmark;
|
||||||
|
fRef = A93170991114E4BB00AE4561 /* CIDGrowlIcon.icns */;
|
||||||
|
};
|
||||||
|
A93171001114EAA100AE4561 /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = A9316EB71114C45100AE4561 /* Growl Registration Ticket.growlRegDict */;
|
||||||
|
name = "Growl Registration Ticket.growlRegDict: 17";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 445;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 486;
|
||||||
|
vrLoc = 0;
|
||||||
|
};
|
||||||
|
A93E61AB11F82BC20066EB15 /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = 256AC3D80F4B6AC300CF3369 /* CIDGrowlAppDelegate.h */;
|
||||||
|
name = "CIDGrowlAppDelegate.h: 17";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 394;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 614;
|
||||||
|
vrLoc = 0;
|
||||||
|
};
|
||||||
|
A93E61E611F82CF20066EB15 /* CIDGrowlAppDelegate.m */ = {
|
||||||
|
isa = PBXFileReference;
|
||||||
|
lastKnownFileType = sourcecode.c.objc;
|
||||||
|
name = CIDGrowlAppDelegate.m;
|
||||||
|
path = /Users/dcp1990/Development/CIDGrowl/CIDGrowlAppDelegate.m;
|
||||||
|
sourceTree = "<absolute>";
|
||||||
|
};
|
||||||
|
A93E61E711F82CF20066EB15 /* PBXBookmark */ = {
|
||||||
|
isa = PBXBookmark;
|
||||||
|
fRef = A93E61E611F82CF20066EB15 /* CIDGrowlAppDelegate.m */;
|
||||||
|
};
|
||||||
|
A93E621011F82E0A0066EB15 /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = 256AC3D90F4B6AC300CF3369 /* CIDGrowlAppDelegate.m */;
|
||||||
|
name = "CIDGrowlAppDelegate.m: 106";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 2514;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 1088;
|
||||||
|
vrLoc = 2413;
|
||||||
|
};
|
||||||
|
A93E621111F82E0A0066EB15 /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = 256AC3D90F4B6AC300CF3369 /* CIDGrowlAppDelegate.m */;
|
||||||
|
name = "CIDGrowlAppDelegate.m: 42";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 851;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 714;
|
||||||
|
vrLoc = 579;
|
||||||
|
};
|
||||||
|
A976839D112487AF00A3F369 /* PlistBookmark */ = {
|
||||||
|
isa = PlistBookmark;
|
||||||
|
fRef = 8D1107310486CEB800E47090 /* CIDGrowl-Info.plist */;
|
||||||
|
fallbackIsa = PBXBookmark;
|
||||||
|
isK = 0;
|
||||||
|
kPath = (
|
||||||
|
);
|
||||||
|
name = "/Users/dcp1990/Development/CIDGrowl/CIDGrowl-Info.plist";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 9223372036854775808;
|
||||||
|
};
|
||||||
|
A9E83795111A9E4C00D217B0 /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = 089C165DFE840E0CC02AAC07 /* English */;
|
||||||
|
name = "InfoPlist.strings: 1";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 0;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 45;
|
||||||
|
vrLoc = 0;
|
||||||
|
};
|
||||||
|
A9F852881466D40F00337FFD /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = 256AC3D90F4B6AC300CF3369 /* CIDGrowlAppDelegate.m */;
|
||||||
|
name = "CIDGrowlAppDelegate.m: 106";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 2514;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 1113;
|
||||||
|
vrLoc = 2391;
|
||||||
|
};
|
||||||
|
A9F852891466D40F00337FFD /* PBXTextBookmark */ = {
|
||||||
|
isa = PBXTextBookmark;
|
||||||
|
fRef = 256AC3D90F4B6AC300CF3369 /* CIDGrowlAppDelegate.m */;
|
||||||
|
name = "CIDGrowlAppDelegate.m: 42";
|
||||||
|
rLen = 0;
|
||||||
|
rLoc = 851;
|
||||||
|
rType = 0;
|
||||||
|
vrLen = 749;
|
||||||
|
vrLoc = 579;
|
||||||
|
};
|
||||||
|
}
|
340
CIDGrowl.xcodeproj/project.pbxproj
Normal file
340
CIDGrowl.xcodeproj/project.pbxproj
Normal file
|
@ -0,0 +1,340 @@
|
||||||
|
// !$*UTF8*$!
|
||||||
|
{
|
||||||
|
archiveVersion = 1;
|
||||||
|
classes = {
|
||||||
|
};
|
||||||
|
objectVersion = 45;
|
||||||
|
objects = {
|
||||||
|
|
||||||
|
/* Begin PBXBuildFile section */
|
||||||
|
1DDD58160DA1D0A300B32029 /* MainMenu.xib in Resources */ = {isa = PBXBuildFile; fileRef = 1DDD58140DA1D0A300B32029 /* MainMenu.xib */; };
|
||||||
|
256AC3DA0F4B6AC300CF3369 /* CIDGrowlAppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 256AC3D90F4B6AC300CF3369 /* CIDGrowlAppDelegate.m */; };
|
||||||
|
8D11072B0486CEB800E47090 /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 089C165CFE840E0CC02AAC07 /* InfoPlist.strings */; };
|
||||||
|
8D11072D0486CEB800E47090 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 29B97316FDCFA39411CA2CEA /* main.m */; settings = {ATTRIBUTES = (); }; };
|
||||||
|
8D11072F0486CEB800E47090 /* Cocoa.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1058C7A1FEA54F0111CA2CBB /* Cocoa.framework */; };
|
||||||
|
A9316F021114C5F100AE4561 /* Growl Registration Ticket.growlRegDict in Resources */ = {isa = PBXBuildFile; fileRef = A9316EB71114C45100AE4561 /* Growl Registration Ticket.growlRegDict */; };
|
||||||
|
A93170011114D40700AE4561 /* menuic.png in Resources */ = {isa = PBXBuildFile; fileRef = A93170001114D40700AE4561 /* menuic.png */; };
|
||||||
|
A93170291114DADB00AE4561 /* menu22.tif in Resources */ = {isa = PBXBuildFile; fileRef = A93170281114DADB00AE4561 /* menu22.tif */; };
|
||||||
|
A93170981114E48000AE4561 /* bigicon.png in Resources */ = {isa = PBXBuildFile; fileRef = A93170971114E48000AE4561 /* bigicon.png */; };
|
||||||
|
A931709A1114E4BB00AE4561 /* CIDGrowlIcon.icns in Resources */ = {isa = PBXBuildFile; fileRef = A93170991114E4BB00AE4561 /* CIDGrowlIcon.icns */; };
|
||||||
|
A93170CC1114E7CB00AE4561 /* growlicon.tif in Resources */ = {isa = PBXBuildFile; fileRef = A93170CB1114E7CB00AE4561 /* growlicon.tif */; };
|
||||||
|
A93E61C311F82CA20066EB15 /* Growl.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = A93E61C211F82CA20066EB15 /* Growl.framework */; };
|
||||||
|
A93E61C611F82CA80066EB15 /* Growl.framework in CopyFiles */ = {isa = PBXBuildFile; fileRef = A93E61C211F82CA20066EB15 /* Growl.framework */; };
|
||||||
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
|
/* Begin PBXCopyFilesBuildPhase section */
|
||||||
|
A9316F101114C60200AE4561 /* CopyFiles */ = {
|
||||||
|
isa = PBXCopyFilesBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
dstPath = "";
|
||||||
|
dstSubfolderSpec = 10;
|
||||||
|
files = (
|
||||||
|
A93E61C611F82CA80066EB15 /* Growl.framework in CopyFiles */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
/* End PBXCopyFilesBuildPhase section */
|
||||||
|
|
||||||
|
/* Begin PBXFileReference section */
|
||||||
|
089C165DFE840E0CC02AAC07 /* English */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.strings; name = English; path = English.lproj/InfoPlist.strings; sourceTree = "<group>"; };
|
||||||
|
1058C7A1FEA54F0111CA2CBB /* Cocoa.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Cocoa.framework; path = /System/Library/Frameworks/Cocoa.framework; sourceTree = "<absolute>"; };
|
||||||
|
13E42FB307B3F0F600E4EEF1 /* CoreData.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreData.framework; path = /System/Library/Frameworks/CoreData.framework; sourceTree = "<absolute>"; };
|
||||||
|
1DDD58150DA1D0A300B32029 /* English */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = English; path = English.lproj/MainMenu.xib; sourceTree = "<group>"; };
|
||||||
|
256AC3D80F4B6AC300CF3369 /* CIDGrowlAppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CIDGrowlAppDelegate.h; sourceTree = "<group>"; };
|
||||||
|
256AC3D90F4B6AC300CF3369 /* CIDGrowlAppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = CIDGrowlAppDelegate.m; sourceTree = "<group>"; };
|
||||||
|
256AC3F00F4B6AF500CF3369 /* CIDGrowl_Prefix.pch */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CIDGrowl_Prefix.pch; sourceTree = "<group>"; };
|
||||||
|
29B97316FDCFA39411CA2CEA /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = main.m; sourceTree = "<group>"; };
|
||||||
|
29B97324FDCFA39411CA2CEA /* AppKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AppKit.framework; path = /System/Library/Frameworks/AppKit.framework; sourceTree = "<absolute>"; };
|
||||||
|
29B97325FDCFA39411CA2CEA /* Foundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Foundation.framework; path = /System/Library/Frameworks/Foundation.framework; sourceTree = "<absolute>"; };
|
||||||
|
8D1107310486CEB800E47090 /* CIDGrowl-Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = "CIDGrowl-Info.plist"; sourceTree = "<group>"; };
|
||||||
|
8D1107320486CEB800E47090 /* CIDGrowl.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = CIDGrowl.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
|
A9316EB71114C45100AE4561 /* Growl Registration Ticket.growlRegDict */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = "Growl Registration Ticket.growlRegDict"; sourceTree = "<group>"; };
|
||||||
|
A93170001114D40700AE4561 /* menuic.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = menuic.png; sourceTree = "<group>"; };
|
||||||
|
A93170281114DADB00AE4561 /* menu22.tif */ = {isa = PBXFileReference; lastKnownFileType = image.tiff; path = menu22.tif; sourceTree = "<group>"; };
|
||||||
|
A93170401114DD0700AE4561 /* menuic.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = menuic.png; sourceTree = "<group>"; };
|
||||||
|
A93170971114E48000AE4561 /* bigicon.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = bigicon.png; sourceTree = "<group>"; };
|
||||||
|
A93170991114E4BB00AE4561 /* CIDGrowlIcon.icns */ = {isa = PBXFileReference; lastKnownFileType = image.icns; path = CIDGrowlIcon.icns; sourceTree = "<group>"; };
|
||||||
|
A93170CB1114E7CB00AE4561 /* growlicon.tif */ = {isa = PBXFileReference; lastKnownFileType = image.tiff; path = growlicon.tif; sourceTree = "<group>"; };
|
||||||
|
A93E61C211F82CA20066EB15 /* Growl.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = Growl.framework; sourceTree = "<group>"; };
|
||||||
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
|
8D11072E0486CEB800E47090 /* Frameworks */ = {
|
||||||
|
isa = PBXFrameworksBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
8D11072F0486CEB800E47090 /* Cocoa.framework in Frameworks */,
|
||||||
|
A93E61C311F82CA20066EB15 /* Growl.framework in Frameworks */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
/* End PBXFrameworksBuildPhase section */
|
||||||
|
|
||||||
|
/* Begin PBXGroup section */
|
||||||
|
080E96DDFE201D6D7F000001 /* Classes */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
256AC3D80F4B6AC300CF3369 /* CIDGrowlAppDelegate.h */,
|
||||||
|
256AC3D90F4B6AC300CF3369 /* CIDGrowlAppDelegate.m */,
|
||||||
|
);
|
||||||
|
name = Classes;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
1058C7A0FEA54F0111CA2CBB /* Linked Frameworks */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
1058C7A1FEA54F0111CA2CBB /* Cocoa.framework */,
|
||||||
|
A93E61C211F82CA20066EB15 /* Growl.framework */,
|
||||||
|
);
|
||||||
|
name = "Linked Frameworks";
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
1058C7A2FEA54F0111CA2CBB /* Other Frameworks */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
29B97324FDCFA39411CA2CEA /* AppKit.framework */,
|
||||||
|
13E42FB307B3F0F600E4EEF1 /* CoreData.framework */,
|
||||||
|
29B97325FDCFA39411CA2CEA /* Foundation.framework */,
|
||||||
|
);
|
||||||
|
name = "Other Frameworks";
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
19C28FACFE9D520D11CA2CBB /* Products */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
8D1107320486CEB800E47090 /* CIDGrowl.app */,
|
||||||
|
);
|
||||||
|
name = Products;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
29B97314FDCFA39411CA2CEA /* CIDGrowl */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
A93170991114E4BB00AE4561 /* CIDGrowlIcon.icns */,
|
||||||
|
A93170971114E48000AE4561 /* bigicon.png */,
|
||||||
|
A93170401114DD0700AE4561 /* menuic.png */,
|
||||||
|
080E96DDFE201D6D7F000001 /* Classes */,
|
||||||
|
29B97315FDCFA39411CA2CEA /* Other Sources */,
|
||||||
|
29B97317FDCFA39411CA2CEA /* Resources */,
|
||||||
|
29B97323FDCFA39411CA2CEA /* Frameworks */,
|
||||||
|
19C28FACFE9D520D11CA2CBB /* Products */,
|
||||||
|
);
|
||||||
|
name = CIDGrowl;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
29B97315FDCFA39411CA2CEA /* Other Sources */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
256AC3F00F4B6AF500CF3369 /* CIDGrowl_Prefix.pch */,
|
||||||
|
29B97316FDCFA39411CA2CEA /* main.m */,
|
||||||
|
);
|
||||||
|
name = "Other Sources";
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
29B97317FDCFA39411CA2CEA /* Resources */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
A93170CB1114E7CB00AE4561 /* growlicon.tif */,
|
||||||
|
A93170281114DADB00AE4561 /* menu22.tif */,
|
||||||
|
A93170001114D40700AE4561 /* menuic.png */,
|
||||||
|
8D1107310486CEB800E47090 /* CIDGrowl-Info.plist */,
|
||||||
|
089C165CFE840E0CC02AAC07 /* InfoPlist.strings */,
|
||||||
|
1DDD58140DA1D0A300B32029 /* MainMenu.xib */,
|
||||||
|
A9316EB71114C45100AE4561 /* Growl Registration Ticket.growlRegDict */,
|
||||||
|
);
|
||||||
|
name = Resources;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
29B97323FDCFA39411CA2CEA /* Frameworks */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
1058C7A0FEA54F0111CA2CBB /* Linked Frameworks */,
|
||||||
|
1058C7A2FEA54F0111CA2CBB /* Other Frameworks */,
|
||||||
|
);
|
||||||
|
name = Frameworks;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
/* End PBXGroup section */
|
||||||
|
|
||||||
|
/* Begin PBXNativeTarget section */
|
||||||
|
8D1107260486CEB800E47090 /* CIDGrowl */ = {
|
||||||
|
isa = PBXNativeTarget;
|
||||||
|
buildConfigurationList = C01FCF4A08A954540054247B /* Build configuration list for PBXNativeTarget "CIDGrowl" */;
|
||||||
|
buildPhases = (
|
||||||
|
8D1107290486CEB800E47090 /* Resources */,
|
||||||
|
8D11072C0486CEB800E47090 /* Sources */,
|
||||||
|
8D11072E0486CEB800E47090 /* Frameworks */,
|
||||||
|
A9316F101114C60200AE4561 /* CopyFiles */,
|
||||||
|
);
|
||||||
|
buildRules = (
|
||||||
|
);
|
||||||
|
dependencies = (
|
||||||
|
);
|
||||||
|
name = CIDGrowl;
|
||||||
|
productInstallPath = "$(HOME)/Applications";
|
||||||
|
productName = CIDGrowl;
|
||||||
|
productReference = 8D1107320486CEB800E47090 /* CIDGrowl.app */;
|
||||||
|
productType = "com.apple.product-type.application";
|
||||||
|
};
|
||||||
|
/* End PBXNativeTarget section */
|
||||||
|
|
||||||
|
/* Begin PBXProject section */
|
||||||
|
29B97313FDCFA39411CA2CEA /* Project object */ = {
|
||||||
|
isa = PBXProject;
|
||||||
|
attributes = {
|
||||||
|
ORGANIZATIONNAME = theamigan.net;
|
||||||
|
};
|
||||||
|
buildConfigurationList = C01FCF4E08A954540054247B /* Build configuration list for PBXProject "CIDGrowl" */;
|
||||||
|
compatibilityVersion = "Xcode 3.1";
|
||||||
|
hasScannedForEncodings = 1;
|
||||||
|
mainGroup = 29B97314FDCFA39411CA2CEA /* CIDGrowl */;
|
||||||
|
projectDirPath = "";
|
||||||
|
projectRoot = "";
|
||||||
|
targets = (
|
||||||
|
8D1107260486CEB800E47090 /* CIDGrowl */,
|
||||||
|
);
|
||||||
|
};
|
||||||
|
/* End PBXProject section */
|
||||||
|
|
||||||
|
/* Begin PBXResourcesBuildPhase section */
|
||||||
|
8D1107290486CEB800E47090 /* Resources */ = {
|
||||||
|
isa = PBXResourcesBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
A9316F021114C5F100AE4561 /* Growl Registration Ticket.growlRegDict in Resources */,
|
||||||
|
8D11072B0486CEB800E47090 /* InfoPlist.strings in Resources */,
|
||||||
|
1DDD58160DA1D0A300B32029 /* MainMenu.xib in Resources */,
|
||||||
|
A93170011114D40700AE4561 /* menuic.png in Resources */,
|
||||||
|
A93170291114DADB00AE4561 /* menu22.tif in Resources */,
|
||||||
|
A93170981114E48000AE4561 /* bigicon.png in Resources */,
|
||||||
|
A931709A1114E4BB00AE4561 /* CIDGrowlIcon.icns in Resources */,
|
||||||
|
A93170CC1114E7CB00AE4561 /* growlicon.tif in Resources */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
/* End PBXResourcesBuildPhase section */
|
||||||
|
|
||||||
|
/* Begin PBXSourcesBuildPhase section */
|
||||||
|
8D11072C0486CEB800E47090 /* Sources */ = {
|
||||||
|
isa = PBXSourcesBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
8D11072D0486CEB800E47090 /* main.m in Sources */,
|
||||||
|
256AC3DA0F4B6AC300CF3369 /* CIDGrowlAppDelegate.m in Sources */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
/* End PBXSourcesBuildPhase section */
|
||||||
|
|
||||||
|
/* Begin PBXVariantGroup section */
|
||||||
|
089C165CFE840E0CC02AAC07 /* InfoPlist.strings */ = {
|
||||||
|
isa = PBXVariantGroup;
|
||||||
|
children = (
|
||||||
|
089C165DFE840E0CC02AAC07 /* English */,
|
||||||
|
);
|
||||||
|
name = InfoPlist.strings;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
1DDD58140DA1D0A300B32029 /* MainMenu.xib */ = {
|
||||||
|
isa = PBXVariantGroup;
|
||||||
|
children = (
|
||||||
|
1DDD58150DA1D0A300B32029 /* English */,
|
||||||
|
);
|
||||||
|
name = MainMenu.xib;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
/* End PBXVariantGroup section */
|
||||||
|
|
||||||
|
/* Begin XCBuildConfiguration section */
|
||||||
|
C01FCF4B08A954540054247B /* Debug */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||||
|
COPY_PHASE_STRIP = NO;
|
||||||
|
FRAMEWORK_SEARCH_PATHS = (
|
||||||
|
"$(inherited)",
|
||||||
|
"\"$(SRCROOT)/../../Desktop\"",
|
||||||
|
"\"$(SRCROOT)\"",
|
||||||
|
);
|
||||||
|
GCC_DYNAMIC_NO_PIC = NO;
|
||||||
|
GCC_ENABLE_FIX_AND_CONTINUE = YES;
|
||||||
|
GCC_MODEL_TUNING = G5;
|
||||||
|
GCC_OPTIMIZATION_LEVEL = 0;
|
||||||
|
GCC_PRECOMPILE_PREFIX_HEADER = YES;
|
||||||
|
GCC_PREFIX_HEADER = CIDGrowl_Prefix.pch;
|
||||||
|
INFOPLIST_FILE = "CIDGrowl-Info.plist";
|
||||||
|
INSTALL_PATH = "$(HOME)/Applications";
|
||||||
|
PRODUCT_NAME = CIDGrowl;
|
||||||
|
};
|
||||||
|
name = Debug;
|
||||||
|
};
|
||||||
|
C01FCF4C08A954540054247B /* Release */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||||
|
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
|
||||||
|
FRAMEWORK_SEARCH_PATHS = (
|
||||||
|
"$(inherited)",
|
||||||
|
"\"$(SRCROOT)/../../Desktop\"",
|
||||||
|
"\"$(SRCROOT)\"",
|
||||||
|
);
|
||||||
|
GCC_MODEL_TUNING = G5;
|
||||||
|
GCC_PRECOMPILE_PREFIX_HEADER = YES;
|
||||||
|
GCC_PREFIX_HEADER = CIDGrowl_Prefix.pch;
|
||||||
|
INFOPLIST_FILE = "CIDGrowl-Info.plist";
|
||||||
|
INSTALL_PATH = "$(HOME)/Applications";
|
||||||
|
PRODUCT_NAME = CIDGrowl;
|
||||||
|
};
|
||||||
|
name = Release;
|
||||||
|
};
|
||||||
|
C01FCF4F08A954540054247B /* Debug */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
ARCHS = "$(ARCHS_STANDARD_32_64_BIT)";
|
||||||
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
|
GCC_OPTIMIZATION_LEVEL = 0;
|
||||||
|
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
||||||
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
|
ONLY_ACTIVE_ARCH = YES;
|
||||||
|
PREBINDING = NO;
|
||||||
|
SDKROOT = macosx10.6;
|
||||||
|
};
|
||||||
|
name = Debug;
|
||||||
|
};
|
||||||
|
C01FCF5008A954540054247B /* Release */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
ARCHS = "$(ARCHS_STANDARD_32_64_BIT)";
|
||||||
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
|
GCC_WARN_ABOUT_RETURN_TYPE = YES;
|
||||||
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
|
PREBINDING = NO;
|
||||||
|
SDKROOT = macosx10.6;
|
||||||
|
};
|
||||||
|
name = Release;
|
||||||
|
};
|
||||||
|
/* End XCBuildConfiguration section */
|
||||||
|
|
||||||
|
/* Begin XCConfigurationList section */
|
||||||
|
C01FCF4A08A954540054247B /* Build configuration list for PBXNativeTarget "CIDGrowl" */ = {
|
||||||
|
isa = XCConfigurationList;
|
||||||
|
buildConfigurations = (
|
||||||
|
C01FCF4B08A954540054247B /* Debug */,
|
||||||
|
C01FCF4C08A954540054247B /* Release */,
|
||||||
|
);
|
||||||
|
defaultConfigurationIsVisible = 0;
|
||||||
|
defaultConfigurationName = Release;
|
||||||
|
};
|
||||||
|
C01FCF4E08A954540054247B /* Build configuration list for PBXProject "CIDGrowl" */ = {
|
||||||
|
isa = XCConfigurationList;
|
||||||
|
buildConfigurations = (
|
||||||
|
C01FCF4F08A954540054247B /* Debug */,
|
||||||
|
C01FCF5008A954540054247B /* Release */,
|
||||||
|
);
|
||||||
|
defaultConfigurationIsVisible = 0;
|
||||||
|
defaultConfigurationName = Release;
|
||||||
|
};
|
||||||
|
/* End XCConfigurationList section */
|
||||||
|
};
|
||||||
|
rootObject = 29B97313FDCFA39411CA2CEA /* Project object */;
|
||||||
|
}
|
31
CIDGrowlAppDelegate.h
Normal file
31
CIDGrowlAppDelegate.h
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
//
|
||||||
|
// CIDGrowlAppDelegate.h
|
||||||
|
// CIDGrowl
|
||||||
|
//
|
||||||
|
// Created by Dan Ponte on 1/30/10.
|
||||||
|
// Copyright 2010 __MyCompanyName__. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
#import <Cocoa/Cocoa.h>
|
||||||
|
#import <Growl/Growl.h>
|
||||||
|
|
||||||
|
@interface CIDGrowlAppDelegate : NSObject <GrowlApplicationBridgeDelegate> {
|
||||||
|
NSWindow *window;
|
||||||
|
IBOutlet NSMenu *statusMenu;
|
||||||
|
NSStatusItem * statusItem;
|
||||||
|
IBOutlet NSMenuItem *callCountItem;
|
||||||
|
//int numberOfCalls;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//-(void)setCallNum:(int)calls;
|
||||||
|
|
||||||
|
+(void)start_netloop:(id)param;
|
||||||
|
|
||||||
|
- (IBAction)openAboutPanel:(id)sender;
|
||||||
|
|
||||||
|
//-(void) growlIsReady;
|
||||||
|
@property (assign) IBOutlet NSWindow *window;
|
||||||
|
|
||||||
|
@end
|
222
CIDGrowlAppDelegate.m
Normal file
222
CIDGrowlAppDelegate.m
Normal file
|
@ -0,0 +1,222 @@
|
||||||
|
//
|
||||||
|
// CIDGrowlAppDelegate.m
|
||||||
|
// CIDGrowl
|
||||||
|
//
|
||||||
|
// Created by Dan Ponte on 1/30/10.
|
||||||
|
// Copyright 2010 __MyCompanyName__. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
#import "CIDGrowlAppDelegate.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <sys/select.h>
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
|
||||||
|
#define PORT 3890
|
||||||
|
#define BUFFERL 256
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@implementation CIDGrowlAppDelegate
|
||||||
|
|
||||||
|
|
||||||
|
@synthesize window;
|
||||||
|
|
||||||
|
- (IBAction)openAboutPanel:(id)sender
|
||||||
|
{
|
||||||
|
NSDictionary *options;
|
||||||
|
NSImage *img;
|
||||||
|
|
||||||
|
img = [NSImage imageNamed: @"Picture 1"];
|
||||||
|
options = [NSDictionary dictionaryWithObjectsAndKeys:
|
||||||
|
@"0.1", @"Version",
|
||||||
|
@"CIDGrowl", @"ApplicationName",
|
||||||
|
img, @"ApplicationIcon",
|
||||||
|
@"Copyright 2010 Dan Ponte", @"Copyright",
|
||||||
|
@"CIDGrowl v0.1", @"ApplicationVersion",
|
||||||
|
nil];
|
||||||
|
|
||||||
|
[[NSApplication sharedApplication] orderFrontStandardAboutPanelWithOptions:options];
|
||||||
|
}
|
||||||
|
|
||||||
|
struct sockaddr_in servsad;
|
||||||
|
char servaddr[256];
|
||||||
|
typedef struct cis
|
||||||
|
{
|
||||||
|
char *name;
|
||||||
|
char *number;
|
||||||
|
char *date;
|
||||||
|
char *time;
|
||||||
|
} cidinfo;
|
||||||
|
|
||||||
|
void
|
||||||
|
parseinfo (buffer, cifo)
|
||||||
|
char *buffer;
|
||||||
|
cidinfo *cifo;
|
||||||
|
{
|
||||||
|
char *bfrp;
|
||||||
|
char *origbuf;
|
||||||
|
origbuf = buffer;
|
||||||
|
bfrp = origbuf;
|
||||||
|
/* 9005:2010:0:WIRELESS CALL :401213123123 */
|
||||||
|
cifo->date = strsep (&bfrp, ":");
|
||||||
|
cifo->time = strsep (&bfrp, ":");
|
||||||
|
if(cifo->time == NULL) return;
|
||||||
|
strsep (&bfrp, ":");
|
||||||
|
cifo->name = strsep (&bfrp, ":");
|
||||||
|
cifo->number = bfrp;
|
||||||
|
}
|
||||||
|
|
||||||
|
void telluser(buf)
|
||||||
|
char *buf;
|
||||||
|
{
|
||||||
|
cidinfo cid;
|
||||||
|
char *ltx;
|
||||||
|
size_t lent;
|
||||||
|
NSString *ltns;
|
||||||
|
bzero(&cid, sizeof cid);
|
||||||
|
parseinfo (buf, &cid);
|
||||||
|
if(cid.name == NULL) return;
|
||||||
|
if(cid.name == NULL || cid.number == NULL) {return;}
|
||||||
|
lent = sizeof ("Name: \nNumber: \nDate: \nTime: \n ");
|
||||||
|
lent +=
|
||||||
|
sizeof (char) * (strlen (cid.name) + strlen (cid.number) +
|
||||||
|
strlen (cid.date) + strlen (cid.time));
|
||||||
|
ltx = (char *) malloc (lent);
|
||||||
|
memset (ltx, 0, lent);
|
||||||
|
snprintf (ltx, lent, "Name: %s\nNumber: %s",
|
||||||
|
cid.name, cid.number, cid.date, cid.time); /* XXX: Use NSString functions right off the bat */
|
||||||
|
ltns = [[NSString alloc] initWithCString:ltx encoding:NSMacOSRomanStringEncoding]; /* turn it into NSString because we are so fucking lazy about rewriting... */
|
||||||
|
[GrowlApplicationBridge notifyWithTitle:@"Phone Call"
|
||||||
|
description:ltns
|
||||||
|
notificationName:@"Phone Call"
|
||||||
|
iconData:nil
|
||||||
|
priority:0
|
||||||
|
isSticky:NO
|
||||||
|
clickContext:[NSDate date]];
|
||||||
|
[ltns autorelease];
|
||||||
|
free (ltx);
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
-(void)setCallNum: (int)calls
|
||||||
|
{
|
||||||
|
NSString *tstr;
|
||||||
|
if (calls)
|
||||||
|
numberOfCalls += calls;
|
||||||
|
else {
|
||||||
|
numberOfCalls = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
tstr = [[NSString alloc] initWithFormat:@"%d calls", numberOfCalls];
|
||||||
|
[callCountItem setTitle:tstr];
|
||||||
|
[tstr autorelease];
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
+(void)start_netloop: (id)param
|
||||||
|
{
|
||||||
|
int sockfd, nbytes;
|
||||||
|
unsigned int addr_len;
|
||||||
|
struct sockaddr_in ouraddr;
|
||||||
|
struct sockaddr_in* bcasaddr;
|
||||||
|
struct timeval tv;
|
||||||
|
NSAutoreleasePool *autoreleasepool = [[NSAutoreleasePool alloc] init];
|
||||||
|
bcasaddr = &servsad;
|
||||||
|
bzero(&servsad, sizeof servsad);
|
||||||
|
fd_set fds_read;
|
||||||
|
FD_ZERO(&fds_read);
|
||||||
|
char buffer[BUFFERL];
|
||||||
|
|
||||||
|
if((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) == -1) {
|
||||||
|
perror("sock");
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
ouraddr.sin_family = AF_INET;
|
||||||
|
ouraddr.sin_port = htons(PORT);
|
||||||
|
ouraddr.sin_addr.s_addr = INADDR_ANY;
|
||||||
|
memset(&(ouraddr.sin_zero), 0, 8);
|
||||||
|
if(bind(sockfd, (struct sockaddr*)&ouraddr, sizeof(struct sockaddr)) == -1) {
|
||||||
|
perror("bind");
|
||||||
|
exit(-2);
|
||||||
|
}
|
||||||
|
addr_len = sizeof(struct sockaddr);
|
||||||
|
while(1)
|
||||||
|
{
|
||||||
|
FD_ZERO(&fds_read);
|
||||||
|
FD_SET(sockfd, &fds_read);
|
||||||
|
tv.tv_sec = 3; tv.tv_usec = 0;
|
||||||
|
switch(select(sockfd + 1, &fds_read, NULL, NULL, NULL))
|
||||||
|
{
|
||||||
|
case -1:
|
||||||
|
perror("select");
|
||||||
|
goto doublebreak; /* the only case K&R ever recommends using a goto! */
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if(FD_ISSET(sockfd, &fds_read) != 0)
|
||||||
|
{
|
||||||
|
|
||||||
|
if((nbytes = recvfrom(sockfd, buffer, BUFFERL - 1, 0, (struct sockaddr*)bcasaddr, &addr_len
|
||||||
|
)) == -1) {
|
||||||
|
perror("recv");
|
||||||
|
goto doublebreak;
|
||||||
|
}
|
||||||
|
buffer[nbytes] = 0;
|
||||||
|
#ifdef DEBUG
|
||||||
|
printf("got %s\n", buffer);
|
||||||
|
#endif
|
||||||
|
telluser(buffer);
|
||||||
|
memset(buffer, 0, BUFFERL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
doublebreak:
|
||||||
|
close(sockfd);
|
||||||
|
[autoreleasepool release];
|
||||||
|
/* TODO: NSLog here (or replace perror()s with NSLog) */
|
||||||
|
[NSApp terminate: nil];
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
- (void) receiveWakeNote: (NSNotification*) note
|
||||||
|
{
|
||||||
|
// make call count zero
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
- (void)awakeFromNib {
|
||||||
|
// Insert code here to initialize your application
|
||||||
|
|
||||||
|
NSImage *appic = [[NSImage alloc] initWithContentsOfFile: [[NSBundle mainBundle] pathForResource:@"menuic" ofType:@"png"]];
|
||||||
|
NSBundle *myBundle = [NSBundle bundleForClass:[CIDGrowlAppDelegate class]];
|
||||||
|
NSString *growlPath = [[myBundle privateFrameworksPath] stringByAppendingPathComponent:@"Growl-WithInstaller.framework"];
|
||||||
|
NSBundle *growlBundle = [NSBundle bundleWithPath:growlPath];
|
||||||
|
statusItem = [[[NSStatusBar systemStatusBar] statusItemWithLength:NSSquareStatusItemLength] retain];
|
||||||
|
|
||||||
|
|
||||||
|
//[statusItem setTitle:@"C"];
|
||||||
|
[statusItem setImage:appic];
|
||||||
|
[statusItem setHighlightMode:YES];
|
||||||
|
[statusItem setMenu:statusMenu];
|
||||||
|
[[[NSWorkspace sharedWorkspace] notificationCenter] addObserver: self
|
||||||
|
selector: @selector(receiveWakeNote:) name: NSWorkspaceDidWakeNotification object: NULL];
|
||||||
|
if (growlBundle && [growlBundle load]) {
|
||||||
|
// Register ourselves as a Growl delegate
|
||||||
|
[GrowlApplicationBridge setGrowlDelegate:self];
|
||||||
|
|
||||||
|
[NSThread detachNewThreadSelector:@selector(start_netloop:) toTarget:[CIDGrowlAppDelegate class] withObject:nil];
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
NSLog(@"ERROR: Could not load Growl.framework");
|
||||||
|
}
|
||||||
|
[appic autorelease];
|
||||||
|
}
|
||||||
|
|
||||||
|
@end
|
BIN
CIDGrowlIcon.icns
Normal file
BIN
CIDGrowlIcon.icns
Normal file
Binary file not shown.
7
CIDGrowl_Prefix.pch
Normal file
7
CIDGrowl_Prefix.pch
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
//
|
||||||
|
// Prefix header for all source files of the 'CIDGrowl' target in the 'CIDGrowl' project
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifdef __OBJC__
|
||||||
|
#import <Cocoa/Cocoa.h>
|
||||||
|
#endif
|
2
English.lproj/InfoPlist.strings
Normal file
2
English.lproj/InfoPlist.strings
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
/* Localized versions of Info.plist keys */
|
||||||
|
|
4274
English.lproj/MainMenu.xib
Normal file
4274
English.lproj/MainMenu.xib
Normal file
File diff suppressed because it is too large
Load diff
20
Growl Registration Ticket.growlRegDict
Normal file
20
Growl Registration Ticket.growlRegDict
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<!--
|
||||||
|
Growl Registration Ticket.growlRegDict
|
||||||
|
CIDGrowl
|
||||||
|
-->
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>TicketVersion</key>
|
||||||
|
<integer>1</integer>
|
||||||
|
<key>AllNotifications</key>
|
||||||
|
<array>
|
||||||
|
<string>Phone Call</string>
|
||||||
|
</array>
|
||||||
|
<key>DefaultNotifications</key>
|
||||||
|
<array>
|
||||||
|
<string>Phone Call</string>
|
||||||
|
</array>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
1
Growl.framework/Growl
Symbolic link
1
Growl.framework/Growl
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
Versions/Current/Growl
|
1
Growl.framework/Headers
Symbolic link
1
Growl.framework/Headers
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
Versions/Current/Headers
|
1
Growl.framework/Resources
Symbolic link
1
Growl.framework/Resources
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
Versions/Current/Resources
|
BIN
Growl.framework/Versions/A/Growl
Executable file
BIN
Growl.framework/Versions/A/Growl
Executable file
Binary file not shown.
6
Growl.framework/Versions/A/Headers/Growl.h
Normal file
6
Growl.framework/Versions/A/Headers/Growl.h
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
#include "GrowlDefines.h"
|
||||||
|
|
||||||
|
#ifdef __OBJC__
|
||||||
|
# include "GrowlApplicationBridge.h"
|
||||||
|
#endif
|
||||||
|
#include "GrowlApplicationBridge-Carbon.h"
|
|
@ -0,0 +1,780 @@
|
||||||
|
//
|
||||||
|
// GrowlApplicationBridge-Carbon.h
|
||||||
|
// Growl
|
||||||
|
//
|
||||||
|
// Created by Mac-arena the Bored Zo on Wed Jun 18 2004.
|
||||||
|
// Based on GrowlApplicationBridge.h by Evan Schoenberg.
|
||||||
|
// This source code is in the public domain. You may freely link it into any
|
||||||
|
// program.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef _GROWLAPPLICATIONBRIDGE_CARBON_H_
|
||||||
|
#define _GROWLAPPLICATIONBRIDGE_CARBON_H_
|
||||||
|
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#include <Carbon/Carbon.h>
|
||||||
|
|
||||||
|
#ifndef GROWL_EXPORT
|
||||||
|
#define GROWL_EXPORT __attribute__((visibility("default"))) DEPRECATED_ATTRIBUTE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*! @header GrowlApplicationBridge-Carbon.h
|
||||||
|
* @abstract Declares an API that Carbon applications can use to interact with Growl.
|
||||||
|
* @discussion GrowlApplicationBridge uses a delegate to provide information //XXX
|
||||||
|
* to Growl (such as your application's name and what notifications it may
|
||||||
|
* post) and to provide information to your application (such as that Growl
|
||||||
|
* is listening for notifications or that a notification has been clicked).
|
||||||
|
*
|
||||||
|
* You can set the Growldelegate with Growl_SetDelegate and find out the
|
||||||
|
* current delegate with Growl_GetDelegate. See struct Growl_Delegate for more
|
||||||
|
* information about the delegate.
|
||||||
|
*/
|
||||||
|
|
||||||
|
__BEGIN_DECLS
|
||||||
|
|
||||||
|
/*! @struct Growl_Delegate
|
||||||
|
* @abstract Delegate to supply GrowlApplicationBridge with information and respond to events.
|
||||||
|
* @discussion The Growl delegate provides your interface to
|
||||||
|
* GrowlApplicationBridge. When GrowlApplicationBridge needs information about
|
||||||
|
* your application, it looks for it in the delegate; when Growl or the user
|
||||||
|
* does something that you might be interested in, GrowlApplicationBridge
|
||||||
|
* looks for a callback in the delegate and calls it if present
|
||||||
|
* (meaning, if it is not <code>NULL</code>).
|
||||||
|
* XXX on all of that
|
||||||
|
* @field size The size of the delegate structure.
|
||||||
|
* @field applicationName The name of your application.
|
||||||
|
* @field registrationDictionary A dictionary describing your application and the notifications it can send out.
|
||||||
|
* @field applicationIconData Your application's icon.
|
||||||
|
* @field growlInstallationWindowTitle The title of the installation window.
|
||||||
|
* @field growlInstallationInformation Text to display in the installation window.
|
||||||
|
* @field growlUpdateWindowTitle The title of the update window.
|
||||||
|
* @field growlUpdateInformation Text to display in the update window.
|
||||||
|
* @field referenceCount A count of owners of the delegate.
|
||||||
|
* @field retain Called when GrowlApplicationBridge receives this delegate.
|
||||||
|
* @field release Called when GrowlApplicationBridge no longer needs this delegate.
|
||||||
|
* @field growlIsReady Called when GrowlHelperApp is listening for notifications.
|
||||||
|
* @field growlNotificationWasClicked Called when a Growl notification is clicked.
|
||||||
|
* @field growlNotificationTimedOut Called when a Growl notification timed out.
|
||||||
|
*/
|
||||||
|
struct Growl_Delegate {
|
||||||
|
/* @discussion This should be sizeof(struct Growl_Delegate).
|
||||||
|
*/
|
||||||
|
size_t size;
|
||||||
|
|
||||||
|
/*All of these attributes are optional.
|
||||||
|
*Optional attributes can be NULL; required attributes that
|
||||||
|
* are NULL cause setting the Growl delegate to fail.
|
||||||
|
*XXX - move optional/required status into the discussion for each field
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This name is used both internally and in the Growl preferences.
|
||||||
|
*
|
||||||
|
* This should remain stable between different versions and incarnations of
|
||||||
|
* your application.
|
||||||
|
* For example, "SurfWriter" is a good app name, whereas "SurfWriter 2.0" and
|
||||||
|
* "SurfWriter Lite" are not.
|
||||||
|
*
|
||||||
|
* This can be <code>NULL</code> if it is provided elsewhere, namely in an
|
||||||
|
* auto-discoverable plist file in your app bundle
|
||||||
|
* (XXX refer to more information on that) or in registrationDictionary.
|
||||||
|
*/
|
||||||
|
CFStringRef applicationName;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Must contain at least these keys:
|
||||||
|
* GROWL_NOTIFICATIONS_ALL (CFArray):
|
||||||
|
* Contains the names of all notifications your application may post.
|
||||||
|
*
|
||||||
|
* Can also contain these keys:
|
||||||
|
* GROWL_NOTIFICATIONS_DEFAULT (CFArray):
|
||||||
|
* Names of notifications that should be enabled by default.
|
||||||
|
* If omitted, GROWL_NOTIFICATIONS_ALL will be used.
|
||||||
|
* GROWL_APP_NAME (CFString):
|
||||||
|
* Same as the applicationName member of this structure.
|
||||||
|
* If both are present, the applicationName member shall prevail.
|
||||||
|
* If this key is present, you may omit applicationName (set it to <code>NULL</code>).
|
||||||
|
* GROWL_APP_ICON (CFData):
|
||||||
|
* Same as the iconData member of this structure.
|
||||||
|
* If both are present, the iconData member shall prevail.
|
||||||
|
* If this key is present, you may omit iconData (set it to <code>NULL</code>).
|
||||||
|
*
|
||||||
|
* If you change the contents of this dictionary after setting the delegate,
|
||||||
|
* be sure to call Growl_Reregister.
|
||||||
|
*
|
||||||
|
* This can be <code>NULL</code> if you have an auto-discoverable plist file in your app
|
||||||
|
* bundle. (XXX refer to more information on that)
|
||||||
|
*/
|
||||||
|
CFDictionaryRef registrationDictionary;
|
||||||
|
|
||||||
|
/* The data can be in any format supported by NSImage. As of
|
||||||
|
* Mac OS X 10.3, this includes the .icns, TIFF, JPEG, GIF, PNG, PDF, and
|
||||||
|
* PICT formats.
|
||||||
|
*
|
||||||
|
* If this is not supplied, Growl will look up your application's icon by
|
||||||
|
* its application name.
|
||||||
|
*/
|
||||||
|
CFDataRef applicationIconData;
|
||||||
|
|
||||||
|
/* Installer display attributes
|
||||||
|
*
|
||||||
|
* These four attributes are used by the Growl installer, if this framework
|
||||||
|
* supports it.
|
||||||
|
* For any of these being <code>NULL</code>, a localised default will be
|
||||||
|
* supplied.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* If this is <code>NULL</code>, Growl will use a default,
|
||||||
|
* localized title.
|
||||||
|
*
|
||||||
|
* Only used if you're using Growl-WithInstaller.framework. Otherwise,
|
||||||
|
* this member is ignored.
|
||||||
|
*/
|
||||||
|
CFStringRef growlInstallationWindowTitle;
|
||||||
|
/* This information may be as long or short as desired (the
|
||||||
|
* window will be sized to fit it). If Growl is not installed, it will
|
||||||
|
* be displayed to the user as an explanation of what Growl is and what
|
||||||
|
* it can do in your application.
|
||||||
|
* It should probably note that no download is required to install.
|
||||||
|
*
|
||||||
|
* If this is <code>NULL</code>, Growl will use a default, localized
|
||||||
|
* explanation.
|
||||||
|
*
|
||||||
|
* Only used if you're using Growl-WithInstaller.framework. Otherwise,
|
||||||
|
* this member is ignored.
|
||||||
|
*/
|
||||||
|
CFStringRef growlInstallationInformation;
|
||||||
|
/* If this is <code>NULL</code>, Growl will use a default,
|
||||||
|
* localized title.
|
||||||
|
*
|
||||||
|
* Only used if you're using Growl-WithInstaller.framework. Otherwise,
|
||||||
|
* this member is ignored.
|
||||||
|
*/
|
||||||
|
CFStringRef growlUpdateWindowTitle;
|
||||||
|
/* This information may be as long or short as desired (the
|
||||||
|
* window will be sized to fit it). If an older version of Growl is
|
||||||
|
* installed, it will be displayed to the user as an explanation that an
|
||||||
|
* updated version of Growl is included in your application and
|
||||||
|
* no download is required.
|
||||||
|
*
|
||||||
|
* If this is <code>NULL</code>, Growl will use a default, localized
|
||||||
|
* explanation.
|
||||||
|
*
|
||||||
|
* Only used if you're using Growl-WithInstaller.framework. Otherwise,
|
||||||
|
* this member is ignored.
|
||||||
|
*/
|
||||||
|
CFStringRef growlUpdateInformation;
|
||||||
|
|
||||||
|
/* This member is provided for use by your retain and release
|
||||||
|
* callbacks (see below).
|
||||||
|
*
|
||||||
|
* GrowlApplicationBridge never directly uses this member. Instead, it
|
||||||
|
* calls your retain callback (if non-<code>NULL</code>) and your release
|
||||||
|
* callback (if non-<code>NULL</code>).
|
||||||
|
*/
|
||||||
|
unsigned referenceCount;
|
||||||
|
|
||||||
|
//Functions. Currently all of these are optional (any of them can be NULL).
|
||||||
|
|
||||||
|
/* When you call Growl_SetDelegate(newDelegate), it will call
|
||||||
|
* oldDelegate->release(oldDelegate), and then it will call
|
||||||
|
* newDelegate->retain(newDelegate), and the return value from retain
|
||||||
|
* is what will be set as the delegate.
|
||||||
|
* (This means that this member works like CFRetain and -[NSObject retain].)
|
||||||
|
* This member is optional (it can be <code>NULL</code>).
|
||||||
|
* For a delegate allocated with malloc, this member would be
|
||||||
|
* <code>NULL</code>.
|
||||||
|
* @result A delegate to which GrowlApplicationBridge holds a reference.
|
||||||
|
*/
|
||||||
|
void *(*retain)(void *);
|
||||||
|
/* When you call Growl_SetDelegate(newDelegate), it will call
|
||||||
|
* oldDelegate->release(oldDelegate), and then it will call
|
||||||
|
* newDelegate->retain(newDelegate), and the return value from retain
|
||||||
|
* is what will be set as the delegate.
|
||||||
|
* (This means that this member works like CFRelease and
|
||||||
|
* -[NSObject release].)
|
||||||
|
* This member is optional (it can be NULL).
|
||||||
|
* For a delegate allocated with malloc, this member might be
|
||||||
|
* <code>free</code>(3).
|
||||||
|
*/
|
||||||
|
void (*release)(void *);
|
||||||
|
|
||||||
|
/* Informs the delegate that Growl (specifically, the GrowlHelperApp) was
|
||||||
|
* launched successfully (or was already running). The application can
|
||||||
|
* take actions with the knowledge that Growl is installed and functional.
|
||||||
|
*/
|
||||||
|
void (*growlIsReady)(void);
|
||||||
|
|
||||||
|
/* Informs the delegate that a Growl notification was clicked. It is only
|
||||||
|
* sent for notifications sent with a non-<code>NULL</code> clickContext,
|
||||||
|
* so if you want to receive a message when a notification is clicked,
|
||||||
|
* clickContext must not be <code>NULL</code> when calling
|
||||||
|
* Growl_PostNotification or
|
||||||
|
* Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext.
|
||||||
|
*/
|
||||||
|
void (*growlNotificationWasClicked)(CFPropertyListRef clickContext);
|
||||||
|
|
||||||
|
/* Informs the delegate that a Growl notification timed out. It is only
|
||||||
|
* sent for notifications sent with a non-<code>NULL</code> clickContext,
|
||||||
|
* so if you want to receive a message when a notification is clicked,
|
||||||
|
* clickContext must not be <code>NULL</code> when calling
|
||||||
|
* Growl_PostNotification or
|
||||||
|
* Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext.
|
||||||
|
*/
|
||||||
|
void (*growlNotificationTimedOut)(CFPropertyListRef clickContext);
|
||||||
|
};
|
||||||
|
|
||||||
|
/*! @struct Growl_Notification
|
||||||
|
* @abstract Structure describing a Growl notification.
|
||||||
|
* @discussion XXX
|
||||||
|
* @field size The size of the notification structure.
|
||||||
|
* @field name Identifies the notification.
|
||||||
|
* @field title Short synopsis of the notification.
|
||||||
|
* @field description Additional text.
|
||||||
|
* @field iconData An icon for the notification.
|
||||||
|
* @field priority An indicator of the notification's importance.
|
||||||
|
* @field reserved Bits reserved for future usage.
|
||||||
|
* @field isSticky Requests that a notification stay on-screen until dismissed explicitly.
|
||||||
|
* @field clickContext An identifier to be passed to your click callback when a notification is clicked.
|
||||||
|
* @field clickCallback A callback to call when the notification is clicked.
|
||||||
|
*/
|
||||||
|
struct Growl_Notification {
|
||||||
|
/* This should be sizeof(struct Growl_Notification).
|
||||||
|
*/
|
||||||
|
size_t size;
|
||||||
|
|
||||||
|
/* The notification name distinguishes one type of
|
||||||
|
* notification from another. The name should be human-readable, as it
|
||||||
|
* will be displayed in the Growl preference pane.
|
||||||
|
*
|
||||||
|
* The name is used in the GROWL_NOTIFICATIONS_ALL and
|
||||||
|
* GROWL_NOTIFICATIONS_DEFAULT arrays in the registration dictionary, and
|
||||||
|
* in this member of the Growl_Notification structure.
|
||||||
|
*/
|
||||||
|
CFStringRef name;
|
||||||
|
|
||||||
|
/* A notification's title describes the notification briefly.
|
||||||
|
* It should be easy to read quickly by the user.
|
||||||
|
*/
|
||||||
|
CFStringRef title;
|
||||||
|
|
||||||
|
/* The description supplements the title with more
|
||||||
|
* information. It is usually longer and sometimes involves a list of
|
||||||
|
* subjects. For example, for a 'Download complete' notification, the
|
||||||
|
* description might have one filename per line. GrowlMail in Growl 0.6
|
||||||
|
* uses a description of '%d new mail(s)' (formatted with the number of
|
||||||
|
* messages).
|
||||||
|
*/
|
||||||
|
CFStringRef description;
|
||||||
|
|
||||||
|
/* The notification icon usually indicates either what
|
||||||
|
* happened (it may have the same icon as e.g. a toolbar item that
|
||||||
|
* started the process that led to the notification), or what it happened
|
||||||
|
* to (e.g. a document icon).
|
||||||
|
*
|
||||||
|
* The icon data is optional, so it can be <code>NULL</code>. In that
|
||||||
|
* case, the application icon is used alone. Not all displays support
|
||||||
|
* icons.
|
||||||
|
*
|
||||||
|
* The data can be in any format supported by NSImage. As of Mac OS X
|
||||||
|
* 10.3, this includes the .icns, TIFF, JPEG, GIF, PNG, PDF, and PICT form
|
||||||
|
* ats.
|
||||||
|
*/
|
||||||
|
CFDataRef iconData;
|
||||||
|
|
||||||
|
/* Priority is new in Growl 0.6, and is represented as a
|
||||||
|
* signed integer from -2 to +2. 0 is Normal priority, -2 is Very Low
|
||||||
|
* priority, and +2 is Very High priority.
|
||||||
|
*
|
||||||
|
* Not all displays support priority. If you do not wish to assign a
|
||||||
|
* priority to your notification, assign 0.
|
||||||
|
*/
|
||||||
|
signed int priority;
|
||||||
|
|
||||||
|
/* These bits are not used in Growl 0.6. Set them to 0.
|
||||||
|
*/
|
||||||
|
unsigned reserved: 31;
|
||||||
|
|
||||||
|
/* When the sticky bit is clear, in most displays,
|
||||||
|
* notifications disappear after a certain amount of time. Sticky
|
||||||
|
* notifications, however, remain on-screen until the user dismisses them
|
||||||
|
* explicitly, usually by clicking them.
|
||||||
|
*
|
||||||
|
* Sticky notifications were introduced in Growl 0.6. Most notifications
|
||||||
|
* should not be sticky. Not all displays support sticky notifications,
|
||||||
|
* and the user may choose in Growl's preference pane to force the
|
||||||
|
* notification to be sticky or non-sticky, in which case the sticky bit
|
||||||
|
* in the notification will be ignored.
|
||||||
|
*/
|
||||||
|
unsigned isSticky: 1;
|
||||||
|
|
||||||
|
/* If this is not <code>NULL</code>, and your click callback
|
||||||
|
* is not <code>NULL</code> either, this will be passed to the callback
|
||||||
|
* when your notification is clicked by the user.
|
||||||
|
*
|
||||||
|
* Click feedback was introduced in Growl 0.6, and it is optional. Not
|
||||||
|
* all displays support click feedback.
|
||||||
|
*/
|
||||||
|
CFPropertyListRef clickContext;
|
||||||
|
|
||||||
|
/* If this is not <code>NULL</code>, it will be called instead
|
||||||
|
* of the Growl delegate's click callback when clickContext is
|
||||||
|
* non-<code>NULL</code> and the notification is clicked on by the user.
|
||||||
|
*
|
||||||
|
* Click feedback was introduced in Growl 0.6, and it is optional. Not
|
||||||
|
* all displays support click feedback.
|
||||||
|
*
|
||||||
|
* The per-notification click callback is not yet supported as of Growl
|
||||||
|
* 0.7.
|
||||||
|
*/
|
||||||
|
void (*clickCallback)(CFPropertyListRef clickContext);
|
||||||
|
|
||||||
|
CFStringRef identifier;
|
||||||
|
};
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
#pragma mark Easy initialisers
|
||||||
|
|
||||||
|
/*! @defined InitGrowlDelegate
|
||||||
|
* @abstract Callable macro. Initializes a Growl delegate structure to defaults.
|
||||||
|
* @discussion Call with a pointer to a struct Growl_Delegate. All of the
|
||||||
|
* members of the structure will be set to 0 or <code>NULL</code>, except for
|
||||||
|
* size (which will be set to <code>sizeof(struct Growl_Delegate)</code>) and
|
||||||
|
* referenceCount (which will be set to 1).
|
||||||
|
*/
|
||||||
|
#define InitGrowlDelegate(delegate) \
|
||||||
|
do { \
|
||||||
|
if (delegate) { \
|
||||||
|
(delegate)->size = sizeof(struct Growl_Delegate); \
|
||||||
|
(delegate)->applicationName = NULL; \
|
||||||
|
(delegate)->registrationDictionary = NULL; \
|
||||||
|
(delegate)->applicationIconData = NULL; \
|
||||||
|
(delegate)->growlInstallationWindowTitle = NULL; \
|
||||||
|
(delegate)->growlInstallationInformation = NULL; \
|
||||||
|
(delegate)->growlUpdateWindowTitle = NULL; \
|
||||||
|
(delegate)->growlUpdateInformation = NULL; \
|
||||||
|
(delegate)->referenceCount = 1U; \
|
||||||
|
(delegate)->retain = NULL; \
|
||||||
|
(delegate)->release = NULL; \
|
||||||
|
(delegate)->growlIsReady = NULL; \
|
||||||
|
(delegate)->growlNotificationWasClicked = NULL; \
|
||||||
|
(delegate)->growlNotificationTimedOut = NULL; \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
/*! @defined InitGrowlNotification
|
||||||
|
* @abstract Callable macro. Initializes a Growl notification structure to defaults.
|
||||||
|
* @discussion Call with a pointer to a struct Growl_Notification. All of
|
||||||
|
* the members of the structure will be set to 0 or <code>NULL</code>, except
|
||||||
|
* for size (which will be set to
|
||||||
|
* <code>sizeof(struct Growl_Notification)</code>).
|
||||||
|
*/
|
||||||
|
#define InitGrowlNotification(notification) \
|
||||||
|
do { \
|
||||||
|
if (notification) { \
|
||||||
|
(notification)->size = sizeof(struct Growl_Notification); \
|
||||||
|
(notification)->name = NULL; \
|
||||||
|
(notification)->title = NULL; \
|
||||||
|
(notification)->description = NULL; \
|
||||||
|
(notification)->iconData = NULL; \
|
||||||
|
(notification)->priority = 0; \
|
||||||
|
(notification)->reserved = 0U; \
|
||||||
|
(notification)->isSticky = false; \
|
||||||
|
(notification)->clickContext = NULL; \
|
||||||
|
(notification)->clickCallback = NULL; \
|
||||||
|
(notification)->identifier = NULL; \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
#pragma mark Public API
|
||||||
|
|
||||||
|
// @functiongroup Managing the Growl delegate
|
||||||
|
|
||||||
|
/*! @function Growl_SetDelegate
|
||||||
|
* @abstract Replaces the current Growl delegate with a new one, or removes
|
||||||
|
* the Growl delegate.
|
||||||
|
* @param newDelegate
|
||||||
|
* @result Returns false and does nothing else if a pointer that was passed in
|
||||||
|
* is unsatisfactory (because it is non-<code>NULL</code>, but at least one
|
||||||
|
* required member of it is <code>NULL</code>). Otherwise, sets or unsets the
|
||||||
|
* delegate and returns true.
|
||||||
|
* @discussion When <code>newDelegate</code> is non-<code>NULL</code>, sets
|
||||||
|
* the delegate to <code>newDelegate</code>. When it is <code>NULL</code>,
|
||||||
|
* the current delegate will be unset, and no delegate will be in place.
|
||||||
|
*
|
||||||
|
* It is legal for <code>newDelegate</code> to be the current delegate;
|
||||||
|
* nothing will happen, and Growl_SetDelegate will return true. It is also
|
||||||
|
* legal for it to be <code>NULL</code>, as described above; again, it will
|
||||||
|
* return true.
|
||||||
|
*
|
||||||
|
* If there was a delegate in place before the call, Growl_SetDelegate will
|
||||||
|
* call the old delegate's release member if it was non-<code>NULL</code>. If
|
||||||
|
* <code>newDelegate</code> is non-<code>NULL</code>, Growl_SetDelegate will
|
||||||
|
* call <code>newDelegate->retain</code>, and set the delegate to its return
|
||||||
|
* value.
|
||||||
|
*
|
||||||
|
* If you are using Growl-WithInstaller.framework, and an older version of
|
||||||
|
* Growl is installed on the user's system, the user will automatically be
|
||||||
|
* prompted to update.
|
||||||
|
*
|
||||||
|
* GrowlApplicationBridge currently does not copy this structure, nor does it
|
||||||
|
* retain any of the CF objects in the structure (it regards the structure as
|
||||||
|
* a container that retains the objects when they are added and releases them
|
||||||
|
* when they are removed or the structure is destroyed). Also,
|
||||||
|
* GrowlApplicationBridge currently does not modify any member of the
|
||||||
|
* structure, except possibly the referenceCount by calling the retain and
|
||||||
|
* release members.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_SetDelegate(struct Growl_Delegate *newDelegate);
|
||||||
|
|
||||||
|
/*! @function Growl_GetDelegate
|
||||||
|
* @abstract Returns the current Growl delegate, if any.
|
||||||
|
* @result The current Growl delegate.
|
||||||
|
* @discussion Returns the last pointer passed into Growl_SetDelegate, or
|
||||||
|
* <code>NULL</code> if no such call has been made.
|
||||||
|
*
|
||||||
|
* This function follows standard Core Foundation reference-counting rules.
|
||||||
|
* Because it is a Get function, not a Copy function, it will not retain the
|
||||||
|
* delegate on your behalf. You are responsible for retaining and releasing
|
||||||
|
* the delegate as needed.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT struct Growl_Delegate *Growl_GetDelegate(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Posting Growl notifications
|
||||||
|
|
||||||
|
/*! @function Growl_PostNotification
|
||||||
|
* @abstract Posts a Growl notification.
|
||||||
|
* @param notification The notification to post.
|
||||||
|
* @discussion This is the preferred means for sending a Growl notification.
|
||||||
|
* The notification name and at least one of the title and description are
|
||||||
|
* required (all three are preferred). All other parameters may be
|
||||||
|
* <code>NULL</code> (or 0 or false as appropriate) to accept default values.
|
||||||
|
*
|
||||||
|
* If using the Growl-WithInstaller framework, if Growl is not installed the
|
||||||
|
* user will be prompted to install Growl.
|
||||||
|
* If the user cancels, this function will have no effect until the next
|
||||||
|
* application session, at which time when it is called the user will be
|
||||||
|
* prompted again. The user is also given the option to not be prompted again.
|
||||||
|
* If the user does choose to install Growl, the requested notification will
|
||||||
|
* be displayed once Growl is installed and running.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_PostNotification(const struct Growl_Notification *notification);
|
||||||
|
|
||||||
|
/*! @function Growl_PostNotificationWithDictionary
|
||||||
|
* @abstract Notifies using a userInfo dictionary suitable for passing to
|
||||||
|
* CFDistributedNotificationCenter.
|
||||||
|
* @param userInfo The dictionary to notify with.
|
||||||
|
* @discussion Before Growl 0.6, your application would have posted
|
||||||
|
* notifications using CFDistributedNotificationCenter by creating a userInfo
|
||||||
|
* dictionary with the notification data. This had the advantage of allowing
|
||||||
|
* you to add other data to the dictionary for programs besides Growl that
|
||||||
|
* might be listening.
|
||||||
|
*
|
||||||
|
* This function allows you to use such dictionaries without being restricted
|
||||||
|
* to using CFDistributedNotificationCenter. The keys for this dictionary
|
||||||
|
* can be found in GrowlDefines.h.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_PostNotificationWithDictionary(CFDictionaryRef userInfo);
|
||||||
|
|
||||||
|
/*! @function Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext
|
||||||
|
* @abstract Posts a Growl notification using parameter values.
|
||||||
|
* @param title The title of the notification.
|
||||||
|
* @param description The description of the notification.
|
||||||
|
* @param notificationName The name of the notification as listed in the
|
||||||
|
* registration dictionary.
|
||||||
|
* @param iconData Data representing a notification icon. Can be <code>NULL</code>.
|
||||||
|
* @param priority The priority of the notification (-2 to +2, with -2
|
||||||
|
* being Very Low and +2 being Very High).
|
||||||
|
* @param isSticky If true, requests that this notification wait for a
|
||||||
|
* response from the user.
|
||||||
|
* @param clickContext An object to pass to the clickCallback, if any. Can
|
||||||
|
* be <code>NULL</code>, in which case the clickCallback is not called.
|
||||||
|
* @discussion Creates a temporary Growl_Notification, fills it out with the
|
||||||
|
* supplied information, and calls Growl_PostNotification on it.
|
||||||
|
* See struct Growl_Notification and Growl_PostNotification for more
|
||||||
|
* information.
|
||||||
|
*
|
||||||
|
* The icon data can be in any format supported by NSImage. As of Mac OS X
|
||||||
|
* 10.3, this includes the .icns, TIFF, JPEG, GIF, PNG, PDF, and PICT formats.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext(
|
||||||
|
/*inhale*/
|
||||||
|
CFStringRef title,
|
||||||
|
CFStringRef description,
|
||||||
|
CFStringRef notificationName,
|
||||||
|
CFDataRef iconData,
|
||||||
|
signed int priority,
|
||||||
|
Boolean isSticky,
|
||||||
|
CFPropertyListRef clickContext);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Registering
|
||||||
|
|
||||||
|
/*! @function Growl_RegisterWithDictionary
|
||||||
|
* @abstract Register your application with Growl without setting a delegate.
|
||||||
|
* @discussion When you call this function with a dictionary,
|
||||||
|
* GrowlApplicationBridge registers your application using that dictionary.
|
||||||
|
* If you pass <code>NULL</code>, GrowlApplicationBridge will ask the delegate
|
||||||
|
* (if there is one) for a dictionary, and if that doesn't work, it will look
|
||||||
|
* in your application's bundle for an auto-discoverable plist.
|
||||||
|
* (XXX refer to more information on that)
|
||||||
|
*
|
||||||
|
* If you pass a dictionary to this function, it must include the
|
||||||
|
* <code>GROWL_APP_NAME</code> key, unless a delegate is set.
|
||||||
|
*
|
||||||
|
* This function is mainly an alternative to the delegate system introduced
|
||||||
|
* with Growl 0.6. Without a delegate, you cannot receive callbacks such as
|
||||||
|
* <code>growlIsReady</code> (since they are sent to the delegate). You can,
|
||||||
|
* however, set a delegate after registering without one.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
* @result <code>false</code> if registration failed (e.g. if Growl isn't installed).
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_RegisterWithDictionary(CFDictionaryRef regDict);
|
||||||
|
|
||||||
|
/*! @function Growl_Reregister
|
||||||
|
* @abstract Updates your registration with Growl.
|
||||||
|
* @discussion If your application changes the contents of the
|
||||||
|
* GROWL_NOTIFICATIONS_ALL key in the registrationDictionary member of the
|
||||||
|
* Growl delegate, or if it changes the value of that member, or if it
|
||||||
|
* changes the contents of its auto-discoverable plist, call this function
|
||||||
|
* to have Growl update its registration information for your application.
|
||||||
|
*
|
||||||
|
* Otherwise, this function does not normally need to be called. If you're
|
||||||
|
* using a delegate, your application will be registered when you set the
|
||||||
|
* delegate if both the delegate and its registrationDictionary member are
|
||||||
|
* non-<code>NULL</code>.
|
||||||
|
*
|
||||||
|
* This function is now implemented using
|
||||||
|
* <code>Growl_RegisterWithDictionary</code>.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_Reregister(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @function Growl_SetWillRegisterWhenGrowlIsReady
|
||||||
|
* @abstract Tells GrowlApplicationBridge to register with Growl when Growl
|
||||||
|
* launches (or not).
|
||||||
|
* @discussion When Growl has started listening for notifications, it posts a
|
||||||
|
* <code>GROWL_IS_READY</code> notification on the Distributed Notification
|
||||||
|
* Center. GrowlApplicationBridge listens for this notification, using it to
|
||||||
|
* perform various tasks (such as calling your delegate's
|
||||||
|
* <code>growlIsReady</code> callback, if it has one). If this function is
|
||||||
|
* called with <code>true</code>, one of those tasks will be to reregister
|
||||||
|
* with Growl (in the manner of <code>Growl_Reregister</code>).
|
||||||
|
*
|
||||||
|
* This attribute is automatically set back to <code>false</code>
|
||||||
|
* (the default) after every <code>GROWL_IS_READY</code> notification.
|
||||||
|
* @param flag <code>true</code> if you want GrowlApplicationBridge to register with
|
||||||
|
* Growl when next it is ready; <code>false</code> if not.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_SetWillRegisterWhenGrowlIsReady(Boolean flag);
|
||||||
|
/*! @function Growl_WillRegisterWhenGrowlIsReady
|
||||||
|
* @abstract Reports whether GrowlApplicationBridge will register with Growl
|
||||||
|
* when Growl next launches.
|
||||||
|
* @result <code>true</code> if GrowlApplicationBridge will register with
|
||||||
|
* Growl when next it posts GROWL_IS_READY; <code>false</code> if not.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_WillRegisterWhenGrowlIsReady(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Obtaining registration dictionaries
|
||||||
|
|
||||||
|
/*! @function Growl_CopyRegistrationDictionaryFromDelegate
|
||||||
|
* @abstract Asks the delegate for a registration dictionary.
|
||||||
|
* @discussion If no delegate is set, or if the delegate's
|
||||||
|
* <code>registrationDictionary</code> member is <code>NULL</code>, this
|
||||||
|
* function returns <code>NULL</code>.
|
||||||
|
*
|
||||||
|
* This function does not attempt to clean up the dictionary in any way - for
|
||||||
|
* example, if it is missing the <code>GROWL_APP_NAME</code> key, the result
|
||||||
|
* will be missing it too. Use
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionary</code> or
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys</code>
|
||||||
|
* to try to fill in missing keys.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CopyRegistrationDictionaryFromDelegate(void);
|
||||||
|
|
||||||
|
/*! @function Growl_CopyRegistrationDictionaryFromBundle
|
||||||
|
* @abstract Looks in a bundle for a registration dictionary.
|
||||||
|
* @discussion This function looks in a bundle for an auto-discoverable
|
||||||
|
* registration dictionary file using <code>CFBundleCopyResourceURL</code>.
|
||||||
|
* If it finds one, it loads the file using <code>CFPropertyList</code> and
|
||||||
|
* returns the result.
|
||||||
|
*
|
||||||
|
* If you pass <code>NULL</code> as the bundle, the main bundle is examined.
|
||||||
|
*
|
||||||
|
* This function does not attempt to clean up the dictionary in any way - for
|
||||||
|
* example, if it is missing the <code>GROWL_APP_NAME</code> key, the result
|
||||||
|
* will be missing it too. Use
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionary:</code> or
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys</code>
|
||||||
|
* to try to fill in missing keys.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CopyRegistrationDictionaryFromBundle(CFBundleRef bundle);
|
||||||
|
|
||||||
|
/*! @function Growl_CreateBestRegistrationDictionary
|
||||||
|
* @abstract Obtains a registration dictionary, filled out to the best of
|
||||||
|
* GrowlApplicationBridge's knowledge.
|
||||||
|
* @discussion This function creates a registration dictionary as best
|
||||||
|
* GrowlApplicationBridge knows how.
|
||||||
|
*
|
||||||
|
* First, GrowlApplicationBridge examines the Growl delegate (if there is
|
||||||
|
* one) and gets the registration dictionary from that. If no such dictionary
|
||||||
|
* was obtained, GrowlApplicationBridge looks in your application's main
|
||||||
|
* bundle for an auto-discoverable registration dictionary file. If that
|
||||||
|
* doesn't exist either, this function returns <code>NULL</code>.
|
||||||
|
*
|
||||||
|
* Second, GrowlApplicationBridge calls
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionary</code> with
|
||||||
|
* whatever dictionary was obtained. The result of that function is the
|
||||||
|
* result of this function.
|
||||||
|
*
|
||||||
|
* GrowlApplicationBridge uses this function when you call
|
||||||
|
* <code>Growl_SetDelegate</code>, or when you call
|
||||||
|
* <code>Growl_RegisterWithDictionary</code> with <code>NULL</code>.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CreateBestRegistrationDictionary(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Filling in registration dictionaries
|
||||||
|
|
||||||
|
/*! @function Growl_CreateRegistrationDictionaryByFillingInDictionary
|
||||||
|
* @abstract Tries to fill in missing keys in a registration dictionary.
|
||||||
|
* @param regDict The dictionary to fill in.
|
||||||
|
* @result The dictionary with the keys filled in.
|
||||||
|
* @discussion This function examines the passed-in dictionary for missing keys,
|
||||||
|
* and tries to work out correct values for them. As of 0.7, it uses:
|
||||||
|
*
|
||||||
|
* Key Value
|
||||||
|
* --- -----
|
||||||
|
* <code>GROWL_APP_NAME</code> <code>CFBundleExecutableName</code>
|
||||||
|
* <code>GROWL_APP_ICON</code> The icon of the application.
|
||||||
|
* <code>GROWL_APP_LOCATION</code> The location of the application.
|
||||||
|
* <code>GROWL_NOTIFICATIONS_DEFAULT</code> <code>GROWL_NOTIFICATIONS_ALL</code>
|
||||||
|
*
|
||||||
|
* Keys are only filled in if missing; if a key is present in the dictionary,
|
||||||
|
* its value will not be changed.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CreateRegistrationDictionaryByFillingInDictionary(CFDictionaryRef regDict);
|
||||||
|
/*! @function Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys
|
||||||
|
* @abstract Tries to fill in missing keys in a registration dictionary.
|
||||||
|
* @param regDict The dictionary to fill in.
|
||||||
|
* @param keys The keys to fill in. If <code>NULL</code>, any missing keys are filled in.
|
||||||
|
* @result The dictionary with the keys filled in.
|
||||||
|
* @discussion This function examines the passed-in dictionary for missing keys,
|
||||||
|
* and tries to work out correct values for them. As of 0.7, it uses:
|
||||||
|
*
|
||||||
|
* Key Value
|
||||||
|
* --- -----
|
||||||
|
* <code>GROWL_APP_NAME</code> <code>CFBundleExecutableName</code>
|
||||||
|
* <code>GROWL_APP_ICON</code> The icon of the application.
|
||||||
|
* <code>GROWL_APP_LOCATION</code> The location of the application.
|
||||||
|
* <code>GROWL_NOTIFICATIONS_DEFAULT</code> <code>GROWL_NOTIFICATIONS_ALL</code>
|
||||||
|
*
|
||||||
|
* Only those keys that are listed in <code>keys</code> will be filled in.
|
||||||
|
* Other missing keys are ignored. Also, keys are only filled in if missing;
|
||||||
|
* if a key is present in the dictionary, its value will not be changed.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys(CFDictionaryRef regDict, CFSetRef keys);
|
||||||
|
|
||||||
|
/*! @brief Tries to fill in missing keys in a notification dictionary.
|
||||||
|
* @param notifDict The dictionary to fill in.
|
||||||
|
* @return The dictionary with the keys filled in. This will be a separate instance from \a notifDict.
|
||||||
|
* @discussion This function examines the \a notifDict for missing keys, and
|
||||||
|
* tries to get them from the last known registration dictionary. As of 1.1,
|
||||||
|
* the keys that it will look for are:
|
||||||
|
*
|
||||||
|
* \li <code>GROWL_APP_NAME</code>
|
||||||
|
* \li <code>GROWL_APP_ICON</code>
|
||||||
|
*
|
||||||
|
* @since Growl.framework 1.1
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CreateNotificationDictionaryByFillingInDictionary(CFDictionaryRef notifDict);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Querying Growl's status
|
||||||
|
|
||||||
|
/*! @function Growl_IsInstalled
|
||||||
|
* @abstract Determines whether the Growl prefpane and its helper app are
|
||||||
|
* installed.
|
||||||
|
* @result Returns true if Growl is installed, false otherwise.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_IsInstalled(void);
|
||||||
|
|
||||||
|
/*! @function Growl_IsRunning
|
||||||
|
* @abstract Cycles through the process list to find whether GrowlHelperApp
|
||||||
|
* is running.
|
||||||
|
* @result Returns true if Growl is running, false otherwise.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_IsRunning(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Launching Growl
|
||||||
|
|
||||||
|
/*! @typedef GrowlLaunchCallback
|
||||||
|
* @abstract Callback to notify you that Growl is running.
|
||||||
|
* @param context The context pointer passed to Growl_LaunchIfInstalled.
|
||||||
|
* @discussion Growl_LaunchIfInstalled calls this callback function if Growl
|
||||||
|
* was already running or if it launched Growl successfully.
|
||||||
|
*/
|
||||||
|
typedef void (*GrowlLaunchCallback)(void *context);
|
||||||
|
|
||||||
|
/*! @function Growl_LaunchIfInstalled
|
||||||
|
* @abstract Launches GrowlHelperApp if it is not already running.
|
||||||
|
* @param callback A callback function which will be called if Growl was successfully
|
||||||
|
* launched or was already running. Can be <code>NULL</code>.
|
||||||
|
* @param context The context pointer to pass to the callback. Can be <code>NULL</code>.
|
||||||
|
* @result Returns true if Growl was successfully launched or was already
|
||||||
|
* running; returns false and does not call the callback otherwise.
|
||||||
|
* @discussion Returns true and calls the callback (if the callback is not
|
||||||
|
* <code>NULL</code>) if the Growl helper app began launching or was already
|
||||||
|
* running. Returns false and performs no other action if Growl could not be
|
||||||
|
* launched (e.g. because the Growl preference pane is not properly installed).
|
||||||
|
*
|
||||||
|
* If <code>Growl_CreateBestRegistrationDictionary</code> returns
|
||||||
|
* non-<code>NULL</code>, this function will register with Growl atomically.
|
||||||
|
*
|
||||||
|
* The callback should take a single argument; this is to allow applications
|
||||||
|
* to have context-relevant information passed back. It is perfectly
|
||||||
|
* acceptable for context to be <code>NULL</code>. The callback itself can be
|
||||||
|
* <code>NULL</code> if you don't want one.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_LaunchIfInstalled(GrowlLaunchCallback callback, void *context);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
#pragma mark Constants
|
||||||
|
|
||||||
|
/*! @defined GROWL_PREFPANE_BUNDLE_IDENTIFIER
|
||||||
|
* @abstract The CFBundleIdentifier of the Growl preference pane bundle.
|
||||||
|
* @discussion GrowlApplicationBridge uses this to determine whether Growl is
|
||||||
|
* currently installed, by searching for the Growl preference pane. Your
|
||||||
|
* application probably does not need to use this macro itself.
|
||||||
|
*/
|
||||||
|
#ifndef GROWL_PREFPANE_BUNDLE_IDENTIFIER
|
||||||
|
#define GROWL_PREFPANE_BUNDLE_IDENTIFIER CFSTR("com.growl.prefpanel")
|
||||||
|
#endif
|
||||||
|
|
||||||
|
__END_DECLS
|
||||||
|
|
||||||
|
#endif /* _GROWLAPPLICATIONBRIDGE_CARBON_H_ */
|
575
Growl.framework/Versions/A/Headers/GrowlApplicationBridge.h
Normal file
575
Growl.framework/Versions/A/Headers/GrowlApplicationBridge.h
Normal file
|
@ -0,0 +1,575 @@
|
||||||
|
//
|
||||||
|
// GrowlApplicationBridge.h
|
||||||
|
// Growl
|
||||||
|
//
|
||||||
|
// Created by Evan Schoenberg on Wed Jun 16 2004.
|
||||||
|
// Copyright 2004-2006 The Growl Project. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @header GrowlApplicationBridge.h
|
||||||
|
* @abstract Defines the GrowlApplicationBridge class.
|
||||||
|
* @discussion This header defines the GrowlApplicationBridge class as well as
|
||||||
|
* the GROWL_PREFPANE_BUNDLE_IDENTIFIER constant.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __GrowlApplicationBridge_h__
|
||||||
|
#define __GrowlApplicationBridge_h__
|
||||||
|
|
||||||
|
#import <Foundation/Foundation.h>
|
||||||
|
#import <AppKit/AppKit.h>
|
||||||
|
#import "GrowlDefines.h"
|
||||||
|
|
||||||
|
//Forward declarations
|
||||||
|
@protocol GrowlApplicationBridgeDelegate;
|
||||||
|
|
||||||
|
//Internal notification when the user chooses not to install (to avoid continuing to cache notifications awaiting installation)
|
||||||
|
#define GROWL_USER_CHOSE_NOT_TO_INSTALL_NOTIFICATION @"User chose not to install"
|
||||||
|
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @class GrowlApplicationBridge
|
||||||
|
* @abstract A class used to interface with Growl.
|
||||||
|
* @discussion This class provides a means to interface with Growl.
|
||||||
|
*
|
||||||
|
* Currently it provides a way to detect if Growl is installed and launch the
|
||||||
|
* GrowlHelperApp if it's not already running.
|
||||||
|
*/
|
||||||
|
@interface GrowlApplicationBridge : NSObject {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method isGrowlInstalled
|
||||||
|
* @abstract Detects whether Growl is installed.
|
||||||
|
* @discussion Determines if the Growl prefpane and its helper app are installed.
|
||||||
|
* @result Returns YES if Growl is installed, NO otherwise.
|
||||||
|
*/
|
||||||
|
+ (BOOL) isGrowlInstalled;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method isGrowlRunning
|
||||||
|
* @abstract Detects whether GrowlHelperApp is currently running.
|
||||||
|
* @discussion Cycles through the process list to find whether GrowlHelperApp is running and returns its findings.
|
||||||
|
* @result Returns YES if GrowlHelperApp is running, NO otherwise.
|
||||||
|
*/
|
||||||
|
+ (BOOL) isGrowlRunning;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method setGrowlDelegate:
|
||||||
|
* @abstract Set the object which will be responsible for providing and receiving Growl information.
|
||||||
|
* @discussion This must be called before using GrowlApplicationBridge.
|
||||||
|
*
|
||||||
|
* The methods in the GrowlApplicationBridgeDelegate protocol are required
|
||||||
|
* and return the basic information needed to register with Growl.
|
||||||
|
*
|
||||||
|
* The methods in the GrowlApplicationBridgeDelegate_InformalProtocol
|
||||||
|
* informal protocol are individually optional. They provide a greater
|
||||||
|
* degree of interaction between the application and growl such as informing
|
||||||
|
* the application when one of its Growl notifications is clicked by the user.
|
||||||
|
*
|
||||||
|
* The methods in the GrowlApplicationBridgeDelegate_Installation_InformalProtocol
|
||||||
|
* informal protocol are individually optional and are only applicable when
|
||||||
|
* using the Growl-WithInstaller.framework which allows for automated Growl
|
||||||
|
* installation.
|
||||||
|
*
|
||||||
|
* When this method is called, data will be collected from inDelegate, Growl
|
||||||
|
* will be launched if it is not already running, and the application will be
|
||||||
|
* registered with Growl.
|
||||||
|
*
|
||||||
|
* If using the Growl-WithInstaller framework, if Growl is already installed
|
||||||
|
* but this copy of the framework has an updated version of Growl, the user
|
||||||
|
* will be prompted to update automatically.
|
||||||
|
*
|
||||||
|
* @param inDelegate The delegate for the GrowlApplicationBridge. It must conform to the GrowlApplicationBridgeDelegate protocol.
|
||||||
|
*/
|
||||||
|
+ (void) setGrowlDelegate:(NSObject<GrowlApplicationBridgeDelegate> *)inDelegate;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlDelegate
|
||||||
|
* @abstract Return the object responsible for providing and receiving Growl information.
|
||||||
|
* @discussion See setGrowlDelegate: for details.
|
||||||
|
* @result The Growl delegate.
|
||||||
|
*/
|
||||||
|
+ (NSObject<GrowlApplicationBridgeDelegate> *) growlDelegate;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:
|
||||||
|
* @abstract Send a Growl notification.
|
||||||
|
* @discussion This is the preferred means for sending a Growl notification.
|
||||||
|
* The notification name and at least one of the title and description are
|
||||||
|
* required (all three are preferred). All other parameters may be
|
||||||
|
* <code>nil</code> (or 0 or NO as appropriate) to accept default values.
|
||||||
|
*
|
||||||
|
* If using the Growl-WithInstaller framework, if Growl is not installed the
|
||||||
|
* user will be prompted to install Growl. If the user cancels, this method
|
||||||
|
* will have no effect until the next application session, at which time when
|
||||||
|
* it is called the user will be prompted again. The user is also given the
|
||||||
|
* option to not be prompted again. If the user does choose to install Growl,
|
||||||
|
* the requested notification will be displayed once Growl is installed and
|
||||||
|
* running.
|
||||||
|
*
|
||||||
|
* @param title The title of the notification displayed to the user.
|
||||||
|
* @param description The full description of the notification displayed to the user.
|
||||||
|
* @param notifName The internal name of the notification. Should be human-readable, as it will be displayed in the Growl preference pane.
|
||||||
|
* @param iconData <code>NSData</code> object to show with the notification as its icon. If <code>nil</code>, the application's icon will be used instead.
|
||||||
|
* @param priority The priority of the notification. The default value is 0; positive values are higher priority and negative values are lower priority. Not all Growl displays support priority.
|
||||||
|
* @param isSticky If YES, the notification will remain on screen until clicked. Not all Growl displays support sticky notifications.
|
||||||
|
* @param clickContext A context passed back to the Growl delegate if it implements -(void)growlNotificationWasClicked: and the notification is clicked. Not all display plugins support clicking. The clickContext must be plist-encodable (completely of <code>NSString</code>, <code>NSArray</code>, <code>NSNumber</code>, <code>NSDictionary</code>, and <code>NSData</code> types).
|
||||||
|
*/
|
||||||
|
+ (void) notifyWithTitle:(NSString *)title
|
||||||
|
description:(NSString *)description
|
||||||
|
notificationName:(NSString *)notifName
|
||||||
|
iconData:(NSData *)iconData
|
||||||
|
priority:(signed int)priority
|
||||||
|
isSticky:(BOOL)isSticky
|
||||||
|
clickContext:(id)clickContext;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:identifier:
|
||||||
|
* @abstract Send a Growl notification.
|
||||||
|
* @discussion This is the preferred means for sending a Growl notification.
|
||||||
|
* The notification name and at least one of the title and description are
|
||||||
|
* required (all three are preferred). All other parameters may be
|
||||||
|
* <code>nil</code> (or 0 or NO as appropriate) to accept default values.
|
||||||
|
*
|
||||||
|
* If using the Growl-WithInstaller framework, if Growl is not installed the
|
||||||
|
* user will be prompted to install Growl. If the user cancels, this method
|
||||||
|
* will have no effect until the next application session, at which time when
|
||||||
|
* it is called the user will be prompted again. The user is also given the
|
||||||
|
* option to not be prompted again. If the user does choose to install Growl,
|
||||||
|
* the requested notification will be displayed once Growl is installed and
|
||||||
|
* running.
|
||||||
|
*
|
||||||
|
* @param title The title of the notification displayed to the user.
|
||||||
|
* @param description The full description of the notification displayed to the user.
|
||||||
|
* @param notifName The internal name of the notification. Should be human-readable, as it will be displayed in the Growl preference pane.
|
||||||
|
* @param iconData <code>NSData</code> object to show with the notification as its icon. If <code>nil</code>, the application's icon will be used instead.
|
||||||
|
* @param priority The priority of the notification. The default value is 0; positive values are higher priority and negative values are lower priority. Not all Growl displays support priority.
|
||||||
|
* @param isSticky If YES, the notification will remain on screen until clicked. Not all Growl displays support sticky notifications.
|
||||||
|
* @param clickContext A context passed back to the Growl delegate if it implements -(void)growlNotificationWasClicked: and the notification is clicked. Not all display plugins support clicking. The clickContext must be plist-encodable (completely of <code>NSString</code>, <code>NSArray</code>, <code>NSNumber</code>, <code>NSDictionary</code>, and <code>NSData</code> types).
|
||||||
|
* @param identifier An identifier for this notification. Notifications with equal identifiers are coalesced.
|
||||||
|
*/
|
||||||
|
+ (void) notifyWithTitle:(NSString *)title
|
||||||
|
description:(NSString *)description
|
||||||
|
notificationName:(NSString *)notifName
|
||||||
|
iconData:(NSData *)iconData
|
||||||
|
priority:(signed int)priority
|
||||||
|
isSticky:(BOOL)isSticky
|
||||||
|
clickContext:(id)clickContext
|
||||||
|
identifier:(NSString *)identifier;
|
||||||
|
|
||||||
|
/*! @method notifyWithDictionary:
|
||||||
|
* @abstract Notifies using a userInfo dictionary suitable for passing to
|
||||||
|
* <code>NSDistributedNotificationCenter</code>.
|
||||||
|
* @param userInfo The dictionary to notify with.
|
||||||
|
* @discussion Before Growl 0.6, your application would have posted
|
||||||
|
* notifications using <code>NSDistributedNotificationCenter</code> by
|
||||||
|
* creating a userInfo dictionary with the notification data. This had the
|
||||||
|
* advantage of allowing you to add other data to the dictionary for programs
|
||||||
|
* besides Growl that might be listening.
|
||||||
|
*
|
||||||
|
* This method allows you to use such dictionaries without being restricted
|
||||||
|
* to using <code>NSDistributedNotificationCenter</code>. The keys for this dictionary
|
||||||
|
* can be found in GrowlDefines.h.
|
||||||
|
*/
|
||||||
|
+ (void) notifyWithDictionary:(NSDictionary *)userInfo;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @method registerWithDictionary:
|
||||||
|
* @abstract Register your application with Growl without setting a delegate.
|
||||||
|
* @discussion When you call this method with a dictionary,
|
||||||
|
* GrowlApplicationBridge registers your application using that dictionary.
|
||||||
|
* If you pass <code>nil</code>, GrowlApplicationBridge will ask the delegate
|
||||||
|
* (if there is one) for a dictionary, and if that doesn't work, it will look
|
||||||
|
* in your application's bundle for an auto-discoverable plist.
|
||||||
|
* (XXX refer to more information on that)
|
||||||
|
*
|
||||||
|
* If you pass a dictionary to this method, it must include the
|
||||||
|
* <code>GROWL_APP_NAME</code> key, unless a delegate is set.
|
||||||
|
*
|
||||||
|
* This method is mainly an alternative to the delegate system introduced
|
||||||
|
* with Growl 0.6. Without a delegate, you cannot receive callbacks such as
|
||||||
|
* <code>-growlIsReady</code> (since they are sent to the delegate). You can,
|
||||||
|
* however, set a delegate after registering without one.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
*/
|
||||||
|
+ (BOOL) registerWithDictionary:(NSDictionary *)regDict;
|
||||||
|
|
||||||
|
/*! @method reregisterGrowlNotifications
|
||||||
|
* @abstract Reregister the notifications for this application.
|
||||||
|
* @discussion This method does not normally need to be called. If your
|
||||||
|
* application changes what notifications it is registering with Growl, call
|
||||||
|
* this method to have the Growl delegate's
|
||||||
|
* <code>-registrationDictionaryForGrowl</code> method called again and the
|
||||||
|
* Growl registration information updated.
|
||||||
|
*
|
||||||
|
* This method is now implemented using <code>-registerWithDictionary:</code>.
|
||||||
|
*/
|
||||||
|
+ (void) reregisterGrowlNotifications;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @method setWillRegisterWhenGrowlIsReady:
|
||||||
|
* @abstract Tells GrowlApplicationBridge to register with Growl when Growl
|
||||||
|
* launches (or not).
|
||||||
|
* @discussion When Growl has started listening for notifications, it posts a
|
||||||
|
* <code>GROWL_IS_READY</code> notification on the Distributed Notification
|
||||||
|
* Center. GrowlApplicationBridge listens for this notification, using it to
|
||||||
|
* perform various tasks (such as calling your delegate's
|
||||||
|
* <code>-growlIsReady</code> method, if it has one). If this method is
|
||||||
|
* called with <code>YES</code>, one of those tasks will be to reregister
|
||||||
|
* with Growl (in the manner of <code>-reregisterGrowlNotifications</code>).
|
||||||
|
*
|
||||||
|
* This attribute is automatically set back to <code>NO</code> (the default)
|
||||||
|
* after every <code>GROWL_IS_READY</code> notification.
|
||||||
|
* @param flag <code>YES</code> if you want GrowlApplicationBridge to register with
|
||||||
|
* Growl when next it is ready; <code>NO</code> if not.
|
||||||
|
*/
|
||||||
|
+ (void) setWillRegisterWhenGrowlIsReady:(BOOL)flag;
|
||||||
|
/*! @method willRegisterWhenGrowlIsReady
|
||||||
|
* @abstract Reports whether GrowlApplicationBridge will register with Growl
|
||||||
|
* when Growl next launches.
|
||||||
|
* @result <code>YES</code> if GrowlApplicationBridge will register with Growl
|
||||||
|
* when next it posts GROWL_IS_READY; <code>NO</code> if not.
|
||||||
|
*/
|
||||||
|
+ (BOOL) willRegisterWhenGrowlIsReady;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @method registrationDictionaryFromDelegate
|
||||||
|
* @abstract Asks the delegate for a registration dictionary.
|
||||||
|
* @discussion If no delegate is set, or if the delegate's
|
||||||
|
* <code>-registrationDictionaryForGrowl</code> method returns
|
||||||
|
* <code>nil</code>, this method returns <code>nil</code>.
|
||||||
|
*
|
||||||
|
* This method does not attempt to clean up the dictionary in any way - for
|
||||||
|
* example, if it is missing the <code>GROWL_APP_NAME</code> key, the result
|
||||||
|
* will be missing it too. Use <code>+[GrowlApplicationBridge
|
||||||
|
* registrationDictionaryByFillingInDictionary:]</code> or
|
||||||
|
* <code>+[GrowlApplicationBridge
|
||||||
|
* registrationDictionaryByFillingInDictionary:restrictToKeys:]</code> to try
|
||||||
|
* to fill in missing keys.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) registrationDictionaryFromDelegate;
|
||||||
|
|
||||||
|
/*! @method registrationDictionaryFromBundle:
|
||||||
|
* @abstract Looks in a bundle for a registration dictionary.
|
||||||
|
* @discussion This method looks in a bundle for an auto-discoverable
|
||||||
|
* registration dictionary file using <code>-[NSBundle
|
||||||
|
* pathForResource:ofType:]</code>. If it finds one, it loads the file using
|
||||||
|
* <code>+[NSDictionary dictionaryWithContentsOfFile:]</code> and returns the
|
||||||
|
* result.
|
||||||
|
*
|
||||||
|
* If you pass <code>nil</code> as the bundle, the main bundle is examined.
|
||||||
|
*
|
||||||
|
* This method does not attempt to clean up the dictionary in any way - for
|
||||||
|
* example, if it is missing the <code>GROWL_APP_NAME</code> key, the result
|
||||||
|
* will be missing it too. Use <code>+[GrowlApplicationBridge
|
||||||
|
* registrationDictionaryByFillingInDictionary:]</code> or
|
||||||
|
* <code>+[GrowlApplicationBridge
|
||||||
|
* registrationDictionaryByFillingInDictionary:restrictToKeys:]</code> to try
|
||||||
|
* to fill in missing keys.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) registrationDictionaryFromBundle:(NSBundle *)bundle;
|
||||||
|
|
||||||
|
/*! @method bestRegistrationDictionary
|
||||||
|
* @abstract Obtains a registration dictionary, filled out to the best of
|
||||||
|
* GrowlApplicationBridge's knowledge.
|
||||||
|
* @discussion This method creates a registration dictionary as best
|
||||||
|
* GrowlApplicationBridge knows how.
|
||||||
|
*
|
||||||
|
* First, GrowlApplicationBridge contacts the Growl delegate (if there is
|
||||||
|
* one) and gets the registration dictionary from that. If no such dictionary
|
||||||
|
* was obtained, GrowlApplicationBridge looks in your application's main
|
||||||
|
* bundle for an auto-discoverable registration dictionary file. If that
|
||||||
|
* doesn't exist either, this method returns <code>nil</code>.
|
||||||
|
*
|
||||||
|
* Second, GrowlApplicationBridge calls
|
||||||
|
* <code>+registrationDictionaryByFillingInDictionary:</code> with whatever
|
||||||
|
* dictionary was obtained. The result of that method is the result of this
|
||||||
|
* method.
|
||||||
|
*
|
||||||
|
* GrowlApplicationBridge uses this method when you call
|
||||||
|
* <code>+setGrowlDelegate:</code>, or when you call
|
||||||
|
* <code>+registerWithDictionary:</code> with <code>nil</code>.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) bestRegistrationDictionary;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @method registrationDictionaryByFillingInDictionary:
|
||||||
|
* @abstract Tries to fill in missing keys in a registration dictionary.
|
||||||
|
* @discussion This method examines the passed-in dictionary for missing keys,
|
||||||
|
* and tries to work out correct values for them. As of 0.7, it uses:
|
||||||
|
*
|
||||||
|
* Key Value
|
||||||
|
* --- -----
|
||||||
|
* <code>GROWL_APP_NAME</code> <code>CFBundleExecutableName</code>
|
||||||
|
* <code>GROWL_APP_ICON</code> The icon of the application.
|
||||||
|
* <code>GROWL_APP_LOCATION</code> The location of the application.
|
||||||
|
* <code>GROWL_NOTIFICATIONS_DEFAULT</code> <code>GROWL_NOTIFICATIONS_ALL</code>
|
||||||
|
*
|
||||||
|
* Keys are only filled in if missing; if a key is present in the dictionary,
|
||||||
|
* its value will not be changed.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @param regDict The dictionary to fill in.
|
||||||
|
* @result The dictionary with the keys filled in. This is an autoreleased
|
||||||
|
* copy of <code>regDict</code>.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) registrationDictionaryByFillingInDictionary:(NSDictionary *)regDict;
|
||||||
|
/*! @method registrationDictionaryByFillingInDictionary:restrictToKeys:
|
||||||
|
* @abstract Tries to fill in missing keys in a registration dictionary.
|
||||||
|
* @discussion This method examines the passed-in dictionary for missing keys,
|
||||||
|
* and tries to work out correct values for them. As of 0.7, it uses:
|
||||||
|
*
|
||||||
|
* Key Value
|
||||||
|
* --- -----
|
||||||
|
* <code>GROWL_APP_NAME</code> <code>CFBundleExecutableName</code>
|
||||||
|
* <code>GROWL_APP_ICON</code> The icon of the application.
|
||||||
|
* <code>GROWL_APP_LOCATION</code> The location of the application.
|
||||||
|
* <code>GROWL_NOTIFICATIONS_DEFAULT</code> <code>GROWL_NOTIFICATIONS_ALL</code>
|
||||||
|
*
|
||||||
|
* Only those keys that are listed in <code>keys</code> will be filled in.
|
||||||
|
* Other missing keys are ignored. Also, keys are only filled in if missing;
|
||||||
|
* if a key is present in the dictionary, its value will not be changed.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @param regDict The dictionary to fill in.
|
||||||
|
* @param keys The keys to fill in. If <code>nil</code>, any missing keys are filled in.
|
||||||
|
* @result The dictionary with the keys filled in. This is an autoreleased
|
||||||
|
* copy of <code>regDict</code>.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) registrationDictionaryByFillingInDictionary:(NSDictionary *)regDict restrictToKeys:(NSSet *)keys;
|
||||||
|
|
||||||
|
/*! @brief Tries to fill in missing keys in a notification dictionary.
|
||||||
|
* @param notifDict The dictionary to fill in.
|
||||||
|
* @return The dictionary with the keys filled in. This will be a separate instance from \a notifDict.
|
||||||
|
* @discussion This function examines the \a notifDict for missing keys, and
|
||||||
|
* tries to get them from the last known registration dictionary. As of 1.1,
|
||||||
|
* the keys that it will look for are:
|
||||||
|
*
|
||||||
|
* \li <code>GROWL_APP_NAME</code>
|
||||||
|
* \li <code>GROWL_APP_ICON</code>
|
||||||
|
*
|
||||||
|
* @since Growl.framework 1.1
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) notificationDictionaryByFillingInDictionary:(NSDictionary *)regDict;
|
||||||
|
|
||||||
|
+ (NSDictionary *) frameworkInfoDictionary;
|
||||||
|
@end
|
||||||
|
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @protocol GrowlApplicationBridgeDelegate
|
||||||
|
* @abstract Required protocol for the Growl delegate.
|
||||||
|
* @discussion The methods in this protocol are required and are called
|
||||||
|
* automatically as needed by GrowlApplicationBridge. See
|
||||||
|
* <code>+[GrowlApplicationBridge setGrowlDelegate:]</code>.
|
||||||
|
* See also <code>GrowlApplicationBridgeDelegate_InformalProtocol</code>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
@protocol GrowlApplicationBridgeDelegate
|
||||||
|
|
||||||
|
// -registrationDictionaryForGrowl has moved to the informal protocol as of 0.7.
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @category NSObject(GrowlApplicationBridgeDelegate_InformalProtocol)
|
||||||
|
* @abstract Methods which may be optionally implemented by the GrowlDelegate.
|
||||||
|
* @discussion The methods in this informal protocol will only be called if implemented by the delegate.
|
||||||
|
*/
|
||||||
|
@interface NSObject (GrowlApplicationBridgeDelegate_InformalProtocol)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method registrationDictionaryForGrowl
|
||||||
|
* @abstract Return the dictionary used to register this application with Growl.
|
||||||
|
* @discussion The returned dictionary gives Growl the complete list of
|
||||||
|
* notifications this application will ever send, and it also specifies which
|
||||||
|
* notifications should be enabled by default. Each is specified by an array
|
||||||
|
* of <code>NSString</code> objects.
|
||||||
|
*
|
||||||
|
* For most applications, these two arrays can be the same (if all sent
|
||||||
|
* notifications should be displayed by default).
|
||||||
|
*
|
||||||
|
* The <code>NSString</code> objects of these arrays will correspond to the
|
||||||
|
* <code>notificationName:</code> parameter passed in
|
||||||
|
* <code>+[GrowlApplicationBridge
|
||||||
|
* notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:]</code> calls.
|
||||||
|
*
|
||||||
|
* The dictionary should have the required key object pairs:
|
||||||
|
* key: GROWL_NOTIFICATIONS_ALL object: <code>NSArray</code> of <code>NSString</code> objects
|
||||||
|
* key: GROWL_NOTIFICATIONS_DEFAULT object: <code>NSArray</code> of <code>NSString</code> objects
|
||||||
|
*
|
||||||
|
* The dictionary may have the following key object pairs:
|
||||||
|
* key: GROWL_NOTIFICATIONS_HUMAN_READABLE_NAMES object: <code>NSDictionary</code> of key: notification name object: human-readable notification name
|
||||||
|
*
|
||||||
|
* You do not need to implement this method if you have an auto-discoverable
|
||||||
|
* plist file in your app bundle. (XXX refer to more information on that)
|
||||||
|
*
|
||||||
|
* @result The <code>NSDictionary</code> to use for registration.
|
||||||
|
*/
|
||||||
|
- (NSDictionary *) registrationDictionaryForGrowl;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method applicationNameForGrowl
|
||||||
|
* @abstract Return the name of this application which will be used for Growl bookkeeping.
|
||||||
|
* @discussion This name is used both internally and in the Growl preferences.
|
||||||
|
*
|
||||||
|
* This should remain stable between different versions and incarnations of
|
||||||
|
* your application.
|
||||||
|
* For example, "SurfWriter" is a good app name, whereas "SurfWriter 2.0" and
|
||||||
|
* "SurfWriter Lite" are not.
|
||||||
|
*
|
||||||
|
* You do not need to implement this method if you are providing the
|
||||||
|
* application name elsewhere, meaning in an auto-discoverable plist file in
|
||||||
|
* your app bundle (XXX refer to more information on that) or in the result
|
||||||
|
* of -registrationDictionaryForGrowl.
|
||||||
|
*
|
||||||
|
* @result The name of the application using Growl.
|
||||||
|
*/
|
||||||
|
- (NSString *) applicationNameForGrowl;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method applicationIconForGrowl
|
||||||
|
* @abstract Return the <code>NSImage</code> to treat as the application icon.
|
||||||
|
* @discussion The delegate may optionally return an <code>NSImage</code>
|
||||||
|
* object to use as the application icon. If this method is not implemented,
|
||||||
|
* {{{-applicationIconDataForGrowl}}} is tried. If that method is not
|
||||||
|
* implemented, the application's own icon is used. Neither method is
|
||||||
|
* generally needed.
|
||||||
|
* @result The <code>NSImage</code> to treat as the application icon.
|
||||||
|
*/
|
||||||
|
- (NSImage *) applicationIconForGrowl;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method applicationIconDataForGrowl
|
||||||
|
* @abstract Return the <code>NSData</code> to treat as the application icon.
|
||||||
|
* @discussion The delegate may optionally return an <code>NSData</code>
|
||||||
|
* object to use as the application icon; if this is not implemented, the
|
||||||
|
* application's own icon is used. This is not generally needed.
|
||||||
|
* @result The <code>NSData</code> to treat as the application icon.
|
||||||
|
* @deprecated In version 1.1, in favor of {{{-applicationIconForGrowl}}}.
|
||||||
|
*/
|
||||||
|
- (NSData *) applicationIconDataForGrowl;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlIsReady
|
||||||
|
* @abstract Informs the delegate that Growl has launched.
|
||||||
|
* @discussion Informs the delegate that Growl (specifically, the
|
||||||
|
* GrowlHelperApp) was launched successfully. The application can take actions
|
||||||
|
* with the knowledge that Growl is installed and functional.
|
||||||
|
*/
|
||||||
|
- (void) growlIsReady;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlNotificationWasClicked:
|
||||||
|
* @abstract Informs the delegate that a Growl notification was clicked.
|
||||||
|
* @discussion Informs the delegate that a Growl notification was clicked. It
|
||||||
|
* is only sent for notifications sent with a non-<code>nil</code>
|
||||||
|
* clickContext, so if you want to receive a message when a notification is
|
||||||
|
* clicked, clickContext must not be <code>nil</code> when calling
|
||||||
|
* <code>+[GrowlApplicationBridge notifyWithTitle: description:notificationName:iconData:priority:isSticky:clickContext:]</code>.
|
||||||
|
* @param clickContext The clickContext passed when displaying the notification originally via +[GrowlApplicationBridge notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:].
|
||||||
|
*/
|
||||||
|
- (void) growlNotificationWasClicked:(id)clickContext;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlNotificationTimedOut:
|
||||||
|
* @abstract Informs the delegate that a Growl notification timed out.
|
||||||
|
* @discussion Informs the delegate that a Growl notification timed out. It
|
||||||
|
* is only sent for notifications sent with a non-<code>nil</code>
|
||||||
|
* clickContext, so if you want to receive a message when a notification is
|
||||||
|
* clicked, clickContext must not be <code>nil</code> when calling
|
||||||
|
* <code>+[GrowlApplicationBridge notifyWithTitle: description:notificationName:iconData:priority:isSticky:clickContext:]</code>.
|
||||||
|
* @param clickContext The clickContext passed when displaying the notification originally via +[GrowlApplicationBridge notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:].
|
||||||
|
*/
|
||||||
|
- (void) growlNotificationTimedOut:(id)clickContext;
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
/*!
|
||||||
|
* @category NSObject(GrowlApplicationBridgeDelegate_Installation_InformalProtocol)
|
||||||
|
* @abstract Methods which may be optionally implemented by the Growl delegate when used with Growl-WithInstaller.framework.
|
||||||
|
* @discussion The methods in this informal protocol will only be called if
|
||||||
|
* implemented by the delegate. They allow greater control of the information
|
||||||
|
* presented to the user when installing or upgrading Growl from within your
|
||||||
|
* application when using Growl-WithInstaller.framework.
|
||||||
|
*/
|
||||||
|
@interface NSObject (GrowlApplicationBridgeDelegate_Installation_InformalProtocol)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlInstallationWindowTitle
|
||||||
|
* @abstract Return the title of the installation window.
|
||||||
|
* @discussion If not implemented, Growl will use a default, localized title.
|
||||||
|
* @result An NSString object to use as the title.
|
||||||
|
*/
|
||||||
|
- (NSString *)growlInstallationWindowTitle;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlUpdateWindowTitle
|
||||||
|
* @abstract Return the title of the upgrade window.
|
||||||
|
* @discussion If not implemented, Growl will use a default, localized title.
|
||||||
|
* @result An NSString object to use as the title.
|
||||||
|
*/
|
||||||
|
- (NSString *)growlUpdateWindowTitle;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlInstallationInformation
|
||||||
|
* @abstract Return the information to display when installing.
|
||||||
|
* @discussion This information may be as long or short as desired (the window
|
||||||
|
* will be sized to fit it). It will be displayed to the user as an
|
||||||
|
* explanation of what Growl is and what it can do in your application. It
|
||||||
|
* should probably note that no download is required to install.
|
||||||
|
*
|
||||||
|
* If this is not implemented, Growl will use a default, localized explanation.
|
||||||
|
* @result An NSAttributedString object to display.
|
||||||
|
*/
|
||||||
|
- (NSAttributedString *)growlInstallationInformation;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlUpdateInformation
|
||||||
|
* @abstract Return the information to display when upgrading.
|
||||||
|
* @discussion This information may be as long or short as desired (the window
|
||||||
|
* will be sized to fit it). It will be displayed to the user as an
|
||||||
|
* explanation that an updated version of Growl is included in your
|
||||||
|
* application and no download is required.
|
||||||
|
*
|
||||||
|
* If this is not implemented, Growl will use a default, localized explanation.
|
||||||
|
* @result An NSAttributedString object to display.
|
||||||
|
*/
|
||||||
|
- (NSAttributedString *)growlUpdateInformation;
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
//private
|
||||||
|
@interface GrowlApplicationBridge (GrowlInstallationPrompt_private)
|
||||||
|
+ (void) _userChoseNotToInstallGrowl;
|
||||||
|
@end
|
||||||
|
|
||||||
|
#endif /* __GrowlApplicationBridge_h__ */
|
348
Growl.framework/Versions/A/Headers/GrowlDefines.h
Normal file
348
Growl.framework/Versions/A/Headers/GrowlDefines.h
Normal file
|
@ -0,0 +1,348 @@
|
||||||
|
//
|
||||||
|
// GrowlDefines.h
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef _GROWLDEFINES_H
|
||||||
|
#define _GROWLDEFINES_H
|
||||||
|
|
||||||
|
#ifdef __OBJC__
|
||||||
|
#define XSTR(x) (@x)
|
||||||
|
#define STRING_TYPE NSString *
|
||||||
|
#else
|
||||||
|
#define XSTR CFSTR
|
||||||
|
#define STRING_TYPE CFStringRef
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*! @header GrowlDefines.h
|
||||||
|
* @abstract Defines all the notification keys.
|
||||||
|
* @discussion Defines all the keys used for registration with Growl and for
|
||||||
|
* Growl notifications.
|
||||||
|
*
|
||||||
|
* Most applications should use the functions or methods of Growl.framework
|
||||||
|
* instead of posting notifications such as those described here.
|
||||||
|
* @updated 2004-01-25
|
||||||
|
*/
|
||||||
|
|
||||||
|
// UserInfo Keys for Registration
|
||||||
|
#pragma mark UserInfo Keys for Registration
|
||||||
|
|
||||||
|
/*! @group Registration userInfo keys */
|
||||||
|
/* @abstract Keys for the userInfo dictionary of a GROWL_APP_REGISTRATION distributed notification.
|
||||||
|
* @discussion The values of these keys describe the application and the
|
||||||
|
* notifications it may post.
|
||||||
|
*
|
||||||
|
* Your application must register with Growl before it can post Growl
|
||||||
|
* notifications (and have them not be ignored). However, as of Growl 0.6,
|
||||||
|
* posting GROWL_APP_REGISTRATION notifications directly is no longer the
|
||||||
|
* preferred way to register your application. Your application should instead
|
||||||
|
* use Growl.framework's delegate system.
|
||||||
|
* See +[GrowlApplicationBridge setGrowlDelegate:] or Growl_SetDelegate for
|
||||||
|
* more information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! @defined GROWL_APP_NAME
|
||||||
|
* @abstract The name of your application.
|
||||||
|
* @discussion The name of your application. This should remain stable between
|
||||||
|
* different versions and incarnations of your application.
|
||||||
|
* For example, "SurfWriter" is a good app name, whereas "SurfWriter 2.0" and
|
||||||
|
* "SurfWriter Lite" are not.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_NAME XSTR("ApplicationName")
|
||||||
|
/*! @defined GROWL_APP_ID
|
||||||
|
* @abstract The bundle identifier of your application.
|
||||||
|
* @discussion The bundle identifier of your application. This key should
|
||||||
|
* be unique for your application while there may be several applications
|
||||||
|
* with the same GROWL_APP_NAME.
|
||||||
|
* This key is optional.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_ID XSTR("ApplicationId")
|
||||||
|
/*! @defined GROWL_APP_ICON
|
||||||
|
* @abstract The image data for your application's icon.
|
||||||
|
* @discussion Image data representing your application's icon. This may be
|
||||||
|
* superimposed on a notification icon as a badge, used as the notification
|
||||||
|
* icon when a notification-specific icon is not supplied, or ignored
|
||||||
|
* altogether, depending on the display. Must be in a format supported by
|
||||||
|
* NSImage, such as TIFF, PNG, GIF, JPEG, BMP, PICT, or PDF.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_ICON XSTR("ApplicationIcon")
|
||||||
|
/*! @defined GROWL_NOTIFICATIONS_DEFAULT
|
||||||
|
* @abstract The array of notifications to turn on by default.
|
||||||
|
* @discussion These are the names of the notifications that should be enabled
|
||||||
|
* by default when your application registers for the first time. If your
|
||||||
|
* application reregisters, Growl will look here for any new notification
|
||||||
|
* names found in GROWL_NOTIFICATIONS_ALL, but ignore any others.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATIONS_DEFAULT XSTR("DefaultNotifications")
|
||||||
|
/*! @defined GROWL_NOTIFICATIONS_ALL
|
||||||
|
* @abstract The array of all notifications your application can send.
|
||||||
|
* @discussion These are the names of all of the notifications that your
|
||||||
|
* application may post. See GROWL_NOTIFICATION_NAME for a discussion of good
|
||||||
|
* notification names.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATIONS_ALL XSTR("AllNotifications")
|
||||||
|
/*! @defined GROWL_NOTIFICATIONS_HUMAN_READABLE_DESCRIPTIONS
|
||||||
|
* @abstract A dictionary of human-readable names for your notifications.
|
||||||
|
* @discussion By default, the Growl UI will display notifications by the names given in GROWL_NOTIFICATIONS_ALL
|
||||||
|
* which correspond to the GROWL_NOTIFICATION_NAME. This dictionary specifies the human-readable name to display.
|
||||||
|
* The keys of the dictionary are GROWL_NOTIFICATION_NAME strings; the objects are the human-readable versions.
|
||||||
|
* For any GROWL_NOTIFICATION_NAME not specific in this dictionary, the GROWL_NOTIFICATION_NAME will be displayed.
|
||||||
|
*
|
||||||
|
* This key is optional.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATIONS_HUMAN_READABLE_NAMES XSTR("HumanReadableNames")
|
||||||
|
/*! @defined GROWL_NOTIFICATIONS_DESCRIPTIONS
|
||||||
|
* @abstract A dictionary of descriptions of _when_ each notification occurs
|
||||||
|
* @discussion This is an NSDictionary whose keys are GROWL_NOTIFICATION_NAME strings and whose objects are
|
||||||
|
* descriptions of _when_ each notification occurs, such as "You received a new mail message" or
|
||||||
|
* "A file finished downloading".
|
||||||
|
*
|
||||||
|
* This key is optional.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATIONS_DESCRIPTIONS XSTR("NotificationDescriptions")
|
||||||
|
|
||||||
|
/*! @defined GROWL_TICKET_VERSION
|
||||||
|
* @abstract The version of your registration ticket.
|
||||||
|
* @discussion Include this key in a ticket plist file that you put in your
|
||||||
|
* application bundle for auto-discovery. The current ticket version is 1.
|
||||||
|
*/
|
||||||
|
#define GROWL_TICKET_VERSION XSTR("TicketVersion")
|
||||||
|
// UserInfo Keys for Notifications
|
||||||
|
#pragma mark UserInfo Keys for Notifications
|
||||||
|
|
||||||
|
/*! @group Notification userInfo keys */
|
||||||
|
/* @abstract Keys for the userInfo dictionary of a GROWL_NOTIFICATION distributed notification.
|
||||||
|
* @discussion The values of these keys describe the content of a Growl
|
||||||
|
* notification.
|
||||||
|
*
|
||||||
|
* Not all of these keys are supported by all displays. Only the name, title,
|
||||||
|
* and description of a notification are universal. Most of the built-in
|
||||||
|
* displays do support all of these keys, and most other visual displays
|
||||||
|
* probably will also. But, as of 0.6, the Log, MailMe, and Speech displays
|
||||||
|
* support only textual data.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! @defined GROWL_NOTIFICATION_NAME
|
||||||
|
* @abstract The name of the notification.
|
||||||
|
* @discussion The name of the notification. Note that if you do not define
|
||||||
|
* GROWL_NOTIFICATIONS_HUMAN_READABLE_NAMES when registering your ticket originally this name
|
||||||
|
* will the one displayed within the Growl preference pane and should be human-readable.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_NAME XSTR("NotificationName")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_TITLE
|
||||||
|
* @abstract The title to display in the notification.
|
||||||
|
* @discussion The title of the notification. Should be very brief.
|
||||||
|
* The title usually says what happened, e.g. "Download complete".
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_TITLE XSTR("NotificationTitle")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_DESCRIPTION
|
||||||
|
* @abstract The description to display in the notification.
|
||||||
|
* @discussion The description should be longer and more verbose than the title.
|
||||||
|
* The description usually tells the subject of the action,
|
||||||
|
* e.g. "Growl-0.6.dmg downloaded in 5.02 minutes".
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_DESCRIPTION XSTR("NotificationDescription")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_ICON
|
||||||
|
* @discussion Image data for the notification icon. Must be in a format
|
||||||
|
* supported by NSImage, such as TIFF, PNG, GIF, JPEG, BMP, PICT, or PDF.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_ICON XSTR("NotificationIcon")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_APP_ICON
|
||||||
|
* @discussion Image data for the application icon, in case GROWL_APP_ICON does
|
||||||
|
* not apply for some reason. Must be in a format supported by NSImage, such
|
||||||
|
* as TIFF, PNG, GIF, JPEG, BMP, PICT, or PDF.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_APP_ICON XSTR("NotificationAppIcon")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_PRIORITY
|
||||||
|
* @discussion The priority of the notification as an integer number from
|
||||||
|
* -2 to +2 (+2 being highest).
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_PRIORITY XSTR("NotificationPriority")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_STICKY
|
||||||
|
* @discussion A Boolean number controlling whether the notification is sticky.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_STICKY XSTR("NotificationSticky")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_CLICK_CONTEXT
|
||||||
|
* @abstract Identifies which notification was clicked.
|
||||||
|
* @discussion An identifier for the notification for clicking purposes.
|
||||||
|
*
|
||||||
|
* This will be passed back to the application when the notification is
|
||||||
|
* clicked. It must be plist-encodable (a data, dictionary, array, number, or
|
||||||
|
* string object), and it should be unique for each notification you post.
|
||||||
|
* A good click context would be a UUID string returned by NSProcessInfo or
|
||||||
|
* CFUUID.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_CLICK_CONTEXT XSTR("NotificationClickContext")
|
||||||
|
|
||||||
|
/*! @defined GROWL_DISPLAY_PLUGIN
|
||||||
|
* @discussion The name of a display plugin which should be used for this notification.
|
||||||
|
* Optional. If this key is not set or the specified display plugin does not
|
||||||
|
* exist, the display plugin stored in the application ticket is used. This key
|
||||||
|
* allows applications to use different default display plugins for their
|
||||||
|
* notifications. The user can still override those settings in the preference
|
||||||
|
* pane.
|
||||||
|
*/
|
||||||
|
#define GROWL_DISPLAY_PLUGIN XSTR("NotificationDisplayPlugin")
|
||||||
|
|
||||||
|
/*! @defined GROWL_NOTIFICATION_IDENTIFIER
|
||||||
|
* @abstract An identifier for the notification for coalescing purposes.
|
||||||
|
* Notifications with the same identifier fall into the same class; only
|
||||||
|
* the last notification of a class is displayed on the screen. If a
|
||||||
|
* notification of the same class is currently being displayed, it is
|
||||||
|
* replaced by this notification.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_IDENTIFIER XSTR("GrowlNotificationIdentifier")
|
||||||
|
|
||||||
|
/*! @defined GROWL_APP_PID
|
||||||
|
* @abstract The process identifier of the process which sends this
|
||||||
|
* notification. If this field is set, the application will only receive
|
||||||
|
* clicked and timed out notifications which originate from this process.
|
||||||
|
*
|
||||||
|
* Optional.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_PID XSTR("ApplicationPID")
|
||||||
|
|
||||||
|
/*! @defined GROWL_NOTIFICATION_PROGRESS
|
||||||
|
* @abstract If this key is set, it should contain a double value wrapped
|
||||||
|
* in a NSNumber which describes some sort of progress (from 0.0 to 100.0).
|
||||||
|
* If this is key is not set, no progress bar is shown.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_PROGRESS XSTR("NotificationProgress")
|
||||||
|
|
||||||
|
// Notifications
|
||||||
|
#pragma mark Notifications
|
||||||
|
|
||||||
|
/*! @group Notification names */
|
||||||
|
/* @abstract Names of distributed notifications used by Growl.
|
||||||
|
* @discussion These are notifications used by applications (directly or
|
||||||
|
* indirectly) to interact with Growl, and by Growl for interaction between
|
||||||
|
* its components.
|
||||||
|
*
|
||||||
|
* Most of these should no longer be used in Growl 0.6 and later, in favor of
|
||||||
|
* Growl.framework's GrowlApplicationBridge APIs.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! @defined GROWL_APP_REGISTRATION
|
||||||
|
* @abstract The distributed notification for registering your application.
|
||||||
|
* @discussion This is the name of the distributed notification that can be
|
||||||
|
* used to register applications with Growl.
|
||||||
|
*
|
||||||
|
* The userInfo dictionary for this notification can contain these keys:
|
||||||
|
* <ul>
|
||||||
|
* <li>GROWL_APP_NAME</li>
|
||||||
|
* <li>GROWL_APP_ICON</li>
|
||||||
|
* <li>GROWL_NOTIFICATIONS_ALL</li>
|
||||||
|
* <li>GROWL_NOTIFICATIONS_DEFAULT</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* No longer recommended as of Growl 0.6. An alternate method of registering
|
||||||
|
* is to use Growl.framework's delegate system.
|
||||||
|
* See +[GrowlApplicationBridge setGrowlDelegate:] or Growl_SetDelegate for
|
||||||
|
* more information.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_REGISTRATION XSTR("GrowlApplicationRegistrationNotification")
|
||||||
|
/*! @defined GROWL_APP_REGISTRATION_CONF
|
||||||
|
* @abstract The distributed notification for confirming registration.
|
||||||
|
* @discussion The name of the distributed notification sent to confirm the
|
||||||
|
* registration. Used by the Growl preference pane. Your application probably
|
||||||
|
* does not need to use this notification.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_REGISTRATION_CONF XSTR("GrowlApplicationRegistrationConfirmationNotification")
|
||||||
|
/*! @defined GROWL_NOTIFICATION
|
||||||
|
* @abstract The distributed notification for Growl notifications.
|
||||||
|
* @discussion This is what it all comes down to. This is the name of the
|
||||||
|
* distributed notification that your application posts to actually send a
|
||||||
|
* Growl notification.
|
||||||
|
*
|
||||||
|
* The userInfo dictionary for this notification can contain these keys:
|
||||||
|
* <ul>
|
||||||
|
* <li>GROWL_NOTIFICATION_NAME (required)</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_TITLE (required)</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_DESCRIPTION (required)</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_ICON</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_APP_ICON</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_PRIORITY</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_STICKY</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_CLICK_CONTEXT</li>
|
||||||
|
* <li>GROWL_APP_NAME (required)</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* No longer recommended as of Growl 0.6. Three alternate methods of posting
|
||||||
|
* notifications are +[GrowlApplicationBridge notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:],
|
||||||
|
* Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext, and
|
||||||
|
* Growl_PostNotification.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION XSTR("GrowlNotification")
|
||||||
|
/*! @defined GROWL_SHUTDOWN
|
||||||
|
* @abstract The distributed notification name that tells Growl to shutdown.
|
||||||
|
* @discussion The Growl preference pane posts this notification when the
|
||||||
|
* "Stop Growl" button is clicked.
|
||||||
|
*/
|
||||||
|
#define GROWL_SHUTDOWN XSTR("GrowlShutdown")
|
||||||
|
/*! @defined GROWL_PING
|
||||||
|
* @abstract A distributed notification to check whether Growl is running.
|
||||||
|
* @discussion This is used by the Growl preference pane. If it receives a
|
||||||
|
* GROWL_PONG, the preference pane takes this to mean that Growl is running.
|
||||||
|
*/
|
||||||
|
#define GROWL_PING XSTR("Honey, Mind Taking Out The Trash")
|
||||||
|
/*! @defined GROWL_PONG
|
||||||
|
* @abstract The distributed notification sent in reply to GROWL_PING.
|
||||||
|
* @discussion GrowlHelperApp posts this in reply to GROWL_PING.
|
||||||
|
*/
|
||||||
|
#define GROWL_PONG XSTR("What Do You Want From Me, Woman")
|
||||||
|
/*! @defined GROWL_IS_READY
|
||||||
|
* @abstract The distributed notification sent when Growl starts up.
|
||||||
|
* @discussion GrowlHelperApp posts this when it has begin listening on all of
|
||||||
|
* its sources for new notifications. GrowlApplicationBridge (in
|
||||||
|
* Growl.framework), upon receiving this notification, reregisters using the
|
||||||
|
* registration dictionary supplied by its delegate.
|
||||||
|
*/
|
||||||
|
#define GROWL_IS_READY XSTR("Lend Me Some Sugar; I Am Your Neighbor!")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_CLICKED
|
||||||
|
* @abstract The distributed notification sent when a supported notification is clicked.
|
||||||
|
* @discussion When a Growl notification with a click context is clicked on by
|
||||||
|
* the user, Growl posts this distributed notification.
|
||||||
|
* The GrowlApplicationBridge responds to this notification by calling a
|
||||||
|
* callback in its delegate.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_CLICKED XSTR("GrowlClicked!")
|
||||||
|
#define GROWL_NOTIFICATION_TIMED_OUT XSTR("GrowlTimedOut!")
|
||||||
|
|
||||||
|
/*! @group Other symbols */
|
||||||
|
/* Symbols which don't fit into any of the other categories. */
|
||||||
|
|
||||||
|
/*! @defined GROWL_KEY_CLICKED_CONTEXT
|
||||||
|
* @abstract Used internally as the key for the clickedContext passed over DNC.
|
||||||
|
* @discussion This key is used in GROWL_NOTIFICATION_CLICKED, and contains the
|
||||||
|
* click context that was supplied in the original notification.
|
||||||
|
*/
|
||||||
|
#define GROWL_KEY_CLICKED_CONTEXT XSTR("ClickedContext")
|
||||||
|
/*! @defined GROWL_REG_DICT_EXTENSION
|
||||||
|
* @abstract The filename extension for registration dictionaries.
|
||||||
|
* @discussion The GrowlApplicationBridge in Growl.framework registers with
|
||||||
|
* Growl by creating a file with the extension of .(GROWL_REG_DICT_EXTENSION)
|
||||||
|
* and opening it in the GrowlHelperApp. This happens whether or not Growl is
|
||||||
|
* running; if it was stopped, it quits immediately without listening for
|
||||||
|
* notifications.
|
||||||
|
*/
|
||||||
|
#define GROWL_REG_DICT_EXTENSION XSTR("growlRegDict")
|
||||||
|
|
||||||
|
|
||||||
|
#define GROWL_POSITION_PREFERENCE_KEY @"GrowlSelectedPosition"
|
||||||
|
|
||||||
|
#endif //ndef _GROWLDEFINES_H
|
24
Growl.framework/Versions/A/Resources/Info.plist
Normal file
24
Growl.framework/Versions/A/Resources/Info.plist
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>CFBundleDevelopmentRegion</key>
|
||||||
|
<string>English</string>
|
||||||
|
<key>CFBundleExecutable</key>
|
||||||
|
<string>Growl</string>
|
||||||
|
<key>CFBundleIdentifier</key>
|
||||||
|
<string>com.growl.growlframework</string>
|
||||||
|
<key>CFBundleInfoDictionaryVersion</key>
|
||||||
|
<string>6.0</string>
|
||||||
|
<key>CFBundlePackageType</key>
|
||||||
|
<string>FMWK</string>
|
||||||
|
<key>CFBundleShortVersionString</key>
|
||||||
|
<string>1.2.1</string>
|
||||||
|
<key>CFBundleSignature</key>
|
||||||
|
<string>GRRR</string>
|
||||||
|
<key>CFBundleVersion</key>
|
||||||
|
<string>1.2.1</string>
|
||||||
|
<key>NSPrincipalClass</key>
|
||||||
|
<string>GrowlApplicationBridge</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
1
Growl.framework/Versions/Current
Symbolic link
1
Growl.framework/Versions/Current
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
A
|
BIN
bigicon.png
Normal file
BIN
bigicon.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 17 KiB |
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/categories.pbxbtree
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/categories.pbxbtree
Normal file
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/cdecls.pbxbtree
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/cdecls.pbxbtree
Normal file
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/decls.pbxbtree
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/decls.pbxbtree
Normal file
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/files.pbxbtree
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/files.pbxbtree
Normal file
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/imports.pbxbtree
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/imports.pbxbtree
Normal file
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/pbxindex.header
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/pbxindex.header
Normal file
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/protocols.pbxbtree
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/protocols.pbxbtree
Normal file
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/refs.pbxbtree
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/refs.pbxbtree
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/subclasses.pbxbtree
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/subclasses.pbxbtree
Normal file
Binary file not shown.
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/symbols0.pbxsymbols
Normal file
BIN
build/CIDGrowl.build/CIDGrowl.pbxindex/symbols0.pbxsymbols
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
37
build/CIDGrowl.build/Debug/CIDGrowl.build/CIDGrowl.dep
Normal file
37
build/CIDGrowl.build/Debug/CIDGrowl.build/CIDGrowl.dep
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
ac085e7c8160f8b24b8bd3f11668f787 4bbda0ea8d50e84fc6f679a8d8f3659a ffffffffffffffffffffffffffffffff 102 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app
|
||||||
|
000000004c47f66c000000000002d347 5d3e4daa9ab8adeb3b22f65de29c4fa7 ffffffffffffffffffffffffffffffff 34145 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/MainMenu.nib
|
||||||
|
3dba052bc3fa63d5c13072c806cc54ce e8d9e12ad28dc1584b88ba95c43a81ec ffffffffffffffffffffffffffffffff 38548 /Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/CIDGrowlAppDelegate.o
|
||||||
|
3dba052bc3592a9ac13072c806ccf774 c71150ef9f938dd05d69017ce122c6c4 ffffffffffffffffffffffffffffffff 4984 /Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/main.o
|
||||||
|
000000004c364a1000000000000000cc d8b3372cf2013f0fe4c204c58129b942 ffffffffffffffffffffffffffffffff 204 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Frameworks/Growl.framework
|
||||||
|
2fc8b1c5006012ad16e1bbe9251bb524 9c8ef030e0f5952b68f56907eaee5c10 ffffffffffffffffffffffffffffffff 18144 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/MacOS/CIDGrowl
|
||||||
|
000000000cfb1f340000000000000176 3dba052bc3592a9ac13072c806ccf71c ffffffffffffffffffffffffffffffff 54265616 /var/folders/H+/H+mA7h1MEoG+kwyM3p-63k+++TI/-Caches-/com.apple.Xcode.501/SharedPrecompiledHeaders/CIDGrowl_Prefix-ghfsbbsdinggdegjnzntxboypiwz/CIDGrowl_Prefix.pch.gch
|
||||||
|
000000004c3fb55c0000000000106afc f0d47a07c7f38e2cf66aaadde2a1c313 ffffffffffffffffffffffffffffffff 1075964 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/growlicon.tif
|
||||||
|
00000000000000000000000000000000 bd93e654c9627570b5e7395ecb05caf6 ffffffffffffffffffffffffffffffff 113806 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/CIDGrowlIcon.icns
|
||||||
|
00000000000000000000000000000000 e8f33ca49e34da27251d321d81d5f0cb ffffffffffffffffffffffffffffffff 17809 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/bigicon.png
|
||||||
|
000000004c3fb55c00000000000065e4 dc4b69e38ba969ae73bcf10bbb46a996 ffffffffffffffffffffffffffffffff 26084 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/menu22.tif
|
||||||
|
00000000000000000000000000000000 a5689844353c26efdec1b3169e73df0a ffffffffffffffffffffffffffffffff 3218 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/menuic.png
|
||||||
|
000000004c3fb55c000000000000002d c66a6022929c48dd85878896d54d9bca ffffffffffffffffffffffffffffffff 92 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/InfoPlist.strings
|
||||||
|
00000000000000000000000000000000 803e547df9aec217a4159892e2332090 ffffffffffffffffffffffffffffffff 486 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/Growl Registration Ticket.growlRegDict
|
||||||
|
00000000000000000000000000000000 1ead57a68dadab85b232a3dc229d6f80 ffffffffffffffffffffffffffffffff 8 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/PkgInfo
|
||||||
|
00000000000000000000000000000000 1ead57a68dadab85b232a3dc229d6f80 ffffffffffffffffffffffffffffffff 985 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Info.plist
|
||||||
|
000000004c364a1000000000000000cc 8472307d101330654fe1cf9649617691 ffffffffffffffffffffffffffffffff 0 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Frameworks/Growl.i
|
||||||
|
000000004c364a1000000000000000cc eb4ab1db13edbb65240fb05f697a4b51 ffffffffffffffffffffffffffffffff 204 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Frameworks/Growl-WithInstaller.framework
|
||||||
|
000000000cfb1f340000000000000176 f0174932a07ce83f79adab3804ed4a95 ffffffffffffffffffffffffffffffff 0 /var/folders/H+/H+mA7h1MEoG+kwyM3p-63k+++TI/-Caches-/com.apple.Xcode.501/SharedPrecompiledHeaders/CIDGrowl_Prefix-axrgkpgoclrhttahaaapjvfneewh/CIDGrowl_Prefix.pch.gch
|
||||||
|
c508ae9dd254cc919e0c00ccf9d06254 4a6190d87ef9521568234f4ded1b06b0 ffffffffffffffffffffffffffffffff 0 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/CIDGrowlAppDelegate.o
|
||||||
|
c508ae9dd2fe7a4e9e0c00ccf9d0c201 174ae0d2e64e876f9b919001a1d38163 ffffffffffffffffffffffffffffffff 5008 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/main.o
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 102 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 18144 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/MacOS/CIDGrowl
|
||||||
|
000000000cfb1f340000000000000176 c508ae9dd2fe7a4e9e0c00ccf9d0c269 ffffffffffffffffffffffffffffffff 54265616 /var/folders/H+/H+mA7h1MEoG+kwyM3p-63k+++TI/-Caches-/com.apple.Xcode.501/SharedPrecompiledHeaders/CIDGrowl_Prefix-fagvflusvjebaedxxcpkqlosognz/CIDGrowl_Prefix.pch.gch
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 204 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Frameworks/Growl-WithInstaller.framework
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 1075964 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/growlicon.tif
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 113806 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/CIDGrowlIcon.icns
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 17809 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/bigicon.png
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 26084 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/menu22.tif
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 3218 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/menuic.png
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 34536 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/MainMenu.nib
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 92 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/InfoPlist.strings
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 486 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/Growl Registration Ticket.growlRegDict
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 8 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/PkgInfo
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 985 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Info.plist
|
||||||
|
000000000ba021b70000000000000176 5b21c2e8081062bffc9abdbcaa886658 ffffffffffffffffffffffffffffffff 54212368 /var/folders/Zv/Zvjdifw7EH8wlZ8m2iFHzU+++Tg/-Caches-/com.apple.Xcode.507/SharedPrecompiledHeaders/CIDGrowl_Prefix-ezcsekrspebkrlhfumhlqhbyvtuo/CIDGrowl_Prefix.pch.gch
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 0 /var/folders/Zv/Zvjdifw7EH8wlZ8m2iFHzU+++Tg/-Caches-/com.apple.Xcode.507/SharedPrecompiledHeaders/CIDGrowl_Prefix-hcoobokcxyxczfcllvapzzmtkkcq/CIDGrowl_Prefix.pch.gch
|
BIN
build/CIDGrowl.build/Debug/CIDGrowl.build/CIDGrowl.hmap
Normal file
BIN
build/CIDGrowl.build/Debug/CIDGrowl.build/CIDGrowl.hmap
Normal file
Binary file not shown.
36
build/CIDGrowl.build/Debug/CIDGrowl.build/CIDGrowl~.dep
Normal file
36
build/CIDGrowl.build/Debug/CIDGrowl.build/CIDGrowl~.dep
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
000000004c364a1000000000000000cc d8b3372cf2013f0fe4c204c58129b942 ffffffffffffffffffffffffffffffff 204 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Frameworks/Growl.framework
|
||||||
|
3dba052b8f669d72c13072c806cced34 e8d9e12ad28dc1584b88ba95c43a81ec ffffffffffffffffffffffffffffffff 0 /Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/CIDGrowlAppDelegate.o
|
||||||
|
3dba052bc3592a9ac13072c806ccf774 c71150ef9f938dd05d69017ce122c6c4 ffffffffffffffffffffffffffffffff 4984 /Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/main.o
|
||||||
|
000000000cfb1f340000000000000176 3dba052bc3592a9ac13072c806ccf71c ffffffffffffffffffffffffffffffff 54265616 /var/folders/H+/H+mA7h1MEoG+kwyM3p-63k+++TI/-Caches-/com.apple.Xcode.501/SharedPrecompiledHeaders/CIDGrowl_Prefix-ghfsbbsdinggdegjnzntxboypiwz/CIDGrowl_Prefix.pch.gch
|
||||||
|
000000004c3fb55c000000000002c822 5d3e4daa9ab8adeb3b22f65de29c4fa7 ffffffffffffffffffffffffffffffff 34536 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/MainMenu.nib
|
||||||
|
000000004c3fb55c0000000000106afc f0d47a07c7f38e2cf66aaadde2a1c313 ffffffffffffffffffffffffffffffff 1075964 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/growlicon.tif
|
||||||
|
00000000000000000000000000000000 bd93e654c9627570b5e7395ecb05caf6 ffffffffffffffffffffffffffffffff 113806 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/CIDGrowlIcon.icns
|
||||||
|
00000000000000000000000000000000 e8f33ca49e34da27251d321d81d5f0cb ffffffffffffffffffffffffffffffff 17809 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/bigicon.png
|
||||||
|
000000004c3fb55c00000000000065e4 dc4b69e38ba969ae73bcf10bbb46a996 ffffffffffffffffffffffffffffffff 26084 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/menu22.tif
|
||||||
|
00000000000000000000000000000000 a5689844353c26efdec1b3169e73df0a ffffffffffffffffffffffffffffffff 3218 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/menuic.png
|
||||||
|
000000004c3fb55c000000000000002d c66a6022929c48dd85878896d54d9bca ffffffffffffffffffffffffffffffff 92 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/InfoPlist.strings
|
||||||
|
00000000000000000000000000000000 803e547df9aec217a4159892e2332090 ffffffffffffffffffffffffffffffff 486 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/Growl Registration Ticket.growlRegDict
|
||||||
|
00000000000000000000000000000000 1ead57a68dadab85b232a3dc229d6f80 ffffffffffffffffffffffffffffffff 985 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Info.plist
|
||||||
|
00000000000000000000000000000000 1ead57a68dadab85b232a3dc229d6f80 ffffffffffffffffffffffffffffffff 8 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/PkgInfo
|
||||||
|
4b551bc222ca4b59fda84bb924e74021 4bbda0ea8d50e84fc6f679a8d8f3659a ffffffffffffffffffffffffffffffff 0 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app
|
||||||
|
2fc8b1c50060143e16e1bbe9251e4a84 482a3379a2cbe7091e1b45d53037fd60 ffffffffffffffffffffffffffffffff 0 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/MacOS/CIDGrowl
|
||||||
|
000000004c364a1000000000000000cc eb4ab1db13edbb65240fb05f697a4b51 ffffffffffffffffffffffffffffffff 204 /Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Frameworks/Growl-WithInstaller.framework
|
||||||
|
000000000cfb1f340000000000000176 f0174932a07ce83f79adab3804ed4a95 ffffffffffffffffffffffffffffffff 0 /var/folders/H+/H+mA7h1MEoG+kwyM3p-63k+++TI/-Caches-/com.apple.Xcode.501/SharedPrecompiledHeaders/CIDGrowl_Prefix-axrgkpgoclrhttahaaapjvfneewh/CIDGrowl_Prefix.pch.gch
|
||||||
|
c508ae9dd254cc919e0c00ccf9d06254 4a6190d87ef9521568234f4ded1b06b0 ffffffffffffffffffffffffffffffff 0 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/CIDGrowlAppDelegate.o
|
||||||
|
c508ae9dd2fe7a4e9e0c00ccf9d0c201 174ae0d2e64e876f9b919001a1d38163 ffffffffffffffffffffffffffffffff 5008 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/main.o
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 102 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 18144 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/MacOS/CIDGrowl
|
||||||
|
000000000cfb1f340000000000000176 c508ae9dd2fe7a4e9e0c00ccf9d0c269 ffffffffffffffffffffffffffffffff 54265616 /var/folders/H+/H+mA7h1MEoG+kwyM3p-63k+++TI/-Caches-/com.apple.Xcode.501/SharedPrecompiledHeaders/CIDGrowl_Prefix-fagvflusvjebaedxxcpkqlosognz/CIDGrowl_Prefix.pch.gch
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 204 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Frameworks/Growl-WithInstaller.framework
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 1075964 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/growlicon.tif
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 113806 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/CIDGrowlIcon.icns
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 17809 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/bigicon.png
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 26084 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/menu22.tif
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 3218 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/menuic.png
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 34536 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/MainMenu.nib
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 92 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/InfoPlist.strings
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 486 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Resources/Growl Registration Ticket.growlRegDict
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 8 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/PkgInfo
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 985 /Users/dcp1990/Users/dcp1990/Development/CIDGrowl/build/Debug/CIDGrowl.app/Contents/Info.plist
|
||||||
|
000000000ba021b70000000000000176 5b21c2e8081062bffc9abdbcaa886658 ffffffffffffffffffffffffffffffff 54212368 /var/folders/Zv/Zvjdifw7EH8wlZ8m2iFHzU+++Tg/-Caches-/com.apple.Xcode.507/SharedPrecompiledHeaders/CIDGrowl_Prefix-ezcsekrspebkrlhfumhlqhbyvtuo/CIDGrowl_Prefix.pch.gch
|
||||||
|
ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff ffffffffffffffffffffffffffffffff 0 /var/folders/Zv/Zvjdifw7EH8wlZ8m2iFHzU+++Tg/-Caches-/com.apple.Xcode.507/SharedPrecompiledHeaders/CIDGrowl_Prefix-hcoobokcxyxczfcllvapzzmtkkcq/CIDGrowl_Prefix.pch.gch
|
|
@ -0,0 +1,2 @@
|
||||||
|
/Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/main.o
|
||||||
|
/Users/dcp1990/Development/CIDGrowl/build/CIDGrowl.build/Debug/CIDGrowl.build/Objects-normal/x86_64/CIDGrowlAppDelegate.o
|
Binary file not shown.
Binary file not shown.
840
build/CIDGrowl.build/Debug/CIDGrowl.build/build-state.dat
Normal file
840
build/CIDGrowl.build/Debug/CIDGrowl.build/build-state.dat
Normal file
File diff suppressed because one or more lines are too long
807
build/CIDGrowl.build/Debug/CIDGrowl.build/build-state~.dat
Normal file
807
build/CIDGrowl.build/Debug/CIDGrowl.build/build-state~.dat
Normal file
File diff suppressed because one or more lines are too long
|
@ -0,0 +1 @@
|
||||||
|
Versions/Current/Growl
|
|
@ -0,0 +1 @@
|
||||||
|
Versions/Current/Headers
|
|
@ -0,0 +1 @@
|
||||||
|
Versions/Current/Resources
|
BIN
build/Debug/CIDGrowl.app/Contents/Frameworks/Growl.framework/Versions/A/Growl
Executable file
BIN
build/Debug/CIDGrowl.app/Contents/Frameworks/Growl.framework/Versions/A/Growl
Executable file
Binary file not shown.
|
@ -0,0 +1,6 @@
|
||||||
|
#include "GrowlDefines.h"
|
||||||
|
|
||||||
|
#ifdef __OBJC__
|
||||||
|
# include "GrowlApplicationBridge.h"
|
||||||
|
#endif
|
||||||
|
#include "GrowlApplicationBridge-Carbon.h"
|
|
@ -0,0 +1,780 @@
|
||||||
|
//
|
||||||
|
// GrowlApplicationBridge-Carbon.h
|
||||||
|
// Growl
|
||||||
|
//
|
||||||
|
// Created by Mac-arena the Bored Zo on Wed Jun 18 2004.
|
||||||
|
// Based on GrowlApplicationBridge.h by Evan Schoenberg.
|
||||||
|
// This source code is in the public domain. You may freely link it into any
|
||||||
|
// program.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef _GROWLAPPLICATIONBRIDGE_CARBON_H_
|
||||||
|
#define _GROWLAPPLICATIONBRIDGE_CARBON_H_
|
||||||
|
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#include <Carbon/Carbon.h>
|
||||||
|
|
||||||
|
#ifndef GROWL_EXPORT
|
||||||
|
#define GROWL_EXPORT __attribute__((visibility("default"))) DEPRECATED_ATTRIBUTE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*! @header GrowlApplicationBridge-Carbon.h
|
||||||
|
* @abstract Declares an API that Carbon applications can use to interact with Growl.
|
||||||
|
* @discussion GrowlApplicationBridge uses a delegate to provide information //XXX
|
||||||
|
* to Growl (such as your application's name and what notifications it may
|
||||||
|
* post) and to provide information to your application (such as that Growl
|
||||||
|
* is listening for notifications or that a notification has been clicked).
|
||||||
|
*
|
||||||
|
* You can set the Growldelegate with Growl_SetDelegate and find out the
|
||||||
|
* current delegate with Growl_GetDelegate. See struct Growl_Delegate for more
|
||||||
|
* information about the delegate.
|
||||||
|
*/
|
||||||
|
|
||||||
|
__BEGIN_DECLS
|
||||||
|
|
||||||
|
/*! @struct Growl_Delegate
|
||||||
|
* @abstract Delegate to supply GrowlApplicationBridge with information and respond to events.
|
||||||
|
* @discussion The Growl delegate provides your interface to
|
||||||
|
* GrowlApplicationBridge. When GrowlApplicationBridge needs information about
|
||||||
|
* your application, it looks for it in the delegate; when Growl or the user
|
||||||
|
* does something that you might be interested in, GrowlApplicationBridge
|
||||||
|
* looks for a callback in the delegate and calls it if present
|
||||||
|
* (meaning, if it is not <code>NULL</code>).
|
||||||
|
* XXX on all of that
|
||||||
|
* @field size The size of the delegate structure.
|
||||||
|
* @field applicationName The name of your application.
|
||||||
|
* @field registrationDictionary A dictionary describing your application and the notifications it can send out.
|
||||||
|
* @field applicationIconData Your application's icon.
|
||||||
|
* @field growlInstallationWindowTitle The title of the installation window.
|
||||||
|
* @field growlInstallationInformation Text to display in the installation window.
|
||||||
|
* @field growlUpdateWindowTitle The title of the update window.
|
||||||
|
* @field growlUpdateInformation Text to display in the update window.
|
||||||
|
* @field referenceCount A count of owners of the delegate.
|
||||||
|
* @field retain Called when GrowlApplicationBridge receives this delegate.
|
||||||
|
* @field release Called when GrowlApplicationBridge no longer needs this delegate.
|
||||||
|
* @field growlIsReady Called when GrowlHelperApp is listening for notifications.
|
||||||
|
* @field growlNotificationWasClicked Called when a Growl notification is clicked.
|
||||||
|
* @field growlNotificationTimedOut Called when a Growl notification timed out.
|
||||||
|
*/
|
||||||
|
struct Growl_Delegate {
|
||||||
|
/* @discussion This should be sizeof(struct Growl_Delegate).
|
||||||
|
*/
|
||||||
|
size_t size;
|
||||||
|
|
||||||
|
/*All of these attributes are optional.
|
||||||
|
*Optional attributes can be NULL; required attributes that
|
||||||
|
* are NULL cause setting the Growl delegate to fail.
|
||||||
|
*XXX - move optional/required status into the discussion for each field
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This name is used both internally and in the Growl preferences.
|
||||||
|
*
|
||||||
|
* This should remain stable between different versions and incarnations of
|
||||||
|
* your application.
|
||||||
|
* For example, "SurfWriter" is a good app name, whereas "SurfWriter 2.0" and
|
||||||
|
* "SurfWriter Lite" are not.
|
||||||
|
*
|
||||||
|
* This can be <code>NULL</code> if it is provided elsewhere, namely in an
|
||||||
|
* auto-discoverable plist file in your app bundle
|
||||||
|
* (XXX refer to more information on that) or in registrationDictionary.
|
||||||
|
*/
|
||||||
|
CFStringRef applicationName;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Must contain at least these keys:
|
||||||
|
* GROWL_NOTIFICATIONS_ALL (CFArray):
|
||||||
|
* Contains the names of all notifications your application may post.
|
||||||
|
*
|
||||||
|
* Can also contain these keys:
|
||||||
|
* GROWL_NOTIFICATIONS_DEFAULT (CFArray):
|
||||||
|
* Names of notifications that should be enabled by default.
|
||||||
|
* If omitted, GROWL_NOTIFICATIONS_ALL will be used.
|
||||||
|
* GROWL_APP_NAME (CFString):
|
||||||
|
* Same as the applicationName member of this structure.
|
||||||
|
* If both are present, the applicationName member shall prevail.
|
||||||
|
* If this key is present, you may omit applicationName (set it to <code>NULL</code>).
|
||||||
|
* GROWL_APP_ICON (CFData):
|
||||||
|
* Same as the iconData member of this structure.
|
||||||
|
* If both are present, the iconData member shall prevail.
|
||||||
|
* If this key is present, you may omit iconData (set it to <code>NULL</code>).
|
||||||
|
*
|
||||||
|
* If you change the contents of this dictionary after setting the delegate,
|
||||||
|
* be sure to call Growl_Reregister.
|
||||||
|
*
|
||||||
|
* This can be <code>NULL</code> if you have an auto-discoverable plist file in your app
|
||||||
|
* bundle. (XXX refer to more information on that)
|
||||||
|
*/
|
||||||
|
CFDictionaryRef registrationDictionary;
|
||||||
|
|
||||||
|
/* The data can be in any format supported by NSImage. As of
|
||||||
|
* Mac OS X 10.3, this includes the .icns, TIFF, JPEG, GIF, PNG, PDF, and
|
||||||
|
* PICT formats.
|
||||||
|
*
|
||||||
|
* If this is not supplied, Growl will look up your application's icon by
|
||||||
|
* its application name.
|
||||||
|
*/
|
||||||
|
CFDataRef applicationIconData;
|
||||||
|
|
||||||
|
/* Installer display attributes
|
||||||
|
*
|
||||||
|
* These four attributes are used by the Growl installer, if this framework
|
||||||
|
* supports it.
|
||||||
|
* For any of these being <code>NULL</code>, a localised default will be
|
||||||
|
* supplied.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* If this is <code>NULL</code>, Growl will use a default,
|
||||||
|
* localized title.
|
||||||
|
*
|
||||||
|
* Only used if you're using Growl-WithInstaller.framework. Otherwise,
|
||||||
|
* this member is ignored.
|
||||||
|
*/
|
||||||
|
CFStringRef growlInstallationWindowTitle;
|
||||||
|
/* This information may be as long or short as desired (the
|
||||||
|
* window will be sized to fit it). If Growl is not installed, it will
|
||||||
|
* be displayed to the user as an explanation of what Growl is and what
|
||||||
|
* it can do in your application.
|
||||||
|
* It should probably note that no download is required to install.
|
||||||
|
*
|
||||||
|
* If this is <code>NULL</code>, Growl will use a default, localized
|
||||||
|
* explanation.
|
||||||
|
*
|
||||||
|
* Only used if you're using Growl-WithInstaller.framework. Otherwise,
|
||||||
|
* this member is ignored.
|
||||||
|
*/
|
||||||
|
CFStringRef growlInstallationInformation;
|
||||||
|
/* If this is <code>NULL</code>, Growl will use a default,
|
||||||
|
* localized title.
|
||||||
|
*
|
||||||
|
* Only used if you're using Growl-WithInstaller.framework. Otherwise,
|
||||||
|
* this member is ignored.
|
||||||
|
*/
|
||||||
|
CFStringRef growlUpdateWindowTitle;
|
||||||
|
/* This information may be as long or short as desired (the
|
||||||
|
* window will be sized to fit it). If an older version of Growl is
|
||||||
|
* installed, it will be displayed to the user as an explanation that an
|
||||||
|
* updated version of Growl is included in your application and
|
||||||
|
* no download is required.
|
||||||
|
*
|
||||||
|
* If this is <code>NULL</code>, Growl will use a default, localized
|
||||||
|
* explanation.
|
||||||
|
*
|
||||||
|
* Only used if you're using Growl-WithInstaller.framework. Otherwise,
|
||||||
|
* this member is ignored.
|
||||||
|
*/
|
||||||
|
CFStringRef growlUpdateInformation;
|
||||||
|
|
||||||
|
/* This member is provided for use by your retain and release
|
||||||
|
* callbacks (see below).
|
||||||
|
*
|
||||||
|
* GrowlApplicationBridge never directly uses this member. Instead, it
|
||||||
|
* calls your retain callback (if non-<code>NULL</code>) and your release
|
||||||
|
* callback (if non-<code>NULL</code>).
|
||||||
|
*/
|
||||||
|
unsigned referenceCount;
|
||||||
|
|
||||||
|
//Functions. Currently all of these are optional (any of them can be NULL).
|
||||||
|
|
||||||
|
/* When you call Growl_SetDelegate(newDelegate), it will call
|
||||||
|
* oldDelegate->release(oldDelegate), and then it will call
|
||||||
|
* newDelegate->retain(newDelegate), and the return value from retain
|
||||||
|
* is what will be set as the delegate.
|
||||||
|
* (This means that this member works like CFRetain and -[NSObject retain].)
|
||||||
|
* This member is optional (it can be <code>NULL</code>).
|
||||||
|
* For a delegate allocated with malloc, this member would be
|
||||||
|
* <code>NULL</code>.
|
||||||
|
* @result A delegate to which GrowlApplicationBridge holds a reference.
|
||||||
|
*/
|
||||||
|
void *(*retain)(void *);
|
||||||
|
/* When you call Growl_SetDelegate(newDelegate), it will call
|
||||||
|
* oldDelegate->release(oldDelegate), and then it will call
|
||||||
|
* newDelegate->retain(newDelegate), and the return value from retain
|
||||||
|
* is what will be set as the delegate.
|
||||||
|
* (This means that this member works like CFRelease and
|
||||||
|
* -[NSObject release].)
|
||||||
|
* This member is optional (it can be NULL).
|
||||||
|
* For a delegate allocated with malloc, this member might be
|
||||||
|
* <code>free</code>(3).
|
||||||
|
*/
|
||||||
|
void (*release)(void *);
|
||||||
|
|
||||||
|
/* Informs the delegate that Growl (specifically, the GrowlHelperApp) was
|
||||||
|
* launched successfully (or was already running). The application can
|
||||||
|
* take actions with the knowledge that Growl is installed and functional.
|
||||||
|
*/
|
||||||
|
void (*growlIsReady)(void);
|
||||||
|
|
||||||
|
/* Informs the delegate that a Growl notification was clicked. It is only
|
||||||
|
* sent for notifications sent with a non-<code>NULL</code> clickContext,
|
||||||
|
* so if you want to receive a message when a notification is clicked,
|
||||||
|
* clickContext must not be <code>NULL</code> when calling
|
||||||
|
* Growl_PostNotification or
|
||||||
|
* Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext.
|
||||||
|
*/
|
||||||
|
void (*growlNotificationWasClicked)(CFPropertyListRef clickContext);
|
||||||
|
|
||||||
|
/* Informs the delegate that a Growl notification timed out. It is only
|
||||||
|
* sent for notifications sent with a non-<code>NULL</code> clickContext,
|
||||||
|
* so if you want to receive a message when a notification is clicked,
|
||||||
|
* clickContext must not be <code>NULL</code> when calling
|
||||||
|
* Growl_PostNotification or
|
||||||
|
* Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext.
|
||||||
|
*/
|
||||||
|
void (*growlNotificationTimedOut)(CFPropertyListRef clickContext);
|
||||||
|
};
|
||||||
|
|
||||||
|
/*! @struct Growl_Notification
|
||||||
|
* @abstract Structure describing a Growl notification.
|
||||||
|
* @discussion XXX
|
||||||
|
* @field size The size of the notification structure.
|
||||||
|
* @field name Identifies the notification.
|
||||||
|
* @field title Short synopsis of the notification.
|
||||||
|
* @field description Additional text.
|
||||||
|
* @field iconData An icon for the notification.
|
||||||
|
* @field priority An indicator of the notification's importance.
|
||||||
|
* @field reserved Bits reserved for future usage.
|
||||||
|
* @field isSticky Requests that a notification stay on-screen until dismissed explicitly.
|
||||||
|
* @field clickContext An identifier to be passed to your click callback when a notification is clicked.
|
||||||
|
* @field clickCallback A callback to call when the notification is clicked.
|
||||||
|
*/
|
||||||
|
struct Growl_Notification {
|
||||||
|
/* This should be sizeof(struct Growl_Notification).
|
||||||
|
*/
|
||||||
|
size_t size;
|
||||||
|
|
||||||
|
/* The notification name distinguishes one type of
|
||||||
|
* notification from another. The name should be human-readable, as it
|
||||||
|
* will be displayed in the Growl preference pane.
|
||||||
|
*
|
||||||
|
* The name is used in the GROWL_NOTIFICATIONS_ALL and
|
||||||
|
* GROWL_NOTIFICATIONS_DEFAULT arrays in the registration dictionary, and
|
||||||
|
* in this member of the Growl_Notification structure.
|
||||||
|
*/
|
||||||
|
CFStringRef name;
|
||||||
|
|
||||||
|
/* A notification's title describes the notification briefly.
|
||||||
|
* It should be easy to read quickly by the user.
|
||||||
|
*/
|
||||||
|
CFStringRef title;
|
||||||
|
|
||||||
|
/* The description supplements the title with more
|
||||||
|
* information. It is usually longer and sometimes involves a list of
|
||||||
|
* subjects. For example, for a 'Download complete' notification, the
|
||||||
|
* description might have one filename per line. GrowlMail in Growl 0.6
|
||||||
|
* uses a description of '%d new mail(s)' (formatted with the number of
|
||||||
|
* messages).
|
||||||
|
*/
|
||||||
|
CFStringRef description;
|
||||||
|
|
||||||
|
/* The notification icon usually indicates either what
|
||||||
|
* happened (it may have the same icon as e.g. a toolbar item that
|
||||||
|
* started the process that led to the notification), or what it happened
|
||||||
|
* to (e.g. a document icon).
|
||||||
|
*
|
||||||
|
* The icon data is optional, so it can be <code>NULL</code>. In that
|
||||||
|
* case, the application icon is used alone. Not all displays support
|
||||||
|
* icons.
|
||||||
|
*
|
||||||
|
* The data can be in any format supported by NSImage. As of Mac OS X
|
||||||
|
* 10.3, this includes the .icns, TIFF, JPEG, GIF, PNG, PDF, and PICT form
|
||||||
|
* ats.
|
||||||
|
*/
|
||||||
|
CFDataRef iconData;
|
||||||
|
|
||||||
|
/* Priority is new in Growl 0.6, and is represented as a
|
||||||
|
* signed integer from -2 to +2. 0 is Normal priority, -2 is Very Low
|
||||||
|
* priority, and +2 is Very High priority.
|
||||||
|
*
|
||||||
|
* Not all displays support priority. If you do not wish to assign a
|
||||||
|
* priority to your notification, assign 0.
|
||||||
|
*/
|
||||||
|
signed int priority;
|
||||||
|
|
||||||
|
/* These bits are not used in Growl 0.6. Set them to 0.
|
||||||
|
*/
|
||||||
|
unsigned reserved: 31;
|
||||||
|
|
||||||
|
/* When the sticky bit is clear, in most displays,
|
||||||
|
* notifications disappear after a certain amount of time. Sticky
|
||||||
|
* notifications, however, remain on-screen until the user dismisses them
|
||||||
|
* explicitly, usually by clicking them.
|
||||||
|
*
|
||||||
|
* Sticky notifications were introduced in Growl 0.6. Most notifications
|
||||||
|
* should not be sticky. Not all displays support sticky notifications,
|
||||||
|
* and the user may choose in Growl's preference pane to force the
|
||||||
|
* notification to be sticky or non-sticky, in which case the sticky bit
|
||||||
|
* in the notification will be ignored.
|
||||||
|
*/
|
||||||
|
unsigned isSticky: 1;
|
||||||
|
|
||||||
|
/* If this is not <code>NULL</code>, and your click callback
|
||||||
|
* is not <code>NULL</code> either, this will be passed to the callback
|
||||||
|
* when your notification is clicked by the user.
|
||||||
|
*
|
||||||
|
* Click feedback was introduced in Growl 0.6, and it is optional. Not
|
||||||
|
* all displays support click feedback.
|
||||||
|
*/
|
||||||
|
CFPropertyListRef clickContext;
|
||||||
|
|
||||||
|
/* If this is not <code>NULL</code>, it will be called instead
|
||||||
|
* of the Growl delegate's click callback when clickContext is
|
||||||
|
* non-<code>NULL</code> and the notification is clicked on by the user.
|
||||||
|
*
|
||||||
|
* Click feedback was introduced in Growl 0.6, and it is optional. Not
|
||||||
|
* all displays support click feedback.
|
||||||
|
*
|
||||||
|
* The per-notification click callback is not yet supported as of Growl
|
||||||
|
* 0.7.
|
||||||
|
*/
|
||||||
|
void (*clickCallback)(CFPropertyListRef clickContext);
|
||||||
|
|
||||||
|
CFStringRef identifier;
|
||||||
|
};
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
#pragma mark Easy initialisers
|
||||||
|
|
||||||
|
/*! @defined InitGrowlDelegate
|
||||||
|
* @abstract Callable macro. Initializes a Growl delegate structure to defaults.
|
||||||
|
* @discussion Call with a pointer to a struct Growl_Delegate. All of the
|
||||||
|
* members of the structure will be set to 0 or <code>NULL</code>, except for
|
||||||
|
* size (which will be set to <code>sizeof(struct Growl_Delegate)</code>) and
|
||||||
|
* referenceCount (which will be set to 1).
|
||||||
|
*/
|
||||||
|
#define InitGrowlDelegate(delegate) \
|
||||||
|
do { \
|
||||||
|
if (delegate) { \
|
||||||
|
(delegate)->size = sizeof(struct Growl_Delegate); \
|
||||||
|
(delegate)->applicationName = NULL; \
|
||||||
|
(delegate)->registrationDictionary = NULL; \
|
||||||
|
(delegate)->applicationIconData = NULL; \
|
||||||
|
(delegate)->growlInstallationWindowTitle = NULL; \
|
||||||
|
(delegate)->growlInstallationInformation = NULL; \
|
||||||
|
(delegate)->growlUpdateWindowTitle = NULL; \
|
||||||
|
(delegate)->growlUpdateInformation = NULL; \
|
||||||
|
(delegate)->referenceCount = 1U; \
|
||||||
|
(delegate)->retain = NULL; \
|
||||||
|
(delegate)->release = NULL; \
|
||||||
|
(delegate)->growlIsReady = NULL; \
|
||||||
|
(delegate)->growlNotificationWasClicked = NULL; \
|
||||||
|
(delegate)->growlNotificationTimedOut = NULL; \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
/*! @defined InitGrowlNotification
|
||||||
|
* @abstract Callable macro. Initializes a Growl notification structure to defaults.
|
||||||
|
* @discussion Call with a pointer to a struct Growl_Notification. All of
|
||||||
|
* the members of the structure will be set to 0 or <code>NULL</code>, except
|
||||||
|
* for size (which will be set to
|
||||||
|
* <code>sizeof(struct Growl_Notification)</code>).
|
||||||
|
*/
|
||||||
|
#define InitGrowlNotification(notification) \
|
||||||
|
do { \
|
||||||
|
if (notification) { \
|
||||||
|
(notification)->size = sizeof(struct Growl_Notification); \
|
||||||
|
(notification)->name = NULL; \
|
||||||
|
(notification)->title = NULL; \
|
||||||
|
(notification)->description = NULL; \
|
||||||
|
(notification)->iconData = NULL; \
|
||||||
|
(notification)->priority = 0; \
|
||||||
|
(notification)->reserved = 0U; \
|
||||||
|
(notification)->isSticky = false; \
|
||||||
|
(notification)->clickContext = NULL; \
|
||||||
|
(notification)->clickCallback = NULL; \
|
||||||
|
(notification)->identifier = NULL; \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
#pragma mark Public API
|
||||||
|
|
||||||
|
// @functiongroup Managing the Growl delegate
|
||||||
|
|
||||||
|
/*! @function Growl_SetDelegate
|
||||||
|
* @abstract Replaces the current Growl delegate with a new one, or removes
|
||||||
|
* the Growl delegate.
|
||||||
|
* @param newDelegate
|
||||||
|
* @result Returns false and does nothing else if a pointer that was passed in
|
||||||
|
* is unsatisfactory (because it is non-<code>NULL</code>, but at least one
|
||||||
|
* required member of it is <code>NULL</code>). Otherwise, sets or unsets the
|
||||||
|
* delegate and returns true.
|
||||||
|
* @discussion When <code>newDelegate</code> is non-<code>NULL</code>, sets
|
||||||
|
* the delegate to <code>newDelegate</code>. When it is <code>NULL</code>,
|
||||||
|
* the current delegate will be unset, and no delegate will be in place.
|
||||||
|
*
|
||||||
|
* It is legal for <code>newDelegate</code> to be the current delegate;
|
||||||
|
* nothing will happen, and Growl_SetDelegate will return true. It is also
|
||||||
|
* legal for it to be <code>NULL</code>, as described above; again, it will
|
||||||
|
* return true.
|
||||||
|
*
|
||||||
|
* If there was a delegate in place before the call, Growl_SetDelegate will
|
||||||
|
* call the old delegate's release member if it was non-<code>NULL</code>. If
|
||||||
|
* <code>newDelegate</code> is non-<code>NULL</code>, Growl_SetDelegate will
|
||||||
|
* call <code>newDelegate->retain</code>, and set the delegate to its return
|
||||||
|
* value.
|
||||||
|
*
|
||||||
|
* If you are using Growl-WithInstaller.framework, and an older version of
|
||||||
|
* Growl is installed on the user's system, the user will automatically be
|
||||||
|
* prompted to update.
|
||||||
|
*
|
||||||
|
* GrowlApplicationBridge currently does not copy this structure, nor does it
|
||||||
|
* retain any of the CF objects in the structure (it regards the structure as
|
||||||
|
* a container that retains the objects when they are added and releases them
|
||||||
|
* when they are removed or the structure is destroyed). Also,
|
||||||
|
* GrowlApplicationBridge currently does not modify any member of the
|
||||||
|
* structure, except possibly the referenceCount by calling the retain and
|
||||||
|
* release members.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_SetDelegate(struct Growl_Delegate *newDelegate);
|
||||||
|
|
||||||
|
/*! @function Growl_GetDelegate
|
||||||
|
* @abstract Returns the current Growl delegate, if any.
|
||||||
|
* @result The current Growl delegate.
|
||||||
|
* @discussion Returns the last pointer passed into Growl_SetDelegate, or
|
||||||
|
* <code>NULL</code> if no such call has been made.
|
||||||
|
*
|
||||||
|
* This function follows standard Core Foundation reference-counting rules.
|
||||||
|
* Because it is a Get function, not a Copy function, it will not retain the
|
||||||
|
* delegate on your behalf. You are responsible for retaining and releasing
|
||||||
|
* the delegate as needed.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT struct Growl_Delegate *Growl_GetDelegate(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Posting Growl notifications
|
||||||
|
|
||||||
|
/*! @function Growl_PostNotification
|
||||||
|
* @abstract Posts a Growl notification.
|
||||||
|
* @param notification The notification to post.
|
||||||
|
* @discussion This is the preferred means for sending a Growl notification.
|
||||||
|
* The notification name and at least one of the title and description are
|
||||||
|
* required (all three are preferred). All other parameters may be
|
||||||
|
* <code>NULL</code> (or 0 or false as appropriate) to accept default values.
|
||||||
|
*
|
||||||
|
* If using the Growl-WithInstaller framework, if Growl is not installed the
|
||||||
|
* user will be prompted to install Growl.
|
||||||
|
* If the user cancels, this function will have no effect until the next
|
||||||
|
* application session, at which time when it is called the user will be
|
||||||
|
* prompted again. The user is also given the option to not be prompted again.
|
||||||
|
* If the user does choose to install Growl, the requested notification will
|
||||||
|
* be displayed once Growl is installed and running.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_PostNotification(const struct Growl_Notification *notification);
|
||||||
|
|
||||||
|
/*! @function Growl_PostNotificationWithDictionary
|
||||||
|
* @abstract Notifies using a userInfo dictionary suitable for passing to
|
||||||
|
* CFDistributedNotificationCenter.
|
||||||
|
* @param userInfo The dictionary to notify with.
|
||||||
|
* @discussion Before Growl 0.6, your application would have posted
|
||||||
|
* notifications using CFDistributedNotificationCenter by creating a userInfo
|
||||||
|
* dictionary with the notification data. This had the advantage of allowing
|
||||||
|
* you to add other data to the dictionary for programs besides Growl that
|
||||||
|
* might be listening.
|
||||||
|
*
|
||||||
|
* This function allows you to use such dictionaries without being restricted
|
||||||
|
* to using CFDistributedNotificationCenter. The keys for this dictionary
|
||||||
|
* can be found in GrowlDefines.h.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_PostNotificationWithDictionary(CFDictionaryRef userInfo);
|
||||||
|
|
||||||
|
/*! @function Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext
|
||||||
|
* @abstract Posts a Growl notification using parameter values.
|
||||||
|
* @param title The title of the notification.
|
||||||
|
* @param description The description of the notification.
|
||||||
|
* @param notificationName The name of the notification as listed in the
|
||||||
|
* registration dictionary.
|
||||||
|
* @param iconData Data representing a notification icon. Can be <code>NULL</code>.
|
||||||
|
* @param priority The priority of the notification (-2 to +2, with -2
|
||||||
|
* being Very Low and +2 being Very High).
|
||||||
|
* @param isSticky If true, requests that this notification wait for a
|
||||||
|
* response from the user.
|
||||||
|
* @param clickContext An object to pass to the clickCallback, if any. Can
|
||||||
|
* be <code>NULL</code>, in which case the clickCallback is not called.
|
||||||
|
* @discussion Creates a temporary Growl_Notification, fills it out with the
|
||||||
|
* supplied information, and calls Growl_PostNotification on it.
|
||||||
|
* See struct Growl_Notification and Growl_PostNotification for more
|
||||||
|
* information.
|
||||||
|
*
|
||||||
|
* The icon data can be in any format supported by NSImage. As of Mac OS X
|
||||||
|
* 10.3, this includes the .icns, TIFF, JPEG, GIF, PNG, PDF, and PICT formats.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext(
|
||||||
|
/*inhale*/
|
||||||
|
CFStringRef title,
|
||||||
|
CFStringRef description,
|
||||||
|
CFStringRef notificationName,
|
||||||
|
CFDataRef iconData,
|
||||||
|
signed int priority,
|
||||||
|
Boolean isSticky,
|
||||||
|
CFPropertyListRef clickContext);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Registering
|
||||||
|
|
||||||
|
/*! @function Growl_RegisterWithDictionary
|
||||||
|
* @abstract Register your application with Growl without setting a delegate.
|
||||||
|
* @discussion When you call this function with a dictionary,
|
||||||
|
* GrowlApplicationBridge registers your application using that dictionary.
|
||||||
|
* If you pass <code>NULL</code>, GrowlApplicationBridge will ask the delegate
|
||||||
|
* (if there is one) for a dictionary, and if that doesn't work, it will look
|
||||||
|
* in your application's bundle for an auto-discoverable plist.
|
||||||
|
* (XXX refer to more information on that)
|
||||||
|
*
|
||||||
|
* If you pass a dictionary to this function, it must include the
|
||||||
|
* <code>GROWL_APP_NAME</code> key, unless a delegate is set.
|
||||||
|
*
|
||||||
|
* This function is mainly an alternative to the delegate system introduced
|
||||||
|
* with Growl 0.6. Without a delegate, you cannot receive callbacks such as
|
||||||
|
* <code>growlIsReady</code> (since they are sent to the delegate). You can,
|
||||||
|
* however, set a delegate after registering without one.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
* @result <code>false</code> if registration failed (e.g. if Growl isn't installed).
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_RegisterWithDictionary(CFDictionaryRef regDict);
|
||||||
|
|
||||||
|
/*! @function Growl_Reregister
|
||||||
|
* @abstract Updates your registration with Growl.
|
||||||
|
* @discussion If your application changes the contents of the
|
||||||
|
* GROWL_NOTIFICATIONS_ALL key in the registrationDictionary member of the
|
||||||
|
* Growl delegate, or if it changes the value of that member, or if it
|
||||||
|
* changes the contents of its auto-discoverable plist, call this function
|
||||||
|
* to have Growl update its registration information for your application.
|
||||||
|
*
|
||||||
|
* Otherwise, this function does not normally need to be called. If you're
|
||||||
|
* using a delegate, your application will be registered when you set the
|
||||||
|
* delegate if both the delegate and its registrationDictionary member are
|
||||||
|
* non-<code>NULL</code>.
|
||||||
|
*
|
||||||
|
* This function is now implemented using
|
||||||
|
* <code>Growl_RegisterWithDictionary</code>.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_Reregister(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @function Growl_SetWillRegisterWhenGrowlIsReady
|
||||||
|
* @abstract Tells GrowlApplicationBridge to register with Growl when Growl
|
||||||
|
* launches (or not).
|
||||||
|
* @discussion When Growl has started listening for notifications, it posts a
|
||||||
|
* <code>GROWL_IS_READY</code> notification on the Distributed Notification
|
||||||
|
* Center. GrowlApplicationBridge listens for this notification, using it to
|
||||||
|
* perform various tasks (such as calling your delegate's
|
||||||
|
* <code>growlIsReady</code> callback, if it has one). If this function is
|
||||||
|
* called with <code>true</code>, one of those tasks will be to reregister
|
||||||
|
* with Growl (in the manner of <code>Growl_Reregister</code>).
|
||||||
|
*
|
||||||
|
* This attribute is automatically set back to <code>false</code>
|
||||||
|
* (the default) after every <code>GROWL_IS_READY</code> notification.
|
||||||
|
* @param flag <code>true</code> if you want GrowlApplicationBridge to register with
|
||||||
|
* Growl when next it is ready; <code>false</code> if not.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT void Growl_SetWillRegisterWhenGrowlIsReady(Boolean flag);
|
||||||
|
/*! @function Growl_WillRegisterWhenGrowlIsReady
|
||||||
|
* @abstract Reports whether GrowlApplicationBridge will register with Growl
|
||||||
|
* when Growl next launches.
|
||||||
|
* @result <code>true</code> if GrowlApplicationBridge will register with
|
||||||
|
* Growl when next it posts GROWL_IS_READY; <code>false</code> if not.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_WillRegisterWhenGrowlIsReady(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Obtaining registration dictionaries
|
||||||
|
|
||||||
|
/*! @function Growl_CopyRegistrationDictionaryFromDelegate
|
||||||
|
* @abstract Asks the delegate for a registration dictionary.
|
||||||
|
* @discussion If no delegate is set, or if the delegate's
|
||||||
|
* <code>registrationDictionary</code> member is <code>NULL</code>, this
|
||||||
|
* function returns <code>NULL</code>.
|
||||||
|
*
|
||||||
|
* This function does not attempt to clean up the dictionary in any way - for
|
||||||
|
* example, if it is missing the <code>GROWL_APP_NAME</code> key, the result
|
||||||
|
* will be missing it too. Use
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionary</code> or
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys</code>
|
||||||
|
* to try to fill in missing keys.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CopyRegistrationDictionaryFromDelegate(void);
|
||||||
|
|
||||||
|
/*! @function Growl_CopyRegistrationDictionaryFromBundle
|
||||||
|
* @abstract Looks in a bundle for a registration dictionary.
|
||||||
|
* @discussion This function looks in a bundle for an auto-discoverable
|
||||||
|
* registration dictionary file using <code>CFBundleCopyResourceURL</code>.
|
||||||
|
* If it finds one, it loads the file using <code>CFPropertyList</code> and
|
||||||
|
* returns the result.
|
||||||
|
*
|
||||||
|
* If you pass <code>NULL</code> as the bundle, the main bundle is examined.
|
||||||
|
*
|
||||||
|
* This function does not attempt to clean up the dictionary in any way - for
|
||||||
|
* example, if it is missing the <code>GROWL_APP_NAME</code> key, the result
|
||||||
|
* will be missing it too. Use
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionary:</code> or
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys</code>
|
||||||
|
* to try to fill in missing keys.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CopyRegistrationDictionaryFromBundle(CFBundleRef bundle);
|
||||||
|
|
||||||
|
/*! @function Growl_CreateBestRegistrationDictionary
|
||||||
|
* @abstract Obtains a registration dictionary, filled out to the best of
|
||||||
|
* GrowlApplicationBridge's knowledge.
|
||||||
|
* @discussion This function creates a registration dictionary as best
|
||||||
|
* GrowlApplicationBridge knows how.
|
||||||
|
*
|
||||||
|
* First, GrowlApplicationBridge examines the Growl delegate (if there is
|
||||||
|
* one) and gets the registration dictionary from that. If no such dictionary
|
||||||
|
* was obtained, GrowlApplicationBridge looks in your application's main
|
||||||
|
* bundle for an auto-discoverable registration dictionary file. If that
|
||||||
|
* doesn't exist either, this function returns <code>NULL</code>.
|
||||||
|
*
|
||||||
|
* Second, GrowlApplicationBridge calls
|
||||||
|
* <code>Growl_CreateRegistrationDictionaryByFillingInDictionary</code> with
|
||||||
|
* whatever dictionary was obtained. The result of that function is the
|
||||||
|
* result of this function.
|
||||||
|
*
|
||||||
|
* GrowlApplicationBridge uses this function when you call
|
||||||
|
* <code>Growl_SetDelegate</code>, or when you call
|
||||||
|
* <code>Growl_RegisterWithDictionary</code> with <code>NULL</code>.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CreateBestRegistrationDictionary(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Filling in registration dictionaries
|
||||||
|
|
||||||
|
/*! @function Growl_CreateRegistrationDictionaryByFillingInDictionary
|
||||||
|
* @abstract Tries to fill in missing keys in a registration dictionary.
|
||||||
|
* @param regDict The dictionary to fill in.
|
||||||
|
* @result The dictionary with the keys filled in.
|
||||||
|
* @discussion This function examines the passed-in dictionary for missing keys,
|
||||||
|
* and tries to work out correct values for them. As of 0.7, it uses:
|
||||||
|
*
|
||||||
|
* Key Value
|
||||||
|
* --- -----
|
||||||
|
* <code>GROWL_APP_NAME</code> <code>CFBundleExecutableName</code>
|
||||||
|
* <code>GROWL_APP_ICON</code> The icon of the application.
|
||||||
|
* <code>GROWL_APP_LOCATION</code> The location of the application.
|
||||||
|
* <code>GROWL_NOTIFICATIONS_DEFAULT</code> <code>GROWL_NOTIFICATIONS_ALL</code>
|
||||||
|
*
|
||||||
|
* Keys are only filled in if missing; if a key is present in the dictionary,
|
||||||
|
* its value will not be changed.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CreateRegistrationDictionaryByFillingInDictionary(CFDictionaryRef regDict);
|
||||||
|
/*! @function Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys
|
||||||
|
* @abstract Tries to fill in missing keys in a registration dictionary.
|
||||||
|
* @param regDict The dictionary to fill in.
|
||||||
|
* @param keys The keys to fill in. If <code>NULL</code>, any missing keys are filled in.
|
||||||
|
* @result The dictionary with the keys filled in.
|
||||||
|
* @discussion This function examines the passed-in dictionary for missing keys,
|
||||||
|
* and tries to work out correct values for them. As of 0.7, it uses:
|
||||||
|
*
|
||||||
|
* Key Value
|
||||||
|
* --- -----
|
||||||
|
* <code>GROWL_APP_NAME</code> <code>CFBundleExecutableName</code>
|
||||||
|
* <code>GROWL_APP_ICON</code> The icon of the application.
|
||||||
|
* <code>GROWL_APP_LOCATION</code> The location of the application.
|
||||||
|
* <code>GROWL_NOTIFICATIONS_DEFAULT</code> <code>GROWL_NOTIFICATIONS_ALL</code>
|
||||||
|
*
|
||||||
|
* Only those keys that are listed in <code>keys</code> will be filled in.
|
||||||
|
* Other missing keys are ignored. Also, keys are only filled in if missing;
|
||||||
|
* if a key is present in the dictionary, its value will not be changed.
|
||||||
|
*
|
||||||
|
* This function was introduced in Growl.framework 0.7.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys(CFDictionaryRef regDict, CFSetRef keys);
|
||||||
|
|
||||||
|
/*! @brief Tries to fill in missing keys in a notification dictionary.
|
||||||
|
* @param notifDict The dictionary to fill in.
|
||||||
|
* @return The dictionary with the keys filled in. This will be a separate instance from \a notifDict.
|
||||||
|
* @discussion This function examines the \a notifDict for missing keys, and
|
||||||
|
* tries to get them from the last known registration dictionary. As of 1.1,
|
||||||
|
* the keys that it will look for are:
|
||||||
|
*
|
||||||
|
* \li <code>GROWL_APP_NAME</code>
|
||||||
|
* \li <code>GROWL_APP_ICON</code>
|
||||||
|
*
|
||||||
|
* @since Growl.framework 1.1
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT CFDictionaryRef Growl_CreateNotificationDictionaryByFillingInDictionary(CFDictionaryRef notifDict);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Querying Growl's status
|
||||||
|
|
||||||
|
/*! @function Growl_IsInstalled
|
||||||
|
* @abstract Determines whether the Growl prefpane and its helper app are
|
||||||
|
* installed.
|
||||||
|
* @result Returns true if Growl is installed, false otherwise.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_IsInstalled(void);
|
||||||
|
|
||||||
|
/*! @function Growl_IsRunning
|
||||||
|
* @abstract Cycles through the process list to find whether GrowlHelperApp
|
||||||
|
* is running.
|
||||||
|
* @result Returns true if Growl is running, false otherwise.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_IsRunning(void);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
// @functiongroup Launching Growl
|
||||||
|
|
||||||
|
/*! @typedef GrowlLaunchCallback
|
||||||
|
* @abstract Callback to notify you that Growl is running.
|
||||||
|
* @param context The context pointer passed to Growl_LaunchIfInstalled.
|
||||||
|
* @discussion Growl_LaunchIfInstalled calls this callback function if Growl
|
||||||
|
* was already running or if it launched Growl successfully.
|
||||||
|
*/
|
||||||
|
typedef void (*GrowlLaunchCallback)(void *context);
|
||||||
|
|
||||||
|
/*! @function Growl_LaunchIfInstalled
|
||||||
|
* @abstract Launches GrowlHelperApp if it is not already running.
|
||||||
|
* @param callback A callback function which will be called if Growl was successfully
|
||||||
|
* launched or was already running. Can be <code>NULL</code>.
|
||||||
|
* @param context The context pointer to pass to the callback. Can be <code>NULL</code>.
|
||||||
|
* @result Returns true if Growl was successfully launched or was already
|
||||||
|
* running; returns false and does not call the callback otherwise.
|
||||||
|
* @discussion Returns true and calls the callback (if the callback is not
|
||||||
|
* <code>NULL</code>) if the Growl helper app began launching or was already
|
||||||
|
* running. Returns false and performs no other action if Growl could not be
|
||||||
|
* launched (e.g. because the Growl preference pane is not properly installed).
|
||||||
|
*
|
||||||
|
* If <code>Growl_CreateBestRegistrationDictionary</code> returns
|
||||||
|
* non-<code>NULL</code>, this function will register with Growl atomically.
|
||||||
|
*
|
||||||
|
* The callback should take a single argument; this is to allow applications
|
||||||
|
* to have context-relevant information passed back. It is perfectly
|
||||||
|
* acceptable for context to be <code>NULL</code>. The callback itself can be
|
||||||
|
* <code>NULL</code> if you don't want one.
|
||||||
|
*/
|
||||||
|
GROWL_EXPORT Boolean Growl_LaunchIfInstalled(GrowlLaunchCallback callback, void *context);
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
#pragma mark Constants
|
||||||
|
|
||||||
|
/*! @defined GROWL_PREFPANE_BUNDLE_IDENTIFIER
|
||||||
|
* @abstract The CFBundleIdentifier of the Growl preference pane bundle.
|
||||||
|
* @discussion GrowlApplicationBridge uses this to determine whether Growl is
|
||||||
|
* currently installed, by searching for the Growl preference pane. Your
|
||||||
|
* application probably does not need to use this macro itself.
|
||||||
|
*/
|
||||||
|
#ifndef GROWL_PREFPANE_BUNDLE_IDENTIFIER
|
||||||
|
#define GROWL_PREFPANE_BUNDLE_IDENTIFIER CFSTR("com.growl.prefpanel")
|
||||||
|
#endif
|
||||||
|
|
||||||
|
__END_DECLS
|
||||||
|
|
||||||
|
#endif /* _GROWLAPPLICATIONBRIDGE_CARBON_H_ */
|
|
@ -0,0 +1,575 @@
|
||||||
|
//
|
||||||
|
// GrowlApplicationBridge.h
|
||||||
|
// Growl
|
||||||
|
//
|
||||||
|
// Created by Evan Schoenberg on Wed Jun 16 2004.
|
||||||
|
// Copyright 2004-2006 The Growl Project. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @header GrowlApplicationBridge.h
|
||||||
|
* @abstract Defines the GrowlApplicationBridge class.
|
||||||
|
* @discussion This header defines the GrowlApplicationBridge class as well as
|
||||||
|
* the GROWL_PREFPANE_BUNDLE_IDENTIFIER constant.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __GrowlApplicationBridge_h__
|
||||||
|
#define __GrowlApplicationBridge_h__
|
||||||
|
|
||||||
|
#import <Foundation/Foundation.h>
|
||||||
|
#import <AppKit/AppKit.h>
|
||||||
|
#import "GrowlDefines.h"
|
||||||
|
|
||||||
|
//Forward declarations
|
||||||
|
@protocol GrowlApplicationBridgeDelegate;
|
||||||
|
|
||||||
|
//Internal notification when the user chooses not to install (to avoid continuing to cache notifications awaiting installation)
|
||||||
|
#define GROWL_USER_CHOSE_NOT_TO_INSTALL_NOTIFICATION @"User chose not to install"
|
||||||
|
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @class GrowlApplicationBridge
|
||||||
|
* @abstract A class used to interface with Growl.
|
||||||
|
* @discussion This class provides a means to interface with Growl.
|
||||||
|
*
|
||||||
|
* Currently it provides a way to detect if Growl is installed and launch the
|
||||||
|
* GrowlHelperApp if it's not already running.
|
||||||
|
*/
|
||||||
|
@interface GrowlApplicationBridge : NSObject {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method isGrowlInstalled
|
||||||
|
* @abstract Detects whether Growl is installed.
|
||||||
|
* @discussion Determines if the Growl prefpane and its helper app are installed.
|
||||||
|
* @result Returns YES if Growl is installed, NO otherwise.
|
||||||
|
*/
|
||||||
|
+ (BOOL) isGrowlInstalled;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method isGrowlRunning
|
||||||
|
* @abstract Detects whether GrowlHelperApp is currently running.
|
||||||
|
* @discussion Cycles through the process list to find whether GrowlHelperApp is running and returns its findings.
|
||||||
|
* @result Returns YES if GrowlHelperApp is running, NO otherwise.
|
||||||
|
*/
|
||||||
|
+ (BOOL) isGrowlRunning;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method setGrowlDelegate:
|
||||||
|
* @abstract Set the object which will be responsible for providing and receiving Growl information.
|
||||||
|
* @discussion This must be called before using GrowlApplicationBridge.
|
||||||
|
*
|
||||||
|
* The methods in the GrowlApplicationBridgeDelegate protocol are required
|
||||||
|
* and return the basic information needed to register with Growl.
|
||||||
|
*
|
||||||
|
* The methods in the GrowlApplicationBridgeDelegate_InformalProtocol
|
||||||
|
* informal protocol are individually optional. They provide a greater
|
||||||
|
* degree of interaction between the application and growl such as informing
|
||||||
|
* the application when one of its Growl notifications is clicked by the user.
|
||||||
|
*
|
||||||
|
* The methods in the GrowlApplicationBridgeDelegate_Installation_InformalProtocol
|
||||||
|
* informal protocol are individually optional and are only applicable when
|
||||||
|
* using the Growl-WithInstaller.framework which allows for automated Growl
|
||||||
|
* installation.
|
||||||
|
*
|
||||||
|
* When this method is called, data will be collected from inDelegate, Growl
|
||||||
|
* will be launched if it is not already running, and the application will be
|
||||||
|
* registered with Growl.
|
||||||
|
*
|
||||||
|
* If using the Growl-WithInstaller framework, if Growl is already installed
|
||||||
|
* but this copy of the framework has an updated version of Growl, the user
|
||||||
|
* will be prompted to update automatically.
|
||||||
|
*
|
||||||
|
* @param inDelegate The delegate for the GrowlApplicationBridge. It must conform to the GrowlApplicationBridgeDelegate protocol.
|
||||||
|
*/
|
||||||
|
+ (void) setGrowlDelegate:(NSObject<GrowlApplicationBridgeDelegate> *)inDelegate;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlDelegate
|
||||||
|
* @abstract Return the object responsible for providing and receiving Growl information.
|
||||||
|
* @discussion See setGrowlDelegate: for details.
|
||||||
|
* @result The Growl delegate.
|
||||||
|
*/
|
||||||
|
+ (NSObject<GrowlApplicationBridgeDelegate> *) growlDelegate;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:
|
||||||
|
* @abstract Send a Growl notification.
|
||||||
|
* @discussion This is the preferred means for sending a Growl notification.
|
||||||
|
* The notification name and at least one of the title and description are
|
||||||
|
* required (all three are preferred). All other parameters may be
|
||||||
|
* <code>nil</code> (or 0 or NO as appropriate) to accept default values.
|
||||||
|
*
|
||||||
|
* If using the Growl-WithInstaller framework, if Growl is not installed the
|
||||||
|
* user will be prompted to install Growl. If the user cancels, this method
|
||||||
|
* will have no effect until the next application session, at which time when
|
||||||
|
* it is called the user will be prompted again. The user is also given the
|
||||||
|
* option to not be prompted again. If the user does choose to install Growl,
|
||||||
|
* the requested notification will be displayed once Growl is installed and
|
||||||
|
* running.
|
||||||
|
*
|
||||||
|
* @param title The title of the notification displayed to the user.
|
||||||
|
* @param description The full description of the notification displayed to the user.
|
||||||
|
* @param notifName The internal name of the notification. Should be human-readable, as it will be displayed in the Growl preference pane.
|
||||||
|
* @param iconData <code>NSData</code> object to show with the notification as its icon. If <code>nil</code>, the application's icon will be used instead.
|
||||||
|
* @param priority The priority of the notification. The default value is 0; positive values are higher priority and negative values are lower priority. Not all Growl displays support priority.
|
||||||
|
* @param isSticky If YES, the notification will remain on screen until clicked. Not all Growl displays support sticky notifications.
|
||||||
|
* @param clickContext A context passed back to the Growl delegate if it implements -(void)growlNotificationWasClicked: and the notification is clicked. Not all display plugins support clicking. The clickContext must be plist-encodable (completely of <code>NSString</code>, <code>NSArray</code>, <code>NSNumber</code>, <code>NSDictionary</code>, and <code>NSData</code> types).
|
||||||
|
*/
|
||||||
|
+ (void) notifyWithTitle:(NSString *)title
|
||||||
|
description:(NSString *)description
|
||||||
|
notificationName:(NSString *)notifName
|
||||||
|
iconData:(NSData *)iconData
|
||||||
|
priority:(signed int)priority
|
||||||
|
isSticky:(BOOL)isSticky
|
||||||
|
clickContext:(id)clickContext;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:identifier:
|
||||||
|
* @abstract Send a Growl notification.
|
||||||
|
* @discussion This is the preferred means for sending a Growl notification.
|
||||||
|
* The notification name and at least one of the title and description are
|
||||||
|
* required (all three are preferred). All other parameters may be
|
||||||
|
* <code>nil</code> (or 0 or NO as appropriate) to accept default values.
|
||||||
|
*
|
||||||
|
* If using the Growl-WithInstaller framework, if Growl is not installed the
|
||||||
|
* user will be prompted to install Growl. If the user cancels, this method
|
||||||
|
* will have no effect until the next application session, at which time when
|
||||||
|
* it is called the user will be prompted again. The user is also given the
|
||||||
|
* option to not be prompted again. If the user does choose to install Growl,
|
||||||
|
* the requested notification will be displayed once Growl is installed and
|
||||||
|
* running.
|
||||||
|
*
|
||||||
|
* @param title The title of the notification displayed to the user.
|
||||||
|
* @param description The full description of the notification displayed to the user.
|
||||||
|
* @param notifName The internal name of the notification. Should be human-readable, as it will be displayed in the Growl preference pane.
|
||||||
|
* @param iconData <code>NSData</code> object to show with the notification as its icon. If <code>nil</code>, the application's icon will be used instead.
|
||||||
|
* @param priority The priority of the notification. The default value is 0; positive values are higher priority and negative values are lower priority. Not all Growl displays support priority.
|
||||||
|
* @param isSticky If YES, the notification will remain on screen until clicked. Not all Growl displays support sticky notifications.
|
||||||
|
* @param clickContext A context passed back to the Growl delegate if it implements -(void)growlNotificationWasClicked: and the notification is clicked. Not all display plugins support clicking. The clickContext must be plist-encodable (completely of <code>NSString</code>, <code>NSArray</code>, <code>NSNumber</code>, <code>NSDictionary</code>, and <code>NSData</code> types).
|
||||||
|
* @param identifier An identifier for this notification. Notifications with equal identifiers are coalesced.
|
||||||
|
*/
|
||||||
|
+ (void) notifyWithTitle:(NSString *)title
|
||||||
|
description:(NSString *)description
|
||||||
|
notificationName:(NSString *)notifName
|
||||||
|
iconData:(NSData *)iconData
|
||||||
|
priority:(signed int)priority
|
||||||
|
isSticky:(BOOL)isSticky
|
||||||
|
clickContext:(id)clickContext
|
||||||
|
identifier:(NSString *)identifier;
|
||||||
|
|
||||||
|
/*! @method notifyWithDictionary:
|
||||||
|
* @abstract Notifies using a userInfo dictionary suitable for passing to
|
||||||
|
* <code>NSDistributedNotificationCenter</code>.
|
||||||
|
* @param userInfo The dictionary to notify with.
|
||||||
|
* @discussion Before Growl 0.6, your application would have posted
|
||||||
|
* notifications using <code>NSDistributedNotificationCenter</code> by
|
||||||
|
* creating a userInfo dictionary with the notification data. This had the
|
||||||
|
* advantage of allowing you to add other data to the dictionary for programs
|
||||||
|
* besides Growl that might be listening.
|
||||||
|
*
|
||||||
|
* This method allows you to use such dictionaries without being restricted
|
||||||
|
* to using <code>NSDistributedNotificationCenter</code>. The keys for this dictionary
|
||||||
|
* can be found in GrowlDefines.h.
|
||||||
|
*/
|
||||||
|
+ (void) notifyWithDictionary:(NSDictionary *)userInfo;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @method registerWithDictionary:
|
||||||
|
* @abstract Register your application with Growl without setting a delegate.
|
||||||
|
* @discussion When you call this method with a dictionary,
|
||||||
|
* GrowlApplicationBridge registers your application using that dictionary.
|
||||||
|
* If you pass <code>nil</code>, GrowlApplicationBridge will ask the delegate
|
||||||
|
* (if there is one) for a dictionary, and if that doesn't work, it will look
|
||||||
|
* in your application's bundle for an auto-discoverable plist.
|
||||||
|
* (XXX refer to more information on that)
|
||||||
|
*
|
||||||
|
* If you pass a dictionary to this method, it must include the
|
||||||
|
* <code>GROWL_APP_NAME</code> key, unless a delegate is set.
|
||||||
|
*
|
||||||
|
* This method is mainly an alternative to the delegate system introduced
|
||||||
|
* with Growl 0.6. Without a delegate, you cannot receive callbacks such as
|
||||||
|
* <code>-growlIsReady</code> (since they are sent to the delegate). You can,
|
||||||
|
* however, set a delegate after registering without one.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
*/
|
||||||
|
+ (BOOL) registerWithDictionary:(NSDictionary *)regDict;
|
||||||
|
|
||||||
|
/*! @method reregisterGrowlNotifications
|
||||||
|
* @abstract Reregister the notifications for this application.
|
||||||
|
* @discussion This method does not normally need to be called. If your
|
||||||
|
* application changes what notifications it is registering with Growl, call
|
||||||
|
* this method to have the Growl delegate's
|
||||||
|
* <code>-registrationDictionaryForGrowl</code> method called again and the
|
||||||
|
* Growl registration information updated.
|
||||||
|
*
|
||||||
|
* This method is now implemented using <code>-registerWithDictionary:</code>.
|
||||||
|
*/
|
||||||
|
+ (void) reregisterGrowlNotifications;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @method setWillRegisterWhenGrowlIsReady:
|
||||||
|
* @abstract Tells GrowlApplicationBridge to register with Growl when Growl
|
||||||
|
* launches (or not).
|
||||||
|
* @discussion When Growl has started listening for notifications, it posts a
|
||||||
|
* <code>GROWL_IS_READY</code> notification on the Distributed Notification
|
||||||
|
* Center. GrowlApplicationBridge listens for this notification, using it to
|
||||||
|
* perform various tasks (such as calling your delegate's
|
||||||
|
* <code>-growlIsReady</code> method, if it has one). If this method is
|
||||||
|
* called with <code>YES</code>, one of those tasks will be to reregister
|
||||||
|
* with Growl (in the manner of <code>-reregisterGrowlNotifications</code>).
|
||||||
|
*
|
||||||
|
* This attribute is automatically set back to <code>NO</code> (the default)
|
||||||
|
* after every <code>GROWL_IS_READY</code> notification.
|
||||||
|
* @param flag <code>YES</code> if you want GrowlApplicationBridge to register with
|
||||||
|
* Growl when next it is ready; <code>NO</code> if not.
|
||||||
|
*/
|
||||||
|
+ (void) setWillRegisterWhenGrowlIsReady:(BOOL)flag;
|
||||||
|
/*! @method willRegisterWhenGrowlIsReady
|
||||||
|
* @abstract Reports whether GrowlApplicationBridge will register with Growl
|
||||||
|
* when Growl next launches.
|
||||||
|
* @result <code>YES</code> if GrowlApplicationBridge will register with Growl
|
||||||
|
* when next it posts GROWL_IS_READY; <code>NO</code> if not.
|
||||||
|
*/
|
||||||
|
+ (BOOL) willRegisterWhenGrowlIsReady;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @method registrationDictionaryFromDelegate
|
||||||
|
* @abstract Asks the delegate for a registration dictionary.
|
||||||
|
* @discussion If no delegate is set, or if the delegate's
|
||||||
|
* <code>-registrationDictionaryForGrowl</code> method returns
|
||||||
|
* <code>nil</code>, this method returns <code>nil</code>.
|
||||||
|
*
|
||||||
|
* This method does not attempt to clean up the dictionary in any way - for
|
||||||
|
* example, if it is missing the <code>GROWL_APP_NAME</code> key, the result
|
||||||
|
* will be missing it too. Use <code>+[GrowlApplicationBridge
|
||||||
|
* registrationDictionaryByFillingInDictionary:]</code> or
|
||||||
|
* <code>+[GrowlApplicationBridge
|
||||||
|
* registrationDictionaryByFillingInDictionary:restrictToKeys:]</code> to try
|
||||||
|
* to fill in missing keys.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) registrationDictionaryFromDelegate;
|
||||||
|
|
||||||
|
/*! @method registrationDictionaryFromBundle:
|
||||||
|
* @abstract Looks in a bundle for a registration dictionary.
|
||||||
|
* @discussion This method looks in a bundle for an auto-discoverable
|
||||||
|
* registration dictionary file using <code>-[NSBundle
|
||||||
|
* pathForResource:ofType:]</code>. If it finds one, it loads the file using
|
||||||
|
* <code>+[NSDictionary dictionaryWithContentsOfFile:]</code> and returns the
|
||||||
|
* result.
|
||||||
|
*
|
||||||
|
* If you pass <code>nil</code> as the bundle, the main bundle is examined.
|
||||||
|
*
|
||||||
|
* This method does not attempt to clean up the dictionary in any way - for
|
||||||
|
* example, if it is missing the <code>GROWL_APP_NAME</code> key, the result
|
||||||
|
* will be missing it too. Use <code>+[GrowlApplicationBridge
|
||||||
|
* registrationDictionaryByFillingInDictionary:]</code> or
|
||||||
|
* <code>+[GrowlApplicationBridge
|
||||||
|
* registrationDictionaryByFillingInDictionary:restrictToKeys:]</code> to try
|
||||||
|
* to fill in missing keys.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) registrationDictionaryFromBundle:(NSBundle *)bundle;
|
||||||
|
|
||||||
|
/*! @method bestRegistrationDictionary
|
||||||
|
* @abstract Obtains a registration dictionary, filled out to the best of
|
||||||
|
* GrowlApplicationBridge's knowledge.
|
||||||
|
* @discussion This method creates a registration dictionary as best
|
||||||
|
* GrowlApplicationBridge knows how.
|
||||||
|
*
|
||||||
|
* First, GrowlApplicationBridge contacts the Growl delegate (if there is
|
||||||
|
* one) and gets the registration dictionary from that. If no such dictionary
|
||||||
|
* was obtained, GrowlApplicationBridge looks in your application's main
|
||||||
|
* bundle for an auto-discoverable registration dictionary file. If that
|
||||||
|
* doesn't exist either, this method returns <code>nil</code>.
|
||||||
|
*
|
||||||
|
* Second, GrowlApplicationBridge calls
|
||||||
|
* <code>+registrationDictionaryByFillingInDictionary:</code> with whatever
|
||||||
|
* dictionary was obtained. The result of that method is the result of this
|
||||||
|
* method.
|
||||||
|
*
|
||||||
|
* GrowlApplicationBridge uses this method when you call
|
||||||
|
* <code>+setGrowlDelegate:</code>, or when you call
|
||||||
|
* <code>+registerWithDictionary:</code> with <code>nil</code>.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @result A registration dictionary.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) bestRegistrationDictionary;
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*! @method registrationDictionaryByFillingInDictionary:
|
||||||
|
* @abstract Tries to fill in missing keys in a registration dictionary.
|
||||||
|
* @discussion This method examines the passed-in dictionary for missing keys,
|
||||||
|
* and tries to work out correct values for them. As of 0.7, it uses:
|
||||||
|
*
|
||||||
|
* Key Value
|
||||||
|
* --- -----
|
||||||
|
* <code>GROWL_APP_NAME</code> <code>CFBundleExecutableName</code>
|
||||||
|
* <code>GROWL_APP_ICON</code> The icon of the application.
|
||||||
|
* <code>GROWL_APP_LOCATION</code> The location of the application.
|
||||||
|
* <code>GROWL_NOTIFICATIONS_DEFAULT</code> <code>GROWL_NOTIFICATIONS_ALL</code>
|
||||||
|
*
|
||||||
|
* Keys are only filled in if missing; if a key is present in the dictionary,
|
||||||
|
* its value will not be changed.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @param regDict The dictionary to fill in.
|
||||||
|
* @result The dictionary with the keys filled in. This is an autoreleased
|
||||||
|
* copy of <code>regDict</code>.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) registrationDictionaryByFillingInDictionary:(NSDictionary *)regDict;
|
||||||
|
/*! @method registrationDictionaryByFillingInDictionary:restrictToKeys:
|
||||||
|
* @abstract Tries to fill in missing keys in a registration dictionary.
|
||||||
|
* @discussion This method examines the passed-in dictionary for missing keys,
|
||||||
|
* and tries to work out correct values for them. As of 0.7, it uses:
|
||||||
|
*
|
||||||
|
* Key Value
|
||||||
|
* --- -----
|
||||||
|
* <code>GROWL_APP_NAME</code> <code>CFBundleExecutableName</code>
|
||||||
|
* <code>GROWL_APP_ICON</code> The icon of the application.
|
||||||
|
* <code>GROWL_APP_LOCATION</code> The location of the application.
|
||||||
|
* <code>GROWL_NOTIFICATIONS_DEFAULT</code> <code>GROWL_NOTIFICATIONS_ALL</code>
|
||||||
|
*
|
||||||
|
* Only those keys that are listed in <code>keys</code> will be filled in.
|
||||||
|
* Other missing keys are ignored. Also, keys are only filled in if missing;
|
||||||
|
* if a key is present in the dictionary, its value will not be changed.
|
||||||
|
*
|
||||||
|
* This method was introduced in Growl.framework 0.7.
|
||||||
|
* @param regDict The dictionary to fill in.
|
||||||
|
* @param keys The keys to fill in. If <code>nil</code>, any missing keys are filled in.
|
||||||
|
* @result The dictionary with the keys filled in. This is an autoreleased
|
||||||
|
* copy of <code>regDict</code>.
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) registrationDictionaryByFillingInDictionary:(NSDictionary *)regDict restrictToKeys:(NSSet *)keys;
|
||||||
|
|
||||||
|
/*! @brief Tries to fill in missing keys in a notification dictionary.
|
||||||
|
* @param notifDict The dictionary to fill in.
|
||||||
|
* @return The dictionary with the keys filled in. This will be a separate instance from \a notifDict.
|
||||||
|
* @discussion This function examines the \a notifDict for missing keys, and
|
||||||
|
* tries to get them from the last known registration dictionary. As of 1.1,
|
||||||
|
* the keys that it will look for are:
|
||||||
|
*
|
||||||
|
* \li <code>GROWL_APP_NAME</code>
|
||||||
|
* \li <code>GROWL_APP_ICON</code>
|
||||||
|
*
|
||||||
|
* @since Growl.framework 1.1
|
||||||
|
*/
|
||||||
|
+ (NSDictionary *) notificationDictionaryByFillingInDictionary:(NSDictionary *)regDict;
|
||||||
|
|
||||||
|
+ (NSDictionary *) frameworkInfoDictionary;
|
||||||
|
@end
|
||||||
|
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @protocol GrowlApplicationBridgeDelegate
|
||||||
|
* @abstract Required protocol for the Growl delegate.
|
||||||
|
* @discussion The methods in this protocol are required and are called
|
||||||
|
* automatically as needed by GrowlApplicationBridge. See
|
||||||
|
* <code>+[GrowlApplicationBridge setGrowlDelegate:]</code>.
|
||||||
|
* See also <code>GrowlApplicationBridgeDelegate_InformalProtocol</code>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
@protocol GrowlApplicationBridgeDelegate
|
||||||
|
|
||||||
|
// -registrationDictionaryForGrowl has moved to the informal protocol as of 0.7.
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
#pragma mark -
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @category NSObject(GrowlApplicationBridgeDelegate_InformalProtocol)
|
||||||
|
* @abstract Methods which may be optionally implemented by the GrowlDelegate.
|
||||||
|
* @discussion The methods in this informal protocol will only be called if implemented by the delegate.
|
||||||
|
*/
|
||||||
|
@interface NSObject (GrowlApplicationBridgeDelegate_InformalProtocol)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method registrationDictionaryForGrowl
|
||||||
|
* @abstract Return the dictionary used to register this application with Growl.
|
||||||
|
* @discussion The returned dictionary gives Growl the complete list of
|
||||||
|
* notifications this application will ever send, and it also specifies which
|
||||||
|
* notifications should be enabled by default. Each is specified by an array
|
||||||
|
* of <code>NSString</code> objects.
|
||||||
|
*
|
||||||
|
* For most applications, these two arrays can be the same (if all sent
|
||||||
|
* notifications should be displayed by default).
|
||||||
|
*
|
||||||
|
* The <code>NSString</code> objects of these arrays will correspond to the
|
||||||
|
* <code>notificationName:</code> parameter passed in
|
||||||
|
* <code>+[GrowlApplicationBridge
|
||||||
|
* notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:]</code> calls.
|
||||||
|
*
|
||||||
|
* The dictionary should have the required key object pairs:
|
||||||
|
* key: GROWL_NOTIFICATIONS_ALL object: <code>NSArray</code> of <code>NSString</code> objects
|
||||||
|
* key: GROWL_NOTIFICATIONS_DEFAULT object: <code>NSArray</code> of <code>NSString</code> objects
|
||||||
|
*
|
||||||
|
* The dictionary may have the following key object pairs:
|
||||||
|
* key: GROWL_NOTIFICATIONS_HUMAN_READABLE_NAMES object: <code>NSDictionary</code> of key: notification name object: human-readable notification name
|
||||||
|
*
|
||||||
|
* You do not need to implement this method if you have an auto-discoverable
|
||||||
|
* plist file in your app bundle. (XXX refer to more information on that)
|
||||||
|
*
|
||||||
|
* @result The <code>NSDictionary</code> to use for registration.
|
||||||
|
*/
|
||||||
|
- (NSDictionary *) registrationDictionaryForGrowl;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method applicationNameForGrowl
|
||||||
|
* @abstract Return the name of this application which will be used for Growl bookkeeping.
|
||||||
|
* @discussion This name is used both internally and in the Growl preferences.
|
||||||
|
*
|
||||||
|
* This should remain stable between different versions and incarnations of
|
||||||
|
* your application.
|
||||||
|
* For example, "SurfWriter" is a good app name, whereas "SurfWriter 2.0" and
|
||||||
|
* "SurfWriter Lite" are not.
|
||||||
|
*
|
||||||
|
* You do not need to implement this method if you are providing the
|
||||||
|
* application name elsewhere, meaning in an auto-discoverable plist file in
|
||||||
|
* your app bundle (XXX refer to more information on that) or in the result
|
||||||
|
* of -registrationDictionaryForGrowl.
|
||||||
|
*
|
||||||
|
* @result The name of the application using Growl.
|
||||||
|
*/
|
||||||
|
- (NSString *) applicationNameForGrowl;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method applicationIconForGrowl
|
||||||
|
* @abstract Return the <code>NSImage</code> to treat as the application icon.
|
||||||
|
* @discussion The delegate may optionally return an <code>NSImage</code>
|
||||||
|
* object to use as the application icon. If this method is not implemented,
|
||||||
|
* {{{-applicationIconDataForGrowl}}} is tried. If that method is not
|
||||||
|
* implemented, the application's own icon is used. Neither method is
|
||||||
|
* generally needed.
|
||||||
|
* @result The <code>NSImage</code> to treat as the application icon.
|
||||||
|
*/
|
||||||
|
- (NSImage *) applicationIconForGrowl;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method applicationIconDataForGrowl
|
||||||
|
* @abstract Return the <code>NSData</code> to treat as the application icon.
|
||||||
|
* @discussion The delegate may optionally return an <code>NSData</code>
|
||||||
|
* object to use as the application icon; if this is not implemented, the
|
||||||
|
* application's own icon is used. This is not generally needed.
|
||||||
|
* @result The <code>NSData</code> to treat as the application icon.
|
||||||
|
* @deprecated In version 1.1, in favor of {{{-applicationIconForGrowl}}}.
|
||||||
|
*/
|
||||||
|
- (NSData *) applicationIconDataForGrowl;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlIsReady
|
||||||
|
* @abstract Informs the delegate that Growl has launched.
|
||||||
|
* @discussion Informs the delegate that Growl (specifically, the
|
||||||
|
* GrowlHelperApp) was launched successfully. The application can take actions
|
||||||
|
* with the knowledge that Growl is installed and functional.
|
||||||
|
*/
|
||||||
|
- (void) growlIsReady;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlNotificationWasClicked:
|
||||||
|
* @abstract Informs the delegate that a Growl notification was clicked.
|
||||||
|
* @discussion Informs the delegate that a Growl notification was clicked. It
|
||||||
|
* is only sent for notifications sent with a non-<code>nil</code>
|
||||||
|
* clickContext, so if you want to receive a message when a notification is
|
||||||
|
* clicked, clickContext must not be <code>nil</code> when calling
|
||||||
|
* <code>+[GrowlApplicationBridge notifyWithTitle: description:notificationName:iconData:priority:isSticky:clickContext:]</code>.
|
||||||
|
* @param clickContext The clickContext passed when displaying the notification originally via +[GrowlApplicationBridge notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:].
|
||||||
|
*/
|
||||||
|
- (void) growlNotificationWasClicked:(id)clickContext;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlNotificationTimedOut:
|
||||||
|
* @abstract Informs the delegate that a Growl notification timed out.
|
||||||
|
* @discussion Informs the delegate that a Growl notification timed out. It
|
||||||
|
* is only sent for notifications sent with a non-<code>nil</code>
|
||||||
|
* clickContext, so if you want to receive a message when a notification is
|
||||||
|
* clicked, clickContext must not be <code>nil</code> when calling
|
||||||
|
* <code>+[GrowlApplicationBridge notifyWithTitle: description:notificationName:iconData:priority:isSticky:clickContext:]</code>.
|
||||||
|
* @param clickContext The clickContext passed when displaying the notification originally via +[GrowlApplicationBridge notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:].
|
||||||
|
*/
|
||||||
|
- (void) growlNotificationTimedOut:(id)clickContext;
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
#pragma mark -
|
||||||
|
/*!
|
||||||
|
* @category NSObject(GrowlApplicationBridgeDelegate_Installation_InformalProtocol)
|
||||||
|
* @abstract Methods which may be optionally implemented by the Growl delegate when used with Growl-WithInstaller.framework.
|
||||||
|
* @discussion The methods in this informal protocol will only be called if
|
||||||
|
* implemented by the delegate. They allow greater control of the information
|
||||||
|
* presented to the user when installing or upgrading Growl from within your
|
||||||
|
* application when using Growl-WithInstaller.framework.
|
||||||
|
*/
|
||||||
|
@interface NSObject (GrowlApplicationBridgeDelegate_Installation_InformalProtocol)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlInstallationWindowTitle
|
||||||
|
* @abstract Return the title of the installation window.
|
||||||
|
* @discussion If not implemented, Growl will use a default, localized title.
|
||||||
|
* @result An NSString object to use as the title.
|
||||||
|
*/
|
||||||
|
- (NSString *)growlInstallationWindowTitle;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlUpdateWindowTitle
|
||||||
|
* @abstract Return the title of the upgrade window.
|
||||||
|
* @discussion If not implemented, Growl will use a default, localized title.
|
||||||
|
* @result An NSString object to use as the title.
|
||||||
|
*/
|
||||||
|
- (NSString *)growlUpdateWindowTitle;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlInstallationInformation
|
||||||
|
* @abstract Return the information to display when installing.
|
||||||
|
* @discussion This information may be as long or short as desired (the window
|
||||||
|
* will be sized to fit it). It will be displayed to the user as an
|
||||||
|
* explanation of what Growl is and what it can do in your application. It
|
||||||
|
* should probably note that no download is required to install.
|
||||||
|
*
|
||||||
|
* If this is not implemented, Growl will use a default, localized explanation.
|
||||||
|
* @result An NSAttributedString object to display.
|
||||||
|
*/
|
||||||
|
- (NSAttributedString *)growlInstallationInformation;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @method growlUpdateInformation
|
||||||
|
* @abstract Return the information to display when upgrading.
|
||||||
|
* @discussion This information may be as long or short as desired (the window
|
||||||
|
* will be sized to fit it). It will be displayed to the user as an
|
||||||
|
* explanation that an updated version of Growl is included in your
|
||||||
|
* application and no download is required.
|
||||||
|
*
|
||||||
|
* If this is not implemented, Growl will use a default, localized explanation.
|
||||||
|
* @result An NSAttributedString object to display.
|
||||||
|
*/
|
||||||
|
- (NSAttributedString *)growlUpdateInformation;
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
//private
|
||||||
|
@interface GrowlApplicationBridge (GrowlInstallationPrompt_private)
|
||||||
|
+ (void) _userChoseNotToInstallGrowl;
|
||||||
|
@end
|
||||||
|
|
||||||
|
#endif /* __GrowlApplicationBridge_h__ */
|
|
@ -0,0 +1,348 @@
|
||||||
|
//
|
||||||
|
// GrowlDefines.h
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef _GROWLDEFINES_H
|
||||||
|
#define _GROWLDEFINES_H
|
||||||
|
|
||||||
|
#ifdef __OBJC__
|
||||||
|
#define XSTR(x) (@x)
|
||||||
|
#define STRING_TYPE NSString *
|
||||||
|
#else
|
||||||
|
#define XSTR CFSTR
|
||||||
|
#define STRING_TYPE CFStringRef
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*! @header GrowlDefines.h
|
||||||
|
* @abstract Defines all the notification keys.
|
||||||
|
* @discussion Defines all the keys used for registration with Growl and for
|
||||||
|
* Growl notifications.
|
||||||
|
*
|
||||||
|
* Most applications should use the functions or methods of Growl.framework
|
||||||
|
* instead of posting notifications such as those described here.
|
||||||
|
* @updated 2004-01-25
|
||||||
|
*/
|
||||||
|
|
||||||
|
// UserInfo Keys for Registration
|
||||||
|
#pragma mark UserInfo Keys for Registration
|
||||||
|
|
||||||
|
/*! @group Registration userInfo keys */
|
||||||
|
/* @abstract Keys for the userInfo dictionary of a GROWL_APP_REGISTRATION distributed notification.
|
||||||
|
* @discussion The values of these keys describe the application and the
|
||||||
|
* notifications it may post.
|
||||||
|
*
|
||||||
|
* Your application must register with Growl before it can post Growl
|
||||||
|
* notifications (and have them not be ignored). However, as of Growl 0.6,
|
||||||
|
* posting GROWL_APP_REGISTRATION notifications directly is no longer the
|
||||||
|
* preferred way to register your application. Your application should instead
|
||||||
|
* use Growl.framework's delegate system.
|
||||||
|
* See +[GrowlApplicationBridge setGrowlDelegate:] or Growl_SetDelegate for
|
||||||
|
* more information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! @defined GROWL_APP_NAME
|
||||||
|
* @abstract The name of your application.
|
||||||
|
* @discussion The name of your application. This should remain stable between
|
||||||
|
* different versions and incarnations of your application.
|
||||||
|
* For example, "SurfWriter" is a good app name, whereas "SurfWriter 2.0" and
|
||||||
|
* "SurfWriter Lite" are not.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_NAME XSTR("ApplicationName")
|
||||||
|
/*! @defined GROWL_APP_ID
|
||||||
|
* @abstract The bundle identifier of your application.
|
||||||
|
* @discussion The bundle identifier of your application. This key should
|
||||||
|
* be unique for your application while there may be several applications
|
||||||
|
* with the same GROWL_APP_NAME.
|
||||||
|
* This key is optional.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_ID XSTR("ApplicationId")
|
||||||
|
/*! @defined GROWL_APP_ICON
|
||||||
|
* @abstract The image data for your application's icon.
|
||||||
|
* @discussion Image data representing your application's icon. This may be
|
||||||
|
* superimposed on a notification icon as a badge, used as the notification
|
||||||
|
* icon when a notification-specific icon is not supplied, or ignored
|
||||||
|
* altogether, depending on the display. Must be in a format supported by
|
||||||
|
* NSImage, such as TIFF, PNG, GIF, JPEG, BMP, PICT, or PDF.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_ICON XSTR("ApplicationIcon")
|
||||||
|
/*! @defined GROWL_NOTIFICATIONS_DEFAULT
|
||||||
|
* @abstract The array of notifications to turn on by default.
|
||||||
|
* @discussion These are the names of the notifications that should be enabled
|
||||||
|
* by default when your application registers for the first time. If your
|
||||||
|
* application reregisters, Growl will look here for any new notification
|
||||||
|
* names found in GROWL_NOTIFICATIONS_ALL, but ignore any others.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATIONS_DEFAULT XSTR("DefaultNotifications")
|
||||||
|
/*! @defined GROWL_NOTIFICATIONS_ALL
|
||||||
|
* @abstract The array of all notifications your application can send.
|
||||||
|
* @discussion These are the names of all of the notifications that your
|
||||||
|
* application may post. See GROWL_NOTIFICATION_NAME for a discussion of good
|
||||||
|
* notification names.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATIONS_ALL XSTR("AllNotifications")
|
||||||
|
/*! @defined GROWL_NOTIFICATIONS_HUMAN_READABLE_DESCRIPTIONS
|
||||||
|
* @abstract A dictionary of human-readable names for your notifications.
|
||||||
|
* @discussion By default, the Growl UI will display notifications by the names given in GROWL_NOTIFICATIONS_ALL
|
||||||
|
* which correspond to the GROWL_NOTIFICATION_NAME. This dictionary specifies the human-readable name to display.
|
||||||
|
* The keys of the dictionary are GROWL_NOTIFICATION_NAME strings; the objects are the human-readable versions.
|
||||||
|
* For any GROWL_NOTIFICATION_NAME not specific in this dictionary, the GROWL_NOTIFICATION_NAME will be displayed.
|
||||||
|
*
|
||||||
|
* This key is optional.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATIONS_HUMAN_READABLE_NAMES XSTR("HumanReadableNames")
|
||||||
|
/*! @defined GROWL_NOTIFICATIONS_DESCRIPTIONS
|
||||||
|
* @abstract A dictionary of descriptions of _when_ each notification occurs
|
||||||
|
* @discussion This is an NSDictionary whose keys are GROWL_NOTIFICATION_NAME strings and whose objects are
|
||||||
|
* descriptions of _when_ each notification occurs, such as "You received a new mail message" or
|
||||||
|
* "A file finished downloading".
|
||||||
|
*
|
||||||
|
* This key is optional.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATIONS_DESCRIPTIONS XSTR("NotificationDescriptions")
|
||||||
|
|
||||||
|
/*! @defined GROWL_TICKET_VERSION
|
||||||
|
* @abstract The version of your registration ticket.
|
||||||
|
* @discussion Include this key in a ticket plist file that you put in your
|
||||||
|
* application bundle for auto-discovery. The current ticket version is 1.
|
||||||
|
*/
|
||||||
|
#define GROWL_TICKET_VERSION XSTR("TicketVersion")
|
||||||
|
// UserInfo Keys for Notifications
|
||||||
|
#pragma mark UserInfo Keys for Notifications
|
||||||
|
|
||||||
|
/*! @group Notification userInfo keys */
|
||||||
|
/* @abstract Keys for the userInfo dictionary of a GROWL_NOTIFICATION distributed notification.
|
||||||
|
* @discussion The values of these keys describe the content of a Growl
|
||||||
|
* notification.
|
||||||
|
*
|
||||||
|
* Not all of these keys are supported by all displays. Only the name, title,
|
||||||
|
* and description of a notification are universal. Most of the built-in
|
||||||
|
* displays do support all of these keys, and most other visual displays
|
||||||
|
* probably will also. But, as of 0.6, the Log, MailMe, and Speech displays
|
||||||
|
* support only textual data.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! @defined GROWL_NOTIFICATION_NAME
|
||||||
|
* @abstract The name of the notification.
|
||||||
|
* @discussion The name of the notification. Note that if you do not define
|
||||||
|
* GROWL_NOTIFICATIONS_HUMAN_READABLE_NAMES when registering your ticket originally this name
|
||||||
|
* will the one displayed within the Growl preference pane and should be human-readable.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_NAME XSTR("NotificationName")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_TITLE
|
||||||
|
* @abstract The title to display in the notification.
|
||||||
|
* @discussion The title of the notification. Should be very brief.
|
||||||
|
* The title usually says what happened, e.g. "Download complete".
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_TITLE XSTR("NotificationTitle")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_DESCRIPTION
|
||||||
|
* @abstract The description to display in the notification.
|
||||||
|
* @discussion The description should be longer and more verbose than the title.
|
||||||
|
* The description usually tells the subject of the action,
|
||||||
|
* e.g. "Growl-0.6.dmg downloaded in 5.02 minutes".
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_DESCRIPTION XSTR("NotificationDescription")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_ICON
|
||||||
|
* @discussion Image data for the notification icon. Must be in a format
|
||||||
|
* supported by NSImage, such as TIFF, PNG, GIF, JPEG, BMP, PICT, or PDF.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_ICON XSTR("NotificationIcon")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_APP_ICON
|
||||||
|
* @discussion Image data for the application icon, in case GROWL_APP_ICON does
|
||||||
|
* not apply for some reason. Must be in a format supported by NSImage, such
|
||||||
|
* as TIFF, PNG, GIF, JPEG, BMP, PICT, or PDF.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_APP_ICON XSTR("NotificationAppIcon")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_PRIORITY
|
||||||
|
* @discussion The priority of the notification as an integer number from
|
||||||
|
* -2 to +2 (+2 being highest).
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_PRIORITY XSTR("NotificationPriority")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_STICKY
|
||||||
|
* @discussion A Boolean number controlling whether the notification is sticky.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_STICKY XSTR("NotificationSticky")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_CLICK_CONTEXT
|
||||||
|
* @abstract Identifies which notification was clicked.
|
||||||
|
* @discussion An identifier for the notification for clicking purposes.
|
||||||
|
*
|
||||||
|
* This will be passed back to the application when the notification is
|
||||||
|
* clicked. It must be plist-encodable (a data, dictionary, array, number, or
|
||||||
|
* string object), and it should be unique for each notification you post.
|
||||||
|
* A good click context would be a UUID string returned by NSProcessInfo or
|
||||||
|
* CFUUID.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_CLICK_CONTEXT XSTR("NotificationClickContext")
|
||||||
|
|
||||||
|
/*! @defined GROWL_DISPLAY_PLUGIN
|
||||||
|
* @discussion The name of a display plugin which should be used for this notification.
|
||||||
|
* Optional. If this key is not set or the specified display plugin does not
|
||||||
|
* exist, the display plugin stored in the application ticket is used. This key
|
||||||
|
* allows applications to use different default display plugins for their
|
||||||
|
* notifications. The user can still override those settings in the preference
|
||||||
|
* pane.
|
||||||
|
*/
|
||||||
|
#define GROWL_DISPLAY_PLUGIN XSTR("NotificationDisplayPlugin")
|
||||||
|
|
||||||
|
/*! @defined GROWL_NOTIFICATION_IDENTIFIER
|
||||||
|
* @abstract An identifier for the notification for coalescing purposes.
|
||||||
|
* Notifications with the same identifier fall into the same class; only
|
||||||
|
* the last notification of a class is displayed on the screen. If a
|
||||||
|
* notification of the same class is currently being displayed, it is
|
||||||
|
* replaced by this notification.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_IDENTIFIER XSTR("GrowlNotificationIdentifier")
|
||||||
|
|
||||||
|
/*! @defined GROWL_APP_PID
|
||||||
|
* @abstract The process identifier of the process which sends this
|
||||||
|
* notification. If this field is set, the application will only receive
|
||||||
|
* clicked and timed out notifications which originate from this process.
|
||||||
|
*
|
||||||
|
* Optional.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_PID XSTR("ApplicationPID")
|
||||||
|
|
||||||
|
/*! @defined GROWL_NOTIFICATION_PROGRESS
|
||||||
|
* @abstract If this key is set, it should contain a double value wrapped
|
||||||
|
* in a NSNumber which describes some sort of progress (from 0.0 to 100.0).
|
||||||
|
* If this is key is not set, no progress bar is shown.
|
||||||
|
*
|
||||||
|
* Optional. Not supported by all display plugins.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_PROGRESS XSTR("NotificationProgress")
|
||||||
|
|
||||||
|
// Notifications
|
||||||
|
#pragma mark Notifications
|
||||||
|
|
||||||
|
/*! @group Notification names */
|
||||||
|
/* @abstract Names of distributed notifications used by Growl.
|
||||||
|
* @discussion These are notifications used by applications (directly or
|
||||||
|
* indirectly) to interact with Growl, and by Growl for interaction between
|
||||||
|
* its components.
|
||||||
|
*
|
||||||
|
* Most of these should no longer be used in Growl 0.6 and later, in favor of
|
||||||
|
* Growl.framework's GrowlApplicationBridge APIs.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! @defined GROWL_APP_REGISTRATION
|
||||||
|
* @abstract The distributed notification for registering your application.
|
||||||
|
* @discussion This is the name of the distributed notification that can be
|
||||||
|
* used to register applications with Growl.
|
||||||
|
*
|
||||||
|
* The userInfo dictionary for this notification can contain these keys:
|
||||||
|
* <ul>
|
||||||
|
* <li>GROWL_APP_NAME</li>
|
||||||
|
* <li>GROWL_APP_ICON</li>
|
||||||
|
* <li>GROWL_NOTIFICATIONS_ALL</li>
|
||||||
|
* <li>GROWL_NOTIFICATIONS_DEFAULT</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* No longer recommended as of Growl 0.6. An alternate method of registering
|
||||||
|
* is to use Growl.framework's delegate system.
|
||||||
|
* See +[GrowlApplicationBridge setGrowlDelegate:] or Growl_SetDelegate for
|
||||||
|
* more information.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_REGISTRATION XSTR("GrowlApplicationRegistrationNotification")
|
||||||
|
/*! @defined GROWL_APP_REGISTRATION_CONF
|
||||||
|
* @abstract The distributed notification for confirming registration.
|
||||||
|
* @discussion The name of the distributed notification sent to confirm the
|
||||||
|
* registration. Used by the Growl preference pane. Your application probably
|
||||||
|
* does not need to use this notification.
|
||||||
|
*/
|
||||||
|
#define GROWL_APP_REGISTRATION_CONF XSTR("GrowlApplicationRegistrationConfirmationNotification")
|
||||||
|
/*! @defined GROWL_NOTIFICATION
|
||||||
|
* @abstract The distributed notification for Growl notifications.
|
||||||
|
* @discussion This is what it all comes down to. This is the name of the
|
||||||
|
* distributed notification that your application posts to actually send a
|
||||||
|
* Growl notification.
|
||||||
|
*
|
||||||
|
* The userInfo dictionary for this notification can contain these keys:
|
||||||
|
* <ul>
|
||||||
|
* <li>GROWL_NOTIFICATION_NAME (required)</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_TITLE (required)</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_DESCRIPTION (required)</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_ICON</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_APP_ICON</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_PRIORITY</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_STICKY</li>
|
||||||
|
* <li>GROWL_NOTIFICATION_CLICK_CONTEXT</li>
|
||||||
|
* <li>GROWL_APP_NAME (required)</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* No longer recommended as of Growl 0.6. Three alternate methods of posting
|
||||||
|
* notifications are +[GrowlApplicationBridge notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:],
|
||||||
|
* Growl_NotifyWithTitleDescriptionNameIconPriorityStickyClickContext, and
|
||||||
|
* Growl_PostNotification.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION XSTR("GrowlNotification")
|
||||||
|
/*! @defined GROWL_SHUTDOWN
|
||||||
|
* @abstract The distributed notification name that tells Growl to shutdown.
|
||||||
|
* @discussion The Growl preference pane posts this notification when the
|
||||||
|
* "Stop Growl" button is clicked.
|
||||||
|
*/
|
||||||
|
#define GROWL_SHUTDOWN XSTR("GrowlShutdown")
|
||||||
|
/*! @defined GROWL_PING
|
||||||
|
* @abstract A distributed notification to check whether Growl is running.
|
||||||
|
* @discussion This is used by the Growl preference pane. If it receives a
|
||||||
|
* GROWL_PONG, the preference pane takes this to mean that Growl is running.
|
||||||
|
*/
|
||||||
|
#define GROWL_PING XSTR("Honey, Mind Taking Out The Trash")
|
||||||
|
/*! @defined GROWL_PONG
|
||||||
|
* @abstract The distributed notification sent in reply to GROWL_PING.
|
||||||
|
* @discussion GrowlHelperApp posts this in reply to GROWL_PING.
|
||||||
|
*/
|
||||||
|
#define GROWL_PONG XSTR("What Do You Want From Me, Woman")
|
||||||
|
/*! @defined GROWL_IS_READY
|
||||||
|
* @abstract The distributed notification sent when Growl starts up.
|
||||||
|
* @discussion GrowlHelperApp posts this when it has begin listening on all of
|
||||||
|
* its sources for new notifications. GrowlApplicationBridge (in
|
||||||
|
* Growl.framework), upon receiving this notification, reregisters using the
|
||||||
|
* registration dictionary supplied by its delegate.
|
||||||
|
*/
|
||||||
|
#define GROWL_IS_READY XSTR("Lend Me Some Sugar; I Am Your Neighbor!")
|
||||||
|
/*! @defined GROWL_NOTIFICATION_CLICKED
|
||||||
|
* @abstract The distributed notification sent when a supported notification is clicked.
|
||||||
|
* @discussion When a Growl notification with a click context is clicked on by
|
||||||
|
* the user, Growl posts this distributed notification.
|
||||||
|
* The GrowlApplicationBridge responds to this notification by calling a
|
||||||
|
* callback in its delegate.
|
||||||
|
*/
|
||||||
|
#define GROWL_NOTIFICATION_CLICKED XSTR("GrowlClicked!")
|
||||||
|
#define GROWL_NOTIFICATION_TIMED_OUT XSTR("GrowlTimedOut!")
|
||||||
|
|
||||||
|
/*! @group Other symbols */
|
||||||
|
/* Symbols which don't fit into any of the other categories. */
|
||||||
|
|
||||||
|
/*! @defined GROWL_KEY_CLICKED_CONTEXT
|
||||||
|
* @abstract Used internally as the key for the clickedContext passed over DNC.
|
||||||
|
* @discussion This key is used in GROWL_NOTIFICATION_CLICKED, and contains the
|
||||||
|
* click context that was supplied in the original notification.
|
||||||
|
*/
|
||||||
|
#define GROWL_KEY_CLICKED_CONTEXT XSTR("ClickedContext")
|
||||||
|
/*! @defined GROWL_REG_DICT_EXTENSION
|
||||||
|
* @abstract The filename extension for registration dictionaries.
|
||||||
|
* @discussion The GrowlApplicationBridge in Growl.framework registers with
|
||||||
|
* Growl by creating a file with the extension of .(GROWL_REG_DICT_EXTENSION)
|
||||||
|
* and opening it in the GrowlHelperApp. This happens whether or not Growl is
|
||||||
|
* running; if it was stopped, it quits immediately without listening for
|
||||||
|
* notifications.
|
||||||
|
*/
|
||||||
|
#define GROWL_REG_DICT_EXTENSION XSTR("growlRegDict")
|
||||||
|
|
||||||
|
|
||||||
|
#define GROWL_POSITION_PREFERENCE_KEY @"GrowlSelectedPosition"
|
||||||
|
|
||||||
|
#endif //ndef _GROWLDEFINES_H
|
|
@ -0,0 +1,24 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>CFBundleDevelopmentRegion</key>
|
||||||
|
<string>English</string>
|
||||||
|
<key>CFBundleExecutable</key>
|
||||||
|
<string>Growl</string>
|
||||||
|
<key>CFBundleIdentifier</key>
|
||||||
|
<string>com.growl.growlframework</string>
|
||||||
|
<key>CFBundleInfoDictionaryVersion</key>
|
||||||
|
<string>6.0</string>
|
||||||
|
<key>CFBundlePackageType</key>
|
||||||
|
<string>FMWK</string>
|
||||||
|
<key>CFBundleShortVersionString</key>
|
||||||
|
<string>1.2.1</string>
|
||||||
|
<key>CFBundleSignature</key>
|
||||||
|
<string>GRRR</string>
|
||||||
|
<key>CFBundleVersion</key>
|
||||||
|
<string>1.2.1</string>
|
||||||
|
<key>NSPrincipalClass</key>
|
||||||
|
<string>GrowlApplicationBridge</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
|
@ -0,0 +1 @@
|
||||||
|
A
|
34
build/Debug/CIDGrowl.app/Contents/Info.plist
Normal file
34
build/Debug/CIDGrowl.app/Contents/Info.plist
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>CFBundleDevelopmentRegion</key>
|
||||||
|
<string>English</string>
|
||||||
|
<key>CFBundleExecutable</key>
|
||||||
|
<string>CIDGrowl</string>
|
||||||
|
<key>CFBundleIconFile</key>
|
||||||
|
<string>CIDGrowlIcon.icns</string>
|
||||||
|
<key>CFBundleIdentifier</key>
|
||||||
|
<string>net.theamigan.CIDGrowl</string>
|
||||||
|
<key>CFBundleInfoDictionaryVersion</key>
|
||||||
|
<string>6.0</string>
|
||||||
|
<key>CFBundleName</key>
|
||||||
|
<string>CIDGrowl</string>
|
||||||
|
<key>CFBundlePackageType</key>
|
||||||
|
<string>APPL</string>
|
||||||
|
<key>CFBundleShortVersionString</key>
|
||||||
|
<string>0.1</string>
|
||||||
|
<key>CFBundleSignature</key>
|
||||||
|
<string>????</string>
|
||||||
|
<key>CFBundleVersion</key>
|
||||||
|
<string>1</string>
|
||||||
|
<key>LSMinimumSystemVersion</key>
|
||||||
|
<string>10.6</string>
|
||||||
|
<key>LSUIElement</key>
|
||||||
|
<true/>
|
||||||
|
<key>NSMainNibFile</key>
|
||||||
|
<string>MainMenu</string>
|
||||||
|
<key>NSPrincipalClass</key>
|
||||||
|
<string>NSApplication</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
BIN
build/Debug/CIDGrowl.app/Contents/MacOS/CIDGrowl
Executable file
BIN
build/Debug/CIDGrowl.app/Contents/MacOS/CIDGrowl
Executable file
Binary file not shown.
1
build/Debug/CIDGrowl.app/Contents/PkgInfo
Normal file
1
build/Debug/CIDGrowl.app/Contents/PkgInfo
Normal file
|
@ -0,0 +1 @@
|
||||||
|
APPL????
|
BIN
build/Debug/CIDGrowl.app/Contents/Resources/CIDGrowlIcon.icns
Normal file
BIN
build/Debug/CIDGrowl.app/Contents/Resources/CIDGrowlIcon.icns
Normal file
Binary file not shown.
Binary file not shown.
BIN
build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/MainMenu.nib
generated
Normal file
BIN
build/Debug/CIDGrowl.app/Contents/Resources/English.lproj/MainMenu.nib
generated
Normal file
Binary file not shown.
|
@ -0,0 +1,20 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<!--
|
||||||
|
Growl Registration Ticket.growlRegDict
|
||||||
|
CIDGrowl
|
||||||
|
-->
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>TicketVersion</key>
|
||||||
|
<integer>1</integer>
|
||||||
|
<key>AllNotifications</key>
|
||||||
|
<array>
|
||||||
|
<string>Phone Call</string>
|
||||||
|
</array>
|
||||||
|
<key>DefaultNotifications</key>
|
||||||
|
<array>
|
||||||
|
<string>Phone Call</string>
|
||||||
|
</array>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
BIN
build/Debug/CIDGrowl.app/Contents/Resources/bigicon.png
Normal file
BIN
build/Debug/CIDGrowl.app/Contents/Resources/bigicon.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 17 KiB |
BIN
build/Debug/CIDGrowl.app/Contents/Resources/growlicon.tif
Normal file
BIN
build/Debug/CIDGrowl.app/Contents/Resources/growlicon.tif
Normal file
Binary file not shown.
BIN
build/Debug/CIDGrowl.app/Contents/Resources/menu22.tif
Normal file
BIN
build/Debug/CIDGrowl.app/Contents/Resources/menu22.tif
Normal file
Binary file not shown.
BIN
build/Debug/CIDGrowl.app/Contents/Resources/menuic.png
Normal file
BIN
build/Debug/CIDGrowl.app/Contents/Resources/menuic.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.1 KiB |
BIN
growlicon.tif
Normal file
BIN
growlicon.tif
Normal file
Binary file not shown.
14
main.m
Normal file
14
main.m
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
//
|
||||||
|
// main.m
|
||||||
|
// CIDGrowl
|
||||||
|
//
|
||||||
|
// Created by Dan Ponte on 1/30/10.
|
||||||
|
// Copyright 2010 __MyCompanyName__. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
#import <Cocoa/Cocoa.h>
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
return NSApplicationMain(argc, (const char **) argv);
|
||||||
|
}
|
BIN
menu22.tif
Normal file
BIN
menu22.tif
Normal file
Binary file not shown.
BIN
menuic.png
Normal file
BIN
menuic.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.1 KiB |
Loading…
Reference in a new issue