mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
865b6b404d
[originally from svn r8037]
197 lines
5.4 KiB
C
197 lines
5.4 KiB
C
/* $Id$ */
|
|
/*
|
|
* Copyright (c) 2003 Ben Harris
|
|
* Copyright (c) 1997-2003 Simon Tatham
|
|
* All rights reserved.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person
|
|
* obtaining a copy of this software and associated documentation
|
|
* files (the "Software"), to deal in the Software without
|
|
* restriction, including without limitation the rights to use,
|
|
* copy, modify, merge, publish, distribute, sublicense, and/or
|
|
* sell copies of the Software, and to permit persons to whom the
|
|
* Software is furnished to do so, subject to the following
|
|
* conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be
|
|
* included in all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
|
|
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE.
|
|
*/
|
|
|
|
/* Stuff to handle the key window in PuTTYgen */
|
|
|
|
#include <MacTypes.h>
|
|
#include <Controls.h>
|
|
#include <Dialogs.h>
|
|
#include <MacWindows.h>
|
|
|
|
#include "putty.h"
|
|
#include "mac.h"
|
|
#include "macpgrid.h"
|
|
#include "ssh.h"
|
|
|
|
/* ----------------------------------------------------------------------
|
|
* Progress report code. This is really horrible :-)
|
|
*/
|
|
#define PROGRESSRANGE 65535
|
|
#define MAXPHASE 5
|
|
struct progress {
|
|
int nphases;
|
|
struct {
|
|
int exponential;
|
|
unsigned startpoint, total;
|
|
unsigned param, current, n; /* if exponential */
|
|
unsigned mult; /* if linear */
|
|
} phases[MAXPHASE];
|
|
unsigned total, divisor, range;
|
|
ControlHandle progbar;
|
|
};
|
|
|
|
static void progress_update(void *param, int action, int phase, int iprogress)
|
|
{
|
|
struct progress *p = (struct progress *) param;
|
|
unsigned progress = iprogress;
|
|
int position;
|
|
|
|
if (action < PROGFN_READY && p->nphases < phase)
|
|
p->nphases = phase;
|
|
switch (action) {
|
|
case PROGFN_INITIALISE:
|
|
p->nphases = 0;
|
|
break;
|
|
case PROGFN_LIN_PHASE:
|
|
p->phases[phase-1].exponential = 0;
|
|
p->phases[phase-1].mult = p->phases[phase].total / progress;
|
|
break;
|
|
case PROGFN_EXP_PHASE:
|
|
p->phases[phase-1].exponential = 1;
|
|
p->phases[phase-1].param = 0x10000 + progress;
|
|
p->phases[phase-1].current = p->phases[phase-1].total;
|
|
p->phases[phase-1].n = 0;
|
|
break;
|
|
case PROGFN_PHASE_EXTENT:
|
|
p->phases[phase-1].total = progress;
|
|
break;
|
|
case PROGFN_READY:
|
|
{
|
|
unsigned total = 0;
|
|
int i;
|
|
for (i = 0; i < p->nphases; i++) {
|
|
p->phases[i].startpoint = total;
|
|
total += p->phases[i].total;
|
|
}
|
|
p->total = total;
|
|
p->divisor = ((p->total + PROGRESSRANGE - 1) / PROGRESSRANGE);
|
|
p->range = p->total / p->divisor;
|
|
SetControlMaximum(p->progbar, p->range);
|
|
}
|
|
break;
|
|
case PROGFN_PROGRESS:
|
|
if (p->phases[phase-1].exponential) {
|
|
while (p->phases[phase-1].n < progress) {
|
|
p->phases[phase-1].n++;
|
|
p->phases[phase-1].current *= p->phases[phase-1].param;
|
|
p->phases[phase-1].current /= 0x10000;
|
|
}
|
|
position = (p->phases[phase-1].startpoint +
|
|
p->phases[phase-1].total - p->phases[phase-1].current);
|
|
} else {
|
|
position = (p->phases[phase-1].startpoint +
|
|
progress * p->phases[phase-1].mult);
|
|
}
|
|
SetControlValue(p->progbar, position / p->divisor);
|
|
break;
|
|
}
|
|
}
|
|
|
|
static void mac_clickkey(WindowPtr window, EventRecord *event)
|
|
{
|
|
short item;
|
|
DialogRef dialog;
|
|
KeyState *ks = mac_windowkey(window);
|
|
|
|
dialog = GetDialogFromWindow(window);
|
|
if (DialogSelect(event, &dialog, &item))
|
|
switch (item) {
|
|
case wiKeyGenerate:
|
|
SetControlMaximum(ks->progress, 1024);
|
|
ks->entropy = snewn(1024, unsigned int);
|
|
ks->entropy_required = 1024;
|
|
ks->entropy_got = 0;
|
|
ks->collecting_entropy = TRUE;
|
|
/* Do something */
|
|
break;
|
|
}
|
|
}
|
|
|
|
static void mac_activatekey(WindowPtr window, EventRecord *event)
|
|
{
|
|
DialogRef dialog;
|
|
DialogItemType itemtype;
|
|
Handle itemhandle;
|
|
short item;
|
|
Rect itemrect;
|
|
int active;
|
|
|
|
dialog = GetDialogFromWindow(window);
|
|
active = (event->modifiers & activeFlag) != 0;
|
|
GetDialogItem(dialog, wiKeyGenerate, &itemtype, &itemhandle, &itemrect);
|
|
HiliteControl((ControlHandle)itemhandle, active ? 0 : 255);
|
|
DialogSelect(event, &dialog, &item);
|
|
}
|
|
|
|
static void mac_updatekey(WindowPtr window)
|
|
{
|
|
#if TARGET_API_MAC_CARBON
|
|
RgnHandle rgn;
|
|
#endif
|
|
|
|
BeginUpdate(window);
|
|
#if TARGET_API_MAC_CARBON
|
|
rgn = NewRgn();
|
|
GetPortVisibleRegion(GetWindowPort(window), rgn);
|
|
UpdateDialog(GetDialogFromWindow(window), rgn);
|
|
DisposeRgn(rgn);
|
|
#else
|
|
UpdateDialog(window, window->visRgn);
|
|
#endif
|
|
EndUpdate(window);
|
|
}
|
|
|
|
void mac_newkey(void)
|
|
{
|
|
KeyState *ks;
|
|
WinInfo *wi;
|
|
Handle h;
|
|
short type;
|
|
Rect rect;
|
|
|
|
ks = snew(KeyState);
|
|
ks->box = GetNewDialog(wKey, NULL, (WindowPtr)-1);
|
|
GetDialogItem(ks->box, wiKeyProgress, &type, &h, &rect);
|
|
ks->progress = (ControlHandle)h;
|
|
wi = snew(WinInfo);
|
|
memset(wi, 0, sizeof(*wi));
|
|
wi->ks = ks;
|
|
wi->wtype = wKey;
|
|
wi->update = &mac_updatekey;
|
|
wi->click = &mac_clickkey;
|
|
wi->activate = &mac_activatekey;
|
|
SetWRefCon(GetDialogWindow(ks->box), (long)wi);
|
|
ShowWindow(GetDialogWindow(ks->box));
|
|
}
|
|
|
|
/*
|
|
* Local Variables:
|
|
* c-file-style: "simon"
|
|
* End:
|
|
*/
|