jcs
/wallops
/amendments
/58
main+chatter: Implement menu updating for cut/copy/paste
jcs made amendment 58 4 months ago
--- chatter.c Fri Aug 30 20:08:34 2024
+++ chatter.c Sat Aug 31 20:05:57 2024
@@ -42,6 +42,7 @@ void chatter_key_down(struct focusable *focusable, Eve
void chatter_mouse_down(struct focusable *focusable, EventRecord *event);
void chatter_resize(struct focusable *focusable, EventRecord *event);
bool chatter_menu(struct focusable *focusable, short menu, short item);
+void chatter_update_menu(struct focusable *focusable);
void chatter_idle(struct focusable *focusable, EventRecord *event);
void chatter_update(struct focusable *focusable, EventRecord *event);
void chatter_resume(struct focusable *focusable, EventRecord *event);
@@ -109,6 +110,7 @@ chatter_init(const char *server, const unsigned short
focusable->quit = chatter_quit;
focusable->resize = chatter_resize;
focusable->menu = chatter_menu;
+ focusable->update_menu = chatter_update_menu;
focusable->resume = chatter_resume;
focusable_add(focusable);
chatter->focusable = focusable;
@@ -809,6 +811,37 @@ chatter_menu(struct focusable *focusable, short menu,
}
return false;
+}
+
+void
+chatter_update_menu(struct focusable *focusable)
+{
+ struct chatter *chatter = (struct chatter *)(focusable->cookie);
+ struct chatter_tab *tab = chatter->current_tab;
+
+ HLock(chatter->input_te);
+ HLock(tab->messages_te);
+
+ EnableItem(edit_menu, EDIT_MENU_PASTE_ID);
+
+ if ((*(chatter->input_te))->selStart != (*(chatter->input_te))->selEnd) {
+ EnableItem(edit_menu, EDIT_MENU_CUT_ID);
+ EnableItem(edit_menu, EDIT_MENU_COPY_ID);
+ goto done;
+ }
+
+ if ((*(tab->messages_te))->selStart != (*(tab->messages_te))->selEnd) {
+ DisableItem(edit_menu, EDIT_MENU_CUT_ID);
+ EnableItem(edit_menu, EDIT_MENU_COPY_ID);
+ goto done;
+ }
+
+ DisableItem(edit_menu, EDIT_MENU_CUT_ID);
+ DisableItem(edit_menu, EDIT_MENU_COPY_ID);
+
+done:
+ HUnlock(tab->messages_te);
+ HUnlock(chatter->input_te);
}
void
--- chatter.h Fri Aug 30 17:22:56 2024
+++ chatter.h Fri Aug 30 21:58:59 2024
@@ -73,6 +73,8 @@ struct chatter {
struct chatter_tab *current_tab;
};
+extern MenuHandle apple_menu, file_menu, edit_menu;
+
void notify(void);
void cancel_notification(void);
--- focusable.h Sat Jan 7 19:16:17 2023
+++ focusable.h Fri Aug 30 21:53:59 2024
@@ -31,6 +31,7 @@ struct focusable {
void (*mouse_down)(struct focusable *focusable, EventRecord *event);
void (*resize)(struct focusable *focusable, EventRecord *event);
bool (*menu)(struct focusable *focusable, short menu, short item);
+ void (*update_menu)(struct focusable *focusable);
void (*suspend)(struct focusable *focusable, EventRecord *event);
void (*resume)(struct focusable *focusable, EventRecord *event);
bool (*close)(struct focusable *focusable);
--- main.c Fri Aug 30 19:21:35 2024
+++ main.c Fri Aug 30 22:20:53 2024
@@ -21,9 +21,9 @@
#include "tcp.h"
#include "util.h"
-MenuHandle apple_menu, file_menu;
NMRec notification = { 0 };
struct settings settings;
+MenuHandle apple_menu, file_menu, edit_menu;
void update_menu(void);
void handle_exit(void);
@@ -67,6 +67,8 @@ main(void)
AddResMenu(apple_menu, 'DRVR');
if (!(file_menu = GetMHandle(FILE_MENU_ID)))
panic("no file menu");
+ if (!(edit_menu = GetMHandle(EDIT_MENU_ID)))
+ panic("no edit menu");
update_menu();
DrawMenuBar();
@@ -146,6 +148,8 @@ main(void)
found_focusable->mouse_down(found_focusable, &event);
break;
}
+
+ update_menu();
break;
case updateEvt:
case activateEvt:
@@ -184,6 +188,8 @@ main(void)
}
break;
}
+
+ update_menu();
}
break;
}
@@ -259,6 +265,17 @@ handle_menu(long menu_id)
void
update_menu(void)
{
+ if (nfocusables) {
+ if (focusables[0]->visible) {
+ EnableItem(edit_menu, 0);
+ if (focusables[0]->update_menu)
+ focusables[0]->update_menu(focusables[0]);
+ } else {
+ DisableItem(edit_menu, 0);
+ }
+ } else {
+ DisableItem(edit_menu, 0);
+ }
}
void