1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 09:58:01 +00:00

Add a mechanism for collecting entropy, and displaying how much we've got,

based on the Windows version.  We don't _do_ anything with the entropy yet,
though.

[originally from svn r2875]
This commit is contained in:
Ben Harris 2003-02-20 22:55:09 +00:00
parent f53c998569
commit bd149e7b1e
4 changed files with 124 additions and 4 deletions

View File

@ -1,4 +1,4 @@
/* $Id: macpgen.c,v 1.3 2003/02/16 14:27:37 ben Exp $ */ /* $Id: macpgen.c,v 1.4 2003/02/20 22:55:09 ben Exp $ */
/* /*
* Copyright (c) 1999, 2003 Ben Harris * Copyright (c) 1999, 2003 Ben Harris
* All rights reserved. * All rights reserved.
@ -204,12 +204,33 @@ static void mac_eventloop(void) {
Boolean gotevent; Boolean gotevent;
EventRecord event; EventRecord event;
RgnHandle cursrgn; RgnHandle cursrgn;
Point mousenow, mousethen;
KeyState *ks;
WindowPtr front;
cursrgn = NewRgn(); cursrgn = NewRgn();
GetMouse(&mousethen);
for (;;) { for (;;) {
mac_adjustcursor(cursrgn); mac_adjustcursor(cursrgn);
gotevent = WaitNextEvent(everyEvent, &event, LONG_MAX, cursrgn); gotevent = WaitNextEvent(everyEvent, &event, LONG_MAX, cursrgn);
mac_adjustcursor(cursrgn); mac_adjustcursor(cursrgn);
front = mac_frontwindow();
if (front != NULL) {
ks = mac_windowkey(front);
if (ks->collecting_entropy) {
GetMouse(&mousenow);
if (mousenow.h != mousethen.h || mousenow.v != mousethen.v) {
ks->entropy[ks->entropy_got++] = *(unsigned *)&mousenow;
ks->entropy[ks->entropy_got++] = TickCount();
if (ks->entropy_got >= ks->entropy_required)
ks->collecting_entropy = 0;
SetControlValue(ks->progress, ks->entropy_got);
mousethen = mousenow;
}
SetEmptyRgn(cursrgn);
}
}
if (gotevent) if (gotevent)
mac_event(&event); mac_event(&event);
if (borednow) if (borednow)

View File

@ -1,4 +1,4 @@
/* $Id: macpgen.r,v 1.3 2003/02/16 14:27:37 ben Exp $ */ /* $Id: macpgen.r,v 1.4 2003/02/20 22:55:09 ben Exp $ */
/* /*
* Copyright (c) 1999, 2002 Ben Harris * Copyright (c) 1999, 2002 Ben Harris
* All rights reserved. * All rights reserved.
@ -460,10 +460,19 @@ resource 'dlgx' (wKey, "key", purgeable) {
} }
}; };
#define cProgress 129
resource 'DITL' (wKey, "key", purgeable) { resource 'DITL' (wKey, "key", purgeable) {
{ {
{ 13, 13, 33, 227 }, { 13, 13, 33, 227 },
Button { enabled, "Generate" }, Button { enabled, "Generate" },
{ 46, 13, 12, 227 },
Control { enabled, cProgress },
} }
}; };
resource 'CNTL' (cProgress) {
{ 46, 13, 12, 227 },
0, visible, 0, 0,
kControlProgressBarProc, 0, ""
};

View File

@ -1,6 +1,7 @@
/* $Id: macpgkey.c,v 1.2 2003/02/16 14:27:37 ben Exp $ */ /* $Id: macpgkey.c,v 1.3 2003/02/20 22:55:09 ben Exp $ */
/* /*
* Copyright (c) 2003 Ben Harris * Copyright (c) 2003 Ben Harris
* Copyright (c) 1997-2003 Simon Tatham
* All rights reserved. * All rights reserved.
* *
* Permission is hereby granted, free of charge, to any person * Permission is hereby granted, free of charge, to any person
@ -28,22 +29,104 @@
/* Stuff to handle the key window in PuTTYgen */ /* Stuff to handle the key window in PuTTYgen */
#include <MacTypes.h> #include <MacTypes.h>
#include <Controls.h>
#include <Dialogs.h> #include <Dialogs.h>
#include <MacWindows.h> #include <MacWindows.h>
#include "putty.h" #include "putty.h"
#include "mac.h" #include "mac.h"
#include "macpgrid.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) static void mac_clickkey(WindowPtr window, EventRecord *event)
{ {
short item; short item;
DialogRef dialog; DialogRef dialog;
KeyState *ks = mac_windowkey(window);
dialog = GetDialogFromWindow(window); dialog = GetDialogFromWindow(window);
if (DialogSelect(event, &dialog, &item)) if (DialogSelect(event, &dialog, &item))
switch (item) { switch (item) {
case wiKeyGenerate: case wiKeyGenerate:
SetControlMaximum(ks->progress, 1024);
ks->entropy = smalloc(1024 * sizeof(*ks->entropy));
ks->entropy_required = 1024;
ks->entropy_got = 0;
ks->collecting_entropy = TRUE;
/* Do something */ /* Do something */
break; break;
} }
@ -87,9 +170,14 @@ void mac_newkey(void)
{ {
KeyState *ks; KeyState *ks;
WinInfo *wi; WinInfo *wi;
Handle h;
short type;
Rect rect;
ks = smalloc(sizeof(*ks)); ks = smalloc(sizeof(*ks));
ks->box = GetNewDialog(wKey, NULL, (WindowPtr)-1); ks->box = GetNewDialog(wKey, NULL, (WindowPtr)-1);
GetDialogItem(ks->box, wiKeyProgress, &type, &h, &rect);
ks->progress = (ControlHandle)h;
wi = smalloc(sizeof(*wi)); wi = smalloc(sizeof(*wi));
memset(wi, 0, sizeof(*wi)); memset(wi, 0, sizeof(*wi));
wi->ks = ks; wi->ks = ks;

View File

@ -1,4 +1,4 @@
/* $Id: macpgrid.h,v 1.3 2003/02/16 14:27:37 ben Exp $ */ /* $Id: macpgrid.h,v 1.4 2003/02/20 22:55:09 ben Exp $ */
/* /*
* macpgrid.h -- Mac resource IDs for PuTTYgen * macpgrid.h -- Mac resource IDs for PuTTYgen
@ -44,3 +44,5 @@
#define wLicence 131 #define wLicence 131
#define wKey 134 #define wKey 134
#define wiKeyGenerate 1 #define wiKeyGenerate 1
#define wiKeyProgress 2