projects
/
u
/
mdw
/
putty
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Windows file selectors contain an edit box as well as the Browse
[u/mdw/putty]
/
mac
/
macevlog.c
diff --git
a/mac/macevlog.c
b/mac/macevlog.c
index
92e65bb
..
7eb047e
100644
(file)
--- a/
mac/macevlog.c
+++ b/
mac/macevlog.c
@@
-1,4
+1,4
@@
-/* $Id: macevlog.c,v 1.
2 2003/02/15 16:22:15
ben Exp $ */
+/* $Id: macevlog.c,v 1.
5 2003/02/23 13:00:38
ben Exp $ */
/*
* Copyright (c) 2003 Ben Harris
* All rights reserved.
/*
* Copyright (c) 2003 Ben Harris
* All rights reserved.
@@
-46,13
+46,11
@@
static void mac_clickeventlog(WindowPtr, EventRecord *);
static void mac_activateeventlog(WindowPtr, EventRecord *);
static void mac_groweventlog(WindowPtr, EventRecord *);
static void mac_updateeventlog(WindowPtr);
static void mac_activateeventlog(WindowPtr, EventRecord *);
static void mac_groweventlog(WindowPtr, EventRecord *);
static void mac_updateeventlog(WindowPtr);
+static void mac_closeeventlog(WindowPtr);
static void mac_createeventlog(Session *s)
{
Rect view;
static void mac_createeventlog(Session *s)
{
Rect view;
-#if TARGET_API_MAC_CARBON
- Rect controlrect;
-#endif
ListBounds bounds = { 0, 0, 0, 1 }; /* 1 column, 0 rows */
Point csize = { 0, 0 };
GrafPtr saveport;
ListBounds bounds = { 0, 0, 0, 1 }; /* 1 column, 0 rows */
Point csize = { 0, 0 };
GrafPtr saveport;
@@
-68,6
+66,7
@@
static void mac_createeventlog(Session *s)
wi->activate = &mac_activateeventlog;
wi->grow = &mac_groweventlog;
wi->update = &mac_updateeventlog;
wi->activate = &mac_activateeventlog;
wi->grow = &mac_groweventlog;
wi->update = &mac_updateeventlog;
+ wi->close = &mac_closeeventlog;
SetWRefCon(s->eventlog_window, (long)wi);
GetPort(&saveport);
SetPort((GrafPtr)GetWindowPort(s->eventlog_window));
SetWRefCon(s->eventlog_window, (long)wi);
GetPort(&saveport);
SetPort((GrafPtr)GetWindowPort(s->eventlog_window));
@@
-89,7
+88,6
@@
static void mac_createeventlog(Session *s)
#else
(*s->eventlog)->selFlags = lExtendDrag | lNoDisjoint | lNoExtend;
#endif
#else
(*s->eventlog)->selFlags = lExtendDrag | lNoDisjoint | lNoExtend;
#endif
- ShowWindow(s->eventlog_window);
}
void mac_freeeventlog(Session *s)
}
void mac_freeeventlog(Session *s)
@@
-113,7
+111,7
@@
void logevent(void *frontend, char *str)
{
Terminal *term = frontend;
Session *s = term->frontend;
{
Terminal *term = frontend;
Session *s = term->frontend;
- ListBounds bounds;
+ ListBounds bounds
, visible
;
Cell cell = { 0, 0 };
if (s->eventlog == NULL)
Cell cell = { 0, 0 };
if (s->eventlog == NULL)
@@
-123,12
+121,18
@@
void logevent(void *frontend, char *str)
#if TARGET_API_MAC_CARBON
GetListDataBounds(s->eventlog, &bounds);
#if TARGET_API_MAC_CARBON
GetListDataBounds(s->eventlog, &bounds);
+ GetListVisibleCells(s->eventlog, &visible);
#else
bounds = (*s->eventlog)->dataBounds;
#else
bounds = (*s->eventlog)->dataBounds;
+ visible = (*s->eventlog)->visible;
#endif
#endif
+
cell.v = bounds.bottom;
LAddRow(1, cell.v, s->eventlog);
LSetCell(str, strlen(str), cell, s->eventlog);
cell.v = bounds.bottom;
LAddRow(1, cell.v, s->eventlog);
LSetCell(str, strlen(str), cell, s->eventlog);
+ /* ">=" and "2" because there can be a blank cell below the last one. */
+ if (visible.bottom >= bounds.bottom)
+ LScroll(0, 2, s->eventlog);
}
static void mac_draweventloggrowicon(Session *s)
}
static void mac_draweventloggrowicon(Session *s)
@@
-249,9
+253,16
@@
static void mac_updateeventlog(WindowPtr window)
EndUpdate(window);
}
EndUpdate(window);
}
+static void mac_closeeventlog(WindowPtr window)
+{
+
+ HideWindow(window);
+}
+
void mac_showeventlog(Session *s)
{
void mac_showeventlog(Session *s)
{
+ SelectWindow(s->eventlog_window);
ShowWindow(s->eventlog_window);
}
ShowWindow(s->eventlog_window);
}