From d0353ecb5f5335fef0a143c885f7c938427f995d Mon Sep 17 00:00:00 2001 From: Mitchell Livingston Date: Sun, 4 Nov 2007 00:54:46 +0000 Subject: [PATCH] add new growl 1.1.2 --- macosx/Growl.framework/Growl | 1 + macosx/Growl.framework/Headers | 1 + macosx/Growl.framework/Resources | 1 + macosx/Growl.framework/Versions/A/Growl | Bin 0 -> 134672 bytes .../Versions/A/Headers/Growl.h | 6 + .../A/Headers/GrowlApplicationBridge-Carbon.h | 780 ++++++++++++++++++ .../A/Headers/GrowlApplicationBridge.h | 609 ++++++++++++++ .../Versions/A/Headers/GrowlDefines.h | 348 ++++++++ .../Versions/A/Resources/Info.plist | 24 + macosx/Growl.framework/Versions/Current | 1 + 10 files changed, 1771 insertions(+) create mode 120000 macosx/Growl.framework/Growl create mode 120000 macosx/Growl.framework/Headers create mode 120000 macosx/Growl.framework/Resources create mode 100755 macosx/Growl.framework/Versions/A/Growl create mode 100644 macosx/Growl.framework/Versions/A/Headers/Growl.h create mode 100644 macosx/Growl.framework/Versions/A/Headers/GrowlApplicationBridge-Carbon.h create mode 100644 macosx/Growl.framework/Versions/A/Headers/GrowlApplicationBridge.h create mode 100644 macosx/Growl.framework/Versions/A/Headers/GrowlDefines.h create mode 100644 macosx/Growl.framework/Versions/A/Resources/Info.plist create mode 120000 macosx/Growl.framework/Versions/Current diff --git a/macosx/Growl.framework/Growl b/macosx/Growl.framework/Growl new file mode 120000 index 000000000..85956e2d2 --- /dev/null +++ b/macosx/Growl.framework/Growl @@ -0,0 +1 @@ +Versions/Current/Growl \ No newline at end of file diff --git a/macosx/Growl.framework/Headers b/macosx/Growl.framework/Headers new file mode 120000 index 000000000..a177d2a6b --- /dev/null +++ b/macosx/Growl.framework/Headers @@ -0,0 +1 @@ +Versions/Current/Headers \ No newline at end of file diff --git a/macosx/Growl.framework/Resources b/macosx/Growl.framework/Resources new file mode 120000 index 000000000..953ee36f3 --- /dev/null +++ b/macosx/Growl.framework/Resources @@ -0,0 +1 @@ +Versions/Current/Resources \ No newline at end of file diff --git a/macosx/Growl.framework/Versions/A/Growl b/macosx/Growl.framework/Versions/A/Growl new file mode 100755 index 0000000000000000000000000000000000000000..1b6668aa1102c38e47e5126b78457e02672df20d GIT binary patch literal 134672 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 literal 0 HcmV?d00001 diff --git a/macosx/Growl.framework/Versions/A/Headers/Growl.h b/macosx/Growl.framework/Versions/A/Headers/Growl.h new file mode 100644 index 000000000..e2a44255d --- /dev/null +++ b/macosx/Growl.framework/Versions/A/Headers/Growl.h @@ -0,0 +1,6 @@ +#include "GrowlDefines.h" + +#ifdef __OBJC__ +# include "GrowlApplicationBridge.h" +#endif +#include "GrowlApplicationBridge-Carbon.h" diff --git a/macosx/Growl.framework/Versions/A/Headers/GrowlApplicationBridge-Carbon.h b/macosx/Growl.framework/Versions/A/Headers/GrowlApplicationBridge-Carbon.h new file mode 100644 index 000000000..e35663f63 --- /dev/null +++ b/macosx/Growl.framework/Versions/A/Headers/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 +#include + +#ifndef GROWL_EXPORT +#define GROWL_EXPORT __attribute__((visibility("default"))) +#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 NULL). + * 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 NULL 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 NULL). + * 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 NULL). + * + * If you change the contents of this dictionary after setting the delegate, + * be sure to call Growl_Reregister. + * + * This can be NULL 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 NULL, a localised default will be + * supplied. + */ + + /* If this is NULL, 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 NULL, 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 NULL, 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 NULL, 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-NULL) and your release + * callback (if non-NULL). + */ + 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 NULL). + * For a delegate allocated with malloc, this member would be + * NULL. + * @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 + * free(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-NULL clickContext, + * so if you want to receive a message when a notification is clicked, + * clickContext must not be NULL 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-NULL clickContext, + * so if you want to receive a message when a notification is clicked, + * clickContext must not be NULL 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 NULL. 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 NULL, and your click callback + * is not NULL 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 NULL, it will be called instead + * of the Growl delegate's click callback when clickContext is + * non-NULL 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 NULL, except for + * size (which will be set to sizeof(struct Growl_Delegate)) 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 NULL, except + * for size (which will be set to + * sizeof(struct Growl_Notification)). + */ +#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-NULL, but at least one + * required member of it is NULL). Otherwise, sets or unsets the + * delegate and returns true. + * @discussion When newDelegate is non-NULL, sets + * the delegate to newDelegate. When it is NULL, + * the current delegate will be unset, and no delegate will be in place. + * + * It is legal for newDelegate to be the current delegate; + * nothing will happen, and Growl_SetDelegate will return true. It is also + * legal for it to be NULL, 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-NULL. If + * newDelegate is non-NULL, Growl_SetDelegate will + * call newDelegate->retain, 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 + * NULL 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 + * NULL (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 NULL. + * @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 NULL, 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 NULL, 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 + * GROWL_APP_NAME 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 + * growlIsReady (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 false 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-NULL. + * + * This function is now implemented using + * Growl_RegisterWithDictionary. + */ +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 + * GROWL_IS_READY notification on the Distributed Notification + * Center. GrowlApplicationBridge listens for this notification, using it to + * perform various tasks (such as calling your delegate's + * growlIsReady callback, if it has one). If this function is + * called with true, one of those tasks will be to reregister + * with Growl (in the manner of Growl_Reregister). + * + * This attribute is automatically set back to false + * (the default) after every GROWL_IS_READY notification. + * @param flag true if you want GrowlApplicationBridge to register with + * Growl when next it is ready; false 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 true if GrowlApplicationBridge will register with + * Growl when next it posts GROWL_IS_READY; false 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 + * registrationDictionary member is NULL, this + * function returns NULL. + * + * This function does not attempt to clean up the dictionary in any way - for + * example, if it is missing the GROWL_APP_NAME key, the result + * will be missing it too. Use + * Growl_CreateRegistrationDictionaryByFillingInDictionary or + * Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys + * 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 CFBundleCopyResourceURL. + * If it finds one, it loads the file using CFPropertyList and + * returns the result. + * + * If you pass NULL 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 GROWL_APP_NAME key, the result + * will be missing it too. Use + * Growl_CreateRegistrationDictionaryByFillingInDictionary: or + * Growl_CreateRegistrationDictionaryByFillingInDictionaryRestrictedToKeys + * 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 NULL. + * + * Second, GrowlApplicationBridge calls + * Growl_CreateRegistrationDictionaryByFillingInDictionary with + * whatever dictionary was obtained. The result of that function is the + * result of this function. + * + * GrowlApplicationBridge uses this function when you call + * Growl_SetDelegate, or when you call + * Growl_RegisterWithDictionary with NULL. + * + * 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 + * --- ----- + * GROWL_APP_NAME CFBundleExecutableName + * GROWL_APP_ICON The icon of the application. + * GROWL_APP_LOCATION The location of the application. + * GROWL_NOTIFICATIONS_DEFAULT GROWL_NOTIFICATIONS_ALL + * + * 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 NULL, 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 + * --- ----- + * GROWL_APP_NAME CFBundleExecutableName + * GROWL_APP_ICON The icon of the application. + * GROWL_APP_LOCATION The location of the application. + * GROWL_NOTIFICATIONS_DEFAULT GROWL_NOTIFICATIONS_ALL + * + * Only those keys that are listed in keys 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 GROWL_APP_NAME + * \li GROWL_APP_ICON + * + * @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 NULL. + * @param context The context pointer to pass to the callback. Can be NULL. + * @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 + * NULL) 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 Growl_CreateBestRegistrationDictionary returns + * non-NULL, 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 NULL. The callback itself can be + * NULL 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_ */ diff --git a/macosx/Growl.framework/Versions/A/Headers/GrowlApplicationBridge.h b/macosx/Growl.framework/Versions/A/Headers/GrowlApplicationBridge.h new file mode 100644 index 000000000..4341f3fbd --- /dev/null +++ b/macosx/Growl.framework/Versions/A/Headers/GrowlApplicationBridge.h @@ -0,0 +1,609 @@ +// +// 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 +#import +#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 *)inDelegate; + +/*! + * @method growlDelegate + * @abstract Return the object responsible for providing and receiving Growl information. + * @discussion See setGrowlDelegate: for details. + * @result The Growl delegate. + */ ++ (NSObject *) 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 + * nil (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 NSData object to show with the notification as its icon. If nil, 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 NSString, NSArray, NSNumber, NSDictionary, and NSData 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 + * nil (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 NSData object to show with the notification as its icon. If nil, 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 NSString, NSArray, NSNumber, NSDictionary, and NSData 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 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 + * nil (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 NSData object to show with the notification as its icon. If nil, 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 NSString, NSArray, NSNumber, NSDictionary, and NSData 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 + * NSDistributedNotificationCenter. + * @param userInfo The dictionary to notify with. + * @discussion Before Growl 0.6, your application would have posted + * notifications using NSDistributedNotificationCenter 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 NSDistributedNotificationCenter. 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 nil, 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 + * GROWL_APP_NAME 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 + * -growlIsReady (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 + * -registrationDictionaryForGrowl method called again and the + * Growl registration information updated. + * + * This method is now implemented using -registerWithDictionary:. + */ ++ (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 + * GROWL_IS_READY notification on the Distributed Notification + * Center. GrowlApplicationBridge listens for this notification, using it to + * perform various tasks (such as calling your delegate's + * -growlIsReady method, if it has one). If this method is + * called with YES, one of those tasks will be to reregister + * with Growl (in the manner of -reregisterGrowlNotifications). + * + * This attribute is automatically set back to NO (the default) + * after every GROWL_IS_READY notification. + * @param flag YES if you want GrowlApplicationBridge to register with + * Growl when next it is ready; NO if not. + */ ++ (void) setWillRegisterWhenGrowlIsReady:(BOOL)flag; +/*! @method willRegisterWhenGrowlIsReady + * @abstract Reports whether GrowlApplicationBridge will register with Growl + * when Growl next launches. + * @result YES if GrowlApplicationBridge will register with Growl + * when next it posts GROWL_IS_READY; NO 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 + * -registrationDictionaryForGrowl method returns + * nil, this method returns nil. + * + * This method does not attempt to clean up the dictionary in any way - for + * example, if it is missing the GROWL_APP_NAME key, the result + * will be missing it too. Use +[GrowlApplicationBridge + * registrationDictionaryByFillingInDictionary:] or + * +[GrowlApplicationBridge + * registrationDictionaryByFillingInDictionary:restrictToKeys:] 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 -[NSBundle + * pathForResource:ofType:]. If it finds one, it loads the file using + * +[NSDictionary dictionaryWithContentsOfFile:] and returns the + * result. + * + * If you pass nil 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 GROWL_APP_NAME key, the result + * will be missing it too. Use +[GrowlApplicationBridge + * registrationDictionaryByFillingInDictionary:] or + * +[GrowlApplicationBridge + * registrationDictionaryByFillingInDictionary:restrictToKeys:] 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 nil. + * + * Second, GrowlApplicationBridge calls + * +registrationDictionaryByFillingInDictionary: with whatever + * dictionary was obtained. The result of that method is the result of this + * method. + * + * GrowlApplicationBridge uses this method when you call + * +setGrowlDelegate:, or when you call + * +registerWithDictionary: with nil. + * + * 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 + * --- ----- + * GROWL_APP_NAME CFBundleExecutableName + * GROWL_APP_ICON The icon of the application. + * GROWL_APP_LOCATION The location of the application. + * GROWL_NOTIFICATIONS_DEFAULT GROWL_NOTIFICATIONS_ALL + * + * 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 regDict. + */ ++ (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 + * --- ----- + * GROWL_APP_NAME CFBundleExecutableName + * GROWL_APP_ICON The icon of the application. + * GROWL_APP_LOCATION The location of the application. + * GROWL_NOTIFICATIONS_DEFAULT GROWL_NOTIFICATIONS_ALL + * + * Only those keys that are listed in keys 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 nil, any missing keys are filled in. + * @result The dictionary with the keys filled in. This is an autoreleased + * copy of regDict. + */ ++ (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 GROWL_APP_NAME + * \li GROWL_APP_ICON + * + * @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 + * +[GrowlApplicationBridge setGrowlDelegate:]. + * See also GrowlApplicationBridgeDelegate_InformalProtocol. + */ + +@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 NSString objects. + * + * For most applications, these two arrays can be the same (if all sent + * notifications should be displayed by default). + * + * The NSString objects of these arrays will correspond to the + * notificationName: parameter passed in + * +[GrowlApplicationBridge + * notifyWithTitle:description:notificationName:iconData:priority:isSticky:clickContext:] calls. + * + * The dictionary should have the required key object pairs: + * key: GROWL_NOTIFICATIONS_ALL object: NSArray of NSString objects + * key: GROWL_NOTIFICATIONS_DEFAULT object: NSArray of NSString objects + * + * The dictionary may have the following key object pairs: + * key: GROWL_NOTIFICATIONS_HUMAN_READABLE_NAMES object: NSDictionary 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 NSDictionary 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 NSImage to treat as the application icon. + * @discussion The delegate may optionally return an NSImage + * 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 NSImage to treat as the application icon. + */ +- (NSImage *) applicationIconForGrowl; + +/*! + * @method applicationIconDataForGrowl + * @abstract Return the NSData to treat as the application icon. + * @discussion The delegate may optionally return an NSData + * 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 NSData 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-nil + * clickContext, so if you want to receive a message when a notification is + * clicked, clickContext must not be nil when calling + * +[GrowlApplicationBridge notifyWithTitle: description:notificationName:iconData:priority:isSticky:clickContext:]. + * @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-nil + * clickContext, so if you want to receive a message when a notification is + * clicked, clickContext must not be nil when calling + * +[GrowlApplicationBridge notifyWithTitle: description:notificationName:iconData:priority:isSticky:clickContext:]. + * @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__ */ diff --git a/macosx/Growl.framework/Versions/A/Headers/GrowlDefines.h b/macosx/Growl.framework/Versions/A/Headers/GrowlDefines.h new file mode 100644 index 000000000..2b971cfe5 --- /dev/null +++ b/macosx/Growl.framework/Versions/A/Headers/GrowlDefines.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: + *
    + *
  • GROWL_APP_NAME
  • + *
  • GROWL_APP_ICON
  • + *
  • GROWL_NOTIFICATIONS_ALL
  • + *
  • GROWL_NOTIFICATIONS_DEFAULT
  • + *
+ * + * 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: + *
    + *
  • GROWL_NOTIFICATION_NAME (required)
  • + *
  • GROWL_NOTIFICATION_TITLE (required)
  • + *
  • GROWL_NOTIFICATION_DESCRIPTION (required)
  • + *
  • GROWL_NOTIFICATION_ICON
  • + *
  • GROWL_NOTIFICATION_APP_ICON
  • + *
  • GROWL_NOTIFICATION_PRIORITY
  • + *
  • GROWL_NOTIFICATION_STICKY
  • + *
  • GROWL_NOTIFICATION_CLICK_CONTEXT
  • + *
  • GROWL_APP_NAME (required)
  • + *
+ * + * 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 diff --git a/macosx/Growl.framework/Versions/A/Resources/Info.plist b/macosx/Growl.framework/Versions/A/Resources/Info.plist new file mode 100644 index 000000000..ab7194d2d --- /dev/null +++ b/macosx/Growl.framework/Versions/A/Resources/Info.plist @@ -0,0 +1,24 @@ + + + + + CFBundleDevelopmentRegion + English + CFBundleExecutable + Growl + CFBundleIdentifier + com.growl.growlframework + CFBundleInfoDictionaryVersion + 6.0 + CFBundlePackageType + FMWK + CFBundleShortVersionString + 1.1.2 + CFBundleSignature + GRRR + CFBundleVersion + 1.1.2 + NSPrincipalClass + GrowlApplicationBridge + + diff --git a/macosx/Growl.framework/Versions/Current b/macosx/Growl.framework/Versions/Current new file mode 120000 index 000000000..8c7e5a667 --- /dev/null +++ b/macosx/Growl.framework/Versions/Current @@ -0,0 +1 @@ +A \ No newline at end of file