home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
The Fred Fish Collection 1.5
/
ffcollection-1-5-1992-11.iso
/
ff_disks
/
500-599
/
ff589.lza
/
Term
/
TermSrc.lha
/
HotkeyPanel.c
< prev
next >
Wrap
C/C++ Source or Header
|
1991-11-03
|
13KB
|
427 lines
/* $Revision Header * Header built automatically - do not edit! *************
*
* (C) Copyright 1991 by Olaf 'Olsen' Barthel & MXM
*
* Name .....: HotkeyPanel.c
* Created ..: Wednesday 19-Jun-91 17:43
* Revision .: 0
*
* Date Author Comment
* ========= ======== ====================
* 19-Jun-91 Olsen Created this file!
*
* $Revision Header ********************************************************/
#include "TermGlobal.h"
enum { GAD_TERMTOFRONT,GAD_BUFFERTOFRONT,GAD_SKIP,GAD_PRIORITY,
GAD_SOMEHOTKEYS,GAD_USE,GAD_LOAD,GAD_SAVE,GAD_CANCEL };
#define WIDTH 527
#define HEIGHT 94
enum { MEN_PRIORITY,MEN_SOMEHOTKEYS,MEN_LOAD,MEN_SAVEIT,MEN_USE,MEN_CANCEL };
STATIC struct NewMenu HotkeyMenu[] =
{
{ NM_TITLE, "Project", 0 , 0, 0, (APTR)0},
{ NM_ITEM, "Commodity Priority", "P", 0, 0, (APTR)MEN_PRIORITY},
{ NM_ITEM, "Hotkeys enabled", "H", 0, 0, (APTR)MEN_SOMEHOTKEYS},
{ NM_ITEM, NM_BARLABEL, 0 , 0, 0, (APTR)0},
{ NM_ITEM, "Load", "L", 0, 0, (APTR)MEN_LOAD},
{ NM_ITEM, "Save", "S", 0, 0, (APTR)MEN_SAVEIT},
{ NM_ITEM, NM_BARLABEL, 0 , 0, 0, (APTR)0},
{ NM_ITEM, "Use", "U", 0, 0, (APTR)MEN_USE},
{ NM_ITEM, "Cancel", "C", 0, 0, (APTR)MEN_CANCEL},
{ NM_ITEM, NM_BARLABEL, 0 , 0, 0, (APTR)0},
{ NM_ITEM, "Quit", "Q", 0, 0, (APTR)MEN_USE},
{ NM_END, 0, 0 , 0, 0, (APTR)0}
};
STATIC struct Gadget *
CreateAllGadgets(struct Hotkeys *Hotkeys,struct Gadget **GadgetArray,struct Gadget **GadgetList,APTR VisualInfo,UWORD TopEdge)
{
struct Gadget *Gadget;
struct NewGadget NewGadget;
LONG Counter = 0;
memset(&NewGadget,0,sizeof(struct NewGadget));
if(Gadget = CreateContext(GadgetList))
{
NewGadget . ng_Width = 300;
NewGadget . ng_Height = 12;
NewGadget . ng_GadgetText = " term Screen To Front";
NewGadget . ng_TextAttr = &DefaultFont;
NewGadget . ng_VisualInfo = VisualInfo;
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_LeftEdge = (strlen(NewGadget . ng_GadgetText) + 2 - 1) * 8 + 1;
NewGadget . ng_TopEdge = 1 + TopEdge;
GadgetArray[Counter++] = Gadget = CreateGadget(STRING_KIND,Gadget,&NewGadget,
GTST_MaxChars, 256,
GTST_String, Hotkeys -> termScreenToFront,
GTST_EditHook, &CommandHook,
TAG_DONE);
NewGadget . ng_GadgetText = "Buffer Screen To Front";
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_TopEdge = NewGadget . ng_TopEdge + NewGadget . ng_Height + 1;
GadgetArray[Counter++] = Gadget = CreateGadget(STRING_KIND,Gadget,&NewGadget,
GTST_MaxChars, 256,
GTST_String, Hotkeys -> BufferScreenToFront,
GTST_EditHook, &CommandHook,
TAG_DONE);
NewGadget . ng_GadgetText = "Skip Dial Entry";
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_TopEdge = NewGadget . ng_TopEdge + NewGadget . ng_Height + 1;
GadgetArray[Counter++] = Gadget = CreateGadget(STRING_KIND,Gadget,&NewGadget,
GTST_MaxChars, 256,
GTST_String, Hotkeys -> SkipDialEntry,
GTST_EditHook, &CommandHook,
TAG_DONE);
NewGadget . ng_GadgetText = "Commodity _Priority ";
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_TopEdge = NewGadget . ng_TopEdge + NewGadget . ng_Height + 1;
NewGadget . ng_Width = 100;
GadgetArray[Counter++] = Gadget = CreateGadget(SLIDER_KIND,Gadget,&NewGadget,
GT_Underscore, '_',
GTSL_Min, -128,
GTSL_Max, 127,
GTSL_Level, Hotkeys -> CommodityPriority,
GTSL_LevelFormat, "%4ld",
GTSL_MaxLevelLen, 4,
TAG_DONE);
NewGadget . ng_Width = 26;
NewGadget . ng_GadgetText = "_Hotkeys enabled";
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_TopEdge = NewGadget . ng_TopEdge + NewGadget . ng_Height + 1;
NewGadget . ng_Height = 11;
GadgetArray[Counter++] = Gadget = CreateGadget(CHECKBOX_KIND,Gadget,&NewGadget,
GT_Underscore, '_',
GTCB_Checked, Hotkeys -> HotkeysEnabled,
TAG_DONE);
NewGadget . ng_Width = 52;
NewGadget . ng_Height = 12;
NewGadget . ng_GadgetText = "_Use";
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_Flags = 0;
NewGadget . ng_LeftEdge = 10;
NewGadget . ng_TopEdge = HEIGHT - 3 - NewGadget . ng_Height;
GadgetArray[Counter++] = Gadget = CreateGadget(BUTTON_KIND,Gadget,&NewGadget,
GT_Underscore, '_',
TAG_DONE);
NewGadget . ng_GadgetText = "_Load";
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_LeftEdge = NewGadget . ng_LeftEdge + (WIDTH + NewGadget . ng_Width) / 4 + 8;
GadgetArray[Counter++] = Gadget = CreateGadget(BUTTON_KIND,Gadget,&NewGadget,
GT_Underscore, '_',
TAG_DONE);
NewGadget . ng_GadgetText = "_Save";
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_LeftEdge = NewGadget . ng_LeftEdge + (WIDTH + NewGadget . ng_Width) / 4 + 8;
GadgetArray[Counter++] = Gadget = CreateGadget(BUTTON_KIND,Gadget,&NewGadget,
GT_Underscore, '_',
TAG_DONE);
NewGadget . ng_GadgetText = "_Cancel";
NewGadget . ng_GadgetID = Counter;
NewGadget . ng_LeftEdge = WIDTH - 10 - NewGadget . ng_Width;
GadgetArray[Counter++] = Gadget = CreateGadget(BUTTON_KIND,Gadget,&NewGadget,
GT_Underscore, '_',
TAG_DONE);
}
return(Gadget);
}
BYTE
HotkeyPanel(struct Hotkeys *Hotkeys)
{
struct Hotkeys PrivateHotkeys;
struct Window *PanelWindow;
struct Menu *PanelMenu;
struct Gadget *GadgetList = NULL;
struct Gadget *GadgetArray[GAD_CANCEL + 1];
struct FileRequest *FileRequest;
UBYTE DummyBuffer[256],*DummyChar;
CopyMem(Hotkeys,&PrivateHotkeys,sizeof(struct Hotkeys));
if(CreateAllGadgets(Hotkeys,&GadgetArray[0],&GadgetList,VisualInfo,Screen -> WBorTop + Screen -> Font -> ta_YSize + 1))
{
if(PanelMenu = CreateMenus(HotkeyMenu,
GTMN_FrontPen, 0,
TAG_DONE))
{
if(LayoutMenus(PanelMenu,VisualInfo,
GTMN_TextAttr,&DefaultFont,
TAG_DONE))
{
if(PanelWindow = OpenWindowTags(NULL,
WA_Left, (Screen -> Width - WIDTH) >> 1,
WA_Top, (Screen -> Height - HEIGHT) >> 1,
WA_Width, WIDTH,
WA_Height, HEIGHT,
WA_Activate, TRUE,
WA_DragBar, TRUE,
WA_DepthGadget, TRUE,
WA_RMBTrap, TRUE,
WA_DepthGadget, TRUE,
WA_CloseGadget, TRUE,
WA_CustomScreen,Screen,
WA_IDCMP, IDCMP_GADGETDOWN | IDCMP_ACTIVEWINDOW | IDCMP_CLOSEWINDOW | SLIDERIDCMP | CHECKBOXIDCMP | LISTVIEWIDCMP | IDCMP_MENUPICK | IDCMP_RAWKEY,
WA_Title, "Hotkey Preferences",
TAG_DONE))
{
struct IntuiMessage *Massage;
ULONG Class,Code;
struct Gadget *Gadget;
BYTE Terminated = FALSE;
PushWindow(PanelWindow);
AddGList(PanelWindow,GadgetList,(UWORD)-1,(UWORD)-1,NULL);
RefreshGList(GadgetList,PanelWindow,NULL,(UWORD)-1);
GT_RefreshWindow(PanelWindow,NULL);
SetMenuStrip(PanelWindow,PanelMenu);
PanelWindow -> Flags &= ~WFLG_RMBTRAP;
ActivateGadget(GadgetArray[GAD_TERMTOFRONT],PanelWindow,NULL);
ActiveGadget = GadgetArray[GAD_TERMTOFRONT];
while(!Terminated)
{
WaitPort(PanelWindow -> UserPort);
while(!Terminated && (Massage = (struct IntuiMessage *)GT_GetIMsg(PanelWindow -> UserPort)))
{
Class = Massage -> Class;
Code = Massage -> Code;
Gadget = (struct Gadget *)Massage -> IAddress;
GT_ReplyIMsg(Massage);
if(Class == IDCMP_GADGETDOWN)
{
if((Gadget -> GadgetType & GTYP_GTYPEMASK) == GTYP_STRGADGET)
ActiveGadget = Gadget;
}
if(Class == IDCMP_ACTIVEWINDOW && ActiveGadget)
ActivateGadget(ActiveGadget,PanelWindow,NULL);
if(Class == IDCMP_RAWKEY)
{
if(Code == IECODE_UP_PREFIX|103 && CommandWindow == PanelWindow)
ActivateGadget(CommandGadget,PanelWindow,NULL);
}
if(Class == IDCMP_MENUPICK)
{
struct MenuItem *MenuItem;
while(Code != MENUNULL)
{
MenuItem = ItemAddress(PanelMenu,Code);
switch((ULONG)GTMENUITEM_USERDATA(MenuItem))
{
case MEN_PRIORITY: if(Hotkeys -> CommodityPriority < 127)
Hotkeys -> CommodityPriority++;
else
Hotkeys -> CommodityPriority = -128;
GT_SetGadgetAttrs(GadgetArray[GAD_PRIORITY],PanelWindow,NULL,
GTSL_Level,Hotkeys -> CommodityPriority,
TAG_DONE);
break;
case MEN_SOMEHOTKEYS: GT_SetGadgetAttrs(GadgetArray[GAD_SOMEHOTKEYS],PanelWindow,NULL,
GTCB_Checked,GadgetArray[GAD_SOMEHOTKEYS] -> Flags & GFLG_SELECTED ? FALSE : TRUE,
TAG_DONE);
break;
case MEN_LOAD: Class = IDCMP_GADGETUP;
Gadget = GadgetArray[GAD_LOAD];
break;
case MEN_SAVEIT: Class = IDCMP_GADGETUP;
Gadget = GadgetArray[GAD_SAVE];
break;
case MEN_USE: Class = IDCMP_GADGETUP;
Gadget = GadgetArray[GAD_USE];
break;
case MEN_CANCEL: Class = IDCMP_GADGETUP;
Gadget = GadgetArray[GAD_CANCEL];
break;
default: break;
}
Code = MenuItem -> NextSelect;
}
if(ActiveGadget)
ActivateGadget(ActiveGadget,PanelWindow,NULL);
}
if(Class == IDCMP_CLOSEWINDOW)
{
Hotkeys -> HotkeysEnabled = GadgetArray[GAD_SOMEHOTKEYS] -> Flags & GFLG_SELECTED;
Terminated = TRUE;
}
if(Class == IDCMP_MOUSEMOVE)
Hotkeys -> CommodityPriority = (WORD)Code;
GadCheck: if(Class == IDCMP_GADGETUP)
{
switch(Gadget -> GadgetID)
{
case GAD_TERMTOFRONT: strcpy(Hotkeys -> termScreenToFront,((struct StringInfo *)Gadget -> SpecialInfo) -> Buffer);
break;
case GAD_BUFFERTOFRONT: strcpy(Hotkeys -> BufferScreenToFront,((struct StringInfo *)Gadget -> SpecialInfo) -> Buffer);
break;
case GAD_SKIP: strcpy(Hotkeys -> SkipDialEntry,((struct StringInfo *)Gadget -> SpecialInfo) -> Buffer);
break;
case GAD_LOAD: strcpy(DummyBuffer,LastKeys);
DummyChar = PathPart(DummyBuffer);
*DummyChar = 0;
SetWait(PanelWindow);
PanelWindow -> Flags |= WFLG_RMBTRAP;
if(FileRequest = GetFile("Load Hotkeys",DummyBuffer,FilePart(LastKeys),DummyBuffer,"#?.term",FALSE,FALSE,FALSE,"Load"))
{
if(ReadIFFData(DummyBuffer,Hotkeys,sizeof(struct Hotkeys),'HOTK'))
MyEasyRequest(Window,"Couldn't load hotkeys\n\"%s\"!","Continue",DummyBuffer);
else
{
strcpy(LastKeys,DummyBuffer);
GT_SetGadgetAttrs(GadgetArray[GAD_TERMTOFRONT],PanelWindow,NULL,
GTST_String,Hotkeys -> termScreenToFront,
TAG_DONE);
GT_SetGadgetAttrs(GadgetArray[GAD_BUFFERTOFRONT],PanelWindow,NULL,
GTST_String,Hotkeys -> BufferScreenToFront,
TAG_DONE);
GT_SetGadgetAttrs(GadgetArray[GAD_SKIP],PanelWindow,NULL,
GTST_String,Hotkeys -> SkipDialEntry,
TAG_DONE);
GT_SetGadgetAttrs(GadgetArray[GAD_PRIORITY],PanelWindow,NULL,
GTSL_Level,Hotkeys -> CommodityPriority,
TAG_DONE);
GT_SetGadgetAttrs(GadgetArray[GAD_PRIORITY],PanelWindow,NULL,
GTCB_Checked,Hotkeys -> HotkeysEnabled,
TAG_DONE);
}
}
ClearPointer(PanelWindow);
PanelWindow -> Flags &= ~WFLG_RMBTRAP;
break;
case GAD_SAVE: strcpy(DummyBuffer,LastKeys);
DummyChar = PathPart(DummyBuffer);
*DummyChar = 0;
SetWait(PanelWindow);
PanelWindow -> Flags |= WFLG_RMBTRAP;
Hotkeys -> HotkeysEnabled = GadgetArray[GAD_SOMEHOTKEYS] -> Flags & GFLG_SELECTED;
if(FileRequest = GetFile("Save Hot Keys",DummyBuffer,FilePart(LastKeys),DummyBuffer,"#?.term",TRUE,FALSE,FALSE,"Save"))
{
if(!WriteIFFData(DummyBuffer,Hotkeys,sizeof(struct Hotkeys),'HOTK'))
MyEasyRequest(Window,"Couldn't save macro keys\n\"%s\"!","Continue",DummyBuffer);
else
strcpy(LastKeys,DummyBuffer);
}
ClearPointer(PanelWindow);
PanelWindow -> Flags &= ~WFLG_RMBTRAP;
break;
case GAD_USE: Terminated = TRUE;
Hotkeys -> HotkeysEnabled = GadgetArray[GAD_SOMEHOTKEYS] -> Flags & GFLG_SELECTED;
break;
case GAD_CANCEL: Terminated = TRUE;
CopyMem(&PrivateHotkeys,Hotkeys,sizeof(struct Hotkeys));
break;
default: break;
}
}
}
}
PanelWindow -> Flags |= WFLG_RMBTRAP;
ClearMenuStrip(PanelWindow);
RemoveGList(PanelWindow,GadgetList,(UWORD)-1);
PopWindow();
CloseWindow(PanelWindow);
}
}
FreeMenus(PanelMenu);
}
}
FreeGadgets(GadgetList);
if(memcmp(&PrivateHotkeys,Hotkeys,sizeof(struct Hotkeys)))
return(TRUE);
else
return(FALSE);
}