a1200   NEWS   APPS   DOCS   ABOUT
a1200
----
a1200
----
Autodocs
 Libraries:
 intuition.library
  ActivateGadget
  ActivateWindow
  AddClass
  AddGList
  AddGadget
  AllocRemember
  AllocScreenBuffer
  AutoRequest
  BeginRefresh
  BuildEasyRequestArgs
  BuildSysRequest
  ChangeScreenBuffer
  ChangeWindowBox
  ClearDMRequest
  ClearMenuStrip
  ClearPointer
  CloseScreen
  CloseWindow
  CloseWorkBench
  CurrentTime
  DisplayAlert
  DisplayBeep
  DisposeObject
  DoGadgetMethodA
  DoubleClick
  DrawBorder
  DrawImage
  DrawImageState
  EasyRequestArgs
  EndRefresh
  EndRequest
  EraseImage
  FreeClass
  FreeRemember
  FreeScreenBuffer
  FreeScreenDrawInfo
  FreeSysRequest
  GadgetMouse
  GetAttr
  GetDefPrefs
  GetDefaultPubScreen
  GetPrefs
  GetScreenData
  GetScreenDrawInfo
  HelpControl
  InitRequester
  IntuiTextLength
  ItemAddress
  LendMenus
  LockIBase
  LockPubScreen
  LockPubScreenList
  MakeClass
  MakeScreen
  ModifyIDCMP
  ModifyProp
  MoveScreen
  MoveWindow
  MoveWindowInFrontOf
  NewModifyProp
  NewObject
  NextObject
  NextPubScreen
  ObtainGIRPort
  OffGadget
  OffMenu
  OnGadget
  OnMenu
  OpenScreen
  OpenScreenTagList
  OpenWindow
  OpenWindowTagList
  OpenWorkBench
  PointInImage
  PrintIText
  PubScreenStatus
  QueryOverscan
  RefreshGList
  RefreshGadgets
  RefreshWindowFrame
  ReleaseGIRPort
  RemakeDisplay
  RemoveClass
  RemoveGList
  RemoveGadget
  ReportMouse
  Request
  ResetMenuStrip
  RethinkDisplay
  ScreenDepth
  ScreenPosition
  ScreenToBack
  ScreenToFront
  ScrollWindowRaster
  SetAttrsA
  SetDMRequest
  SetDefaultPubScreen
  SetEditHook
  SetGadgetAttrsA
  SetMenuStrip
  SetMouseQueue
  SetPointer
  SetPrefs
  SetPubScreenModes
  SetWindowPointerA
  SetWindowTitles
  ShowTitle
  SizeWindow
  SysReqHandler
  TimedDisplayAlert
  UnlockIBase
  UnlockPubScreen
  UnlockPubScreenList
  ViewAddress
  ViewPortAddress
  WBenchToBack
  WBenchToFront
  WindowLimits
  WindowToBack
  WindowToFront
  ZipWindow
Include
GuruMeditation
Docs » Autodocs » intuition.library » SetEditHook

NAME

	SetEditHook -- Set global processing for string gadgets. (V36)

SYNOPSIS

	OldHook = SetEditHook( Hook )
D0 A0
struct Hook *SetEditHook( struct Hook * );

FUNCTION

	Sets new global editing hook for string gadgets.
WARNING: The use and integration of this function has not
been explored, and thus should be considered a risky function.
Do *NOT* use this in a commercial product until further notice.

INPUTS

	Hook -- A pointer to a struct Hook which determines a function
in your code to be called every time the user types a key.
This is done before control is passed to the gadget custom
editing hook, so affects ALL string gadgets.

RESULT

	Returns previous global edit hook structure.  You may need this
hook if you wish to invoke the previous edit hook's behavior
in addition to your own.

NOTES

	There are a few key differences between a global edit hook and the
more famililar per-gadget StringExtend->EditHook field. In the
case of the latter, the hook's creator supplies a WorkBuffer.
Intuition's idea of the result of a keystroke is stored in
the SGWork structure (which references the WorkBuffer). The
state of the gadget before Intuition's hook acted is available in
the StringInfo->Buffer, ->BufferPos, and ->NumChars fields.
In the case of a global editing hook, your hook _becomes_
Intuition's hook, which affects all gadgets, most of which
do not have a WorkBuffer. This means that if you invoke
Intuition's original hook (which you got as the result of this
function), there isn't any easy way for you to "undo" that after
the fact. This means that if Intuition's behavior for certain
keystrokes is incompatible with your hook's objectives, then
you must avoid calling Intuition's hook for those keys. One
approach is to run through your hook's code first, acting on
those keys you wish to recognize. Then, call Intuition's
hook for those keys you do not recognize, or for those keys
whose default actions you wish to add to.
Do not forget to set SGA_REDISPLAY when needed (see sghooks.h),
and please be sure to give the SGWork->EditOp field a value
which is as meaningful as possible.
Currently, only SGH_KEY messages are sent to the global edit
hook, though custom edit hooks do receive SGH_CLICK messages
in addition.
Finally, there is currently no arbitration between a global
edit hook and a custom edit hook as to ownership of keystrokes.
It would be fair to expect that a custom edit hook would be
written to match the current Intuition edit hook. If your
global edit hook acts on (say) up and down arrow keystrokes,
an undesirable result may occur if some string gadget's custom
hook also acts on these keystrokes. There is currently
no easy way to resolve this issue.

BUGS

SEE ALSO

Comments

Name:
E-mail: Use this if you want a message if you get a response, will not be shown.
Comment:
Select correct short for:

Paradox

PDX
SNT
DC
AYS

Comments:

$VER: d0.se 1.14 Copyright © 2011-2025 Tobias Geijersson support at d0 dot se