home *** CD-ROM | disk | FTP | other *** search
/ Amiga ISO Collection / AmigaUtilCD1.iso / Printer / add16.dms / in.adf / reqbase.i < prev    next >
Encoding:
Text File  |  1993-02-22  |  20.8 KB  |  476 lines

  1.  
  2. ; reqlibrary.i © 1988/1989 reserved by Colin Fox and Bruce Dawson */
  3.  
  4.         IFND    REQ_LIBRARY_I
  5.  
  6. REQ_LIBRARY_I   SET     1
  7.  
  8.                 INCLUDE "intuition/intuition.i"
  9.  
  10.                 INCLUDE "libraries/dos.i"
  11.                 INCLUDE "libraries/dosextens.i"
  12.  
  13.                 INCLUDE "exec/memory.i"
  14.                 INCLUDE "exec/initializers.i"
  15.                 INCLUDE "exec/alerts.i"
  16.  
  17. ReqVersion      EQU     1
  18.  
  19.  
  20. PairsSize       EQU     20
  21.  
  22.  STRUCTURE      GadgetBlock.,0          ;a boolean button style text gadget
  23.         STRUCT  gb_Gadget,gg_SIZEOF
  24.         STRUCT  gb_Border,bd_SIZEOF
  25.         STRUCT  gb_Pairs,PairsSize
  26.         STRUCT  gb_Text,it_SIZEOF
  27.         LABEL   gb_SIZEOF
  28.  
  29.  STRUCTURE      StringBlock.,0          ;a string gadget
  30.         STRUCT  sb_Gadget,gg_SIZEOF
  31.         STRUCT  sb_Info,si_SIZEOF
  32.         STRUCT  sb_Border,bd_SIZEOF
  33.         STRUCT  sb_Pairs,PairsSize
  34.         LABEL   sb_SIZEOF
  35.  
  36.  STRUCTURE      PropBlock.,0            ;a prop gadget
  37.         STRUCT  pb_Gadget,gg_SIZEOF
  38.         STRUCT  pb_Info,pi_SIZEOF
  39.         STRUCT  pb_Image,ig_SIZEOF
  40.         LABEL   pb_SIZEOF
  41.  
  42.  STRUCTURE      SliderBlock.,0          ;a slider (two arrows & a prop)
  43.         STRUCT  slb_ArrowUpLt,gg_SIZEOF
  44.         STRUCT  slb_ImageUpLt,ig_SIZEOF
  45.         STRUCT  slb_ArrowDnRt,gg_SIZEOF
  46.         STRUCT  slb_ImageDnRt,ig_SIZEOF
  47.         STRUCT  slb_Prop,pb_SIZEOF      ;this is at the end for REFRESH GLIST purposes
  48.         LABEL   slb_SIZEOF
  49.  
  50.  STRUCTURE      TwoImageBlock,0
  51.         STRUCT  tib_Gadget,gg_SIZEOF
  52.         STRUCT  tib_Image1,ig_SIZEOF
  53.         STRUCT  tib_Image2,ig_SIZEOF
  54.         LABEL   tib_SIZEOF
  55.  
  56. ATTITUDEB       EQU     16      ;Bit# of the attitude bit.
  57.  
  58. HorizSlider     EQU     0<<ATTITUDEB    ;which way the slider stands
  59. VertSlider      EQU     1<<ATTITUDEB    ;This is so that it bypasses all gadget flags.
  60.  
  61.  
  62.  
  63. ;         This structure is use with the TextRequester function.
  64.  
  65.  STRUCTURE TRStructure,0
  66.         APTR    TR_Text                 ;This is the message text, including printf() style formatting if desired.
  67.         APTR    TR_Controls             ;This is the address of the parameter list, if printf() style formatting is used.
  68.         APTR    TR_Window               ;This is an optional (zero if not used) pointer to a window on the screen you
  69.                                         ;would like the requester to show up on.
  70.         APTR    TR_MiddleText           ;If non-zero, this is the text for the gadget in the lower middle (returns 2).
  71.         APTR    TR_PositiveText         ;If non-zero, this is the text for the gadget in the lower left hand corner (returns 1).
  72.         APTR    TR_NegativeText         ;If non-zero, this is the text for the gadget in the lower right (returns 0).
  73.         APTR    TR_Title                ;This is the title for the window.
  74.         WORD    TR_KeyMask              ;This is the qualifier mask for the keyboard shortcuts.
  75.                                         ;Use $FFFF to allow any qualifiers (or none).
  76.                                         ;Zero means that no keyboard shortcuts are allowed.
  77.         WORD    TR_textcolor            ;Color of the text.  Uses Color 1 if no Color specified.
  78.         WORD    TR_detailcolor          ;Detail and block color, as in a NewWindow structure.  If
  79.         WORD    TR_blockcolor           ;both are left zero, block pen will be set to 1.
  80.         WORD    TR_versionnumber        ;Make SURE this is set to zero.
  81.         LONG    TR_rfu1                 ;Make SURE you leave these two zeroed also.
  82.         LONG    TR_rfu2                 ;Make SURE you leave these two zeroed also.
  83.         LABEL   TR_SIZEOF
  84.  
  85. ;/* NOTE:
  86. ;
  87. ;    The  control  values  mentioned above are used if you choose to insert
  88. ;printf  style directives in your strings and should contain the address of
  89. ;a list of control parameters, usually on the stack.
  90. ;    */
  91.  
  92.  
  93.  
  94. ;         This structure is for use with the GetLong function.
  95.  
  96. GLNODEFAULTB    EQU     0       ;Set this bit in the flags if you don't want a default
  97.                                 ;value to show up in the get long string gadget.  For
  98.                                 ;some things this is much better than having a zero
  99.                                 ;show up.
  100.  
  101. GLNODEFAULTM    EQU     1<<GLNODEFAULTB
  102.  
  103.  STRUCTURE      GetLongStruct,0
  104.         APTR    gl_titlebar
  105.         LONG    gl_defaultval
  106.         LONG    gl_minlimit
  107.         LONG    gl_maxlimit
  108.         LONG    gl_result
  109.         APTR    gl_window
  110.         WORD    gl_versionnumber;       ;Make SURE this is set to zero.
  111.         LONG    gl_flags;               ;Some, uh flags.  See above for bit definitions.
  112.         LONG    gl_rfu2;                ;Make SURE you leave these two zeroed also.
  113.         LABEL   gl_SIZEOF
  114.  
  115.  
  116.  STRUCTURE      GetStringStruct,0
  117.         APTR    gs_titlebar
  118.         APTR    gs_stringbuffer
  119.         APTR    gs_window
  120.         WORD    gs_stringsize
  121.         WORD    gs_visiblesize
  122.         WORD    gs_versionnumber
  123.         LONG    gs_flags
  124.         LONG    gs_rfu1
  125.         LONG    gs_rfu2
  126.         LONG    gs_rfu3
  127.         LABEL   gs_SIZEOF
  128.  
  129.  
  130.  
  131. ;         Remember,   if  you  don't  want  to  go  through  the  hassle  of
  132. ; initializing a ExtendedColorRequester structure, you can always just call
  133. ; ColorRequester  (as opposed to ExtendedColorRequester).  ColorRequester
  134. ; just  takes  a  single  parameter, in D0, the color that should start out
  135. ; being highlit.  It returns a single value, the color that was selected at
  136. ; the end.
  137.  
  138. ;         This structure is for use with the ExtendedColorRequester (_not_,
  139. ; the ColorRequester) function.
  140.  
  141.  STRUCTURE      ExtendedColorRequesterStruct,0
  142.         LONG    ecr_defcolor            ;The color that is initially highlit.
  143.         APTR    ecr_window              ;The window the 'requester' opens up in (zero normally).
  144.         LONG    ecr_rfu1                        ;Who knows what these will be used for,
  145.         LONG    ecr_rfu2                        ;but I'm sure we'll think of something.
  146.         LONG    ecr_rfu3                        ;Until then, just keep these zeroed.
  147.         LONG    ecr_rfu4                        ;Okay?
  148.         LONG    ecr_rfu5
  149.         LABEL   ecr_SIZEOF
  150.  
  151.  
  152.  
  153.         IFND    DSIZE
  154. DSIZE           EQU     130
  155. FCHARS          EQU     30
  156.         ENDC
  157. WILDLENGTH      EQU     30
  158.  
  159. FRQSHOWINFOB    EQU     0       ;Set this in Flags if you want .info files to show.  They default to hidden.
  160. FRQEXTSELECTB   EQU     1       ;Set this in Flags if you want extended select.  Default is not.
  161. FRQCACHINGB     EQU     2       ;Set this in Flags if you want directory caching.  Default is not.
  162. FRQGETFONTSB    EQU     3       ;Set this in Flags if you want a font requester rather than a file requester.
  163. FRQINFOGADGETB  EQU     4       ;Set this in Flags if you want a hide-info files gadget.
  164. FRQHIDEWILDSB   EQU     5       ;Set this in Flags if you DON'T want 'show' and 'hide' string gadgets.
  165. FRQABSOLUTEXYB  EQU     6       ;Use absolute x,y positions rather than centering on mouse.
  166. FRQCACHEPURGEB  EQU     7       ;Purge the cache whenever the directory date stamp changes if this is set.
  167. FRQNOHALFCACHEB EQU     8       ;Don't cache a directory unless it is completely read in when this is set.
  168. FRQNOSORTB      EQU     9       ;Set this in Flags if you DON'T want sorted directories.
  169. FRQNODRAGB      EQU     10      ;Set this in Flags if you DON'T want a drag bar and depth gadgets.
  170. FRQSAVINGB      EQU     11      ;Set this bit if you are selecting a file to save to.
  171. FRQLOADINGB     EQU     12      ;Set this bit if you are selecting a file(s) to load from.
  172.                                 ;These two bits (save and load) aren't currently used for
  173.                                 ;anything, but they may be in the future, so you should
  174.                                 ;remember to set them.  Also, these bits make it easier if
  175.                                 ;somebody wants to customize the file requester for their
  176.                                 ;machine.  They can make it behave differently for loading
  177.                                 ;vs saving.
  178. FRQDIRONLYB     EQU     13      ;Allow the user to select a directory, rather than a file.
  179.  
  180. FRQSHOWINFOM    EQU     1<<FRQSHOWINFOB
  181. FRQEXTSELECTM   EQU     1<<FRQEXTSELECTB
  182. FRQCACHINGM     EQU     1<<FRQCACHINGB
  183. FRQGETFONTSM    EQU     1<<FRQGETFONTSB
  184. FRQINFOGADGETM  EQU     1<<FRQINFOGADGETB
  185. FRQHIDEWILDSM   EQU     1<<FRQHIDEWILDSB
  186. FRQABSOLUTEXYM  EQU     1<<FRQABSOLUTEXYB
  187. FRQCACHEPURGEM  EQU     1<<FRQCACHEPURGEB
  188. FRQNOHALFCACHEM EQU     1<<FRQNOHALFCACHEB
  189. FRQNOSORTM      EQU     1<<FRQNOSORTB
  190. FRQNODRAGM      EQU     1<<FRQNODRAGB
  191. FRQSAVINGM      EQU     1<<FRQSAVINGB
  192. FRQLOADINGM     EQU     1<<FRQLOADINGB
  193. FRQDIRONLYM     EQU     1<<FRQDIRONLYB
  194.  
  195.  
  196.  STRUCTURE      ESStructure,0           ;ExtendedSelectStructure
  197.                 LONG    es_NextFile     ;This must be the first element!
  198.                 WORD    es_NameLength   ;File name length, not including the terminating zero.
  199.                 WORD    es_Pad
  200.                 APTR    es_Node         ;Node that the user has extended selected.
  201.                 LABEL   es_SIZEOF
  202.  
  203. ;         When  using  extended  select,  the  directory pointer is required
  204. ; since  only  the  file  names  are stored in the frq_ExtendedSelect linked
  205. ; list.   When  not  using  extended select, you can either have frq_Dir and
  206. ; frq_File  point  be initialized, or you can have frq_PathName initialized,
  207. ; or  both.   frq_PathName will contain the concatenation of the file and
  208. ; directory chosen.
  209.  
  210.  STRUCTURE      .FileRequester,0
  211.         UWORD   frq_VersionNumber               ;MUST BE ZERO!!!!!!!!!!!!!!!!!!
  212.  
  213.         ;You will probably want to initialize these three variables.
  214.         APTR    frq_Title                       ; Hailing text
  215.         APTR    frq_Dir                         ; Directory array (must be DSIZE+1 characters long)
  216.         APTR    frq_File                        ; Filename array (must be FCHARS+1 characters long)
  217.         ;If you initialize this variable then the file requester will place the complete path name in here on exit.
  218.         APTR    frq_PathName                    ; Complete path name array - (must be DSIZE+FCHARS+2 long)
  219.         ;If you want the file requester to pop up on your custom screen, put one of your window pointers here.
  220.         ;Or better yet, you can leave this field zeroed and put a pointer to one of your windows in the
  221.         ;pr_WindowPtr field in your process structure.
  222.         APTR    frq_Window                      ; Window requesting or NULL
  223.         ;Initialize these to the number of lines and columns you want to appear in the inner window that
  224.         ;displays the file names.  If you leave these set to zero then default values will be used.
  225.         UWORD   frq_MaxExtendedSelect           ; Zero implies a maximum of 65535, as long as FRQEXTSELECT is set.
  226.         UWORD   frq_numlines                    ; Number of lines in file window.
  227.         UWORD   frq_numcolumns                  ; Number of columns in file window.
  228.         UWORD   frq_devcolumns                  ; Number of columns in device window.
  229.         ULONG   frq_Flags                       ; Various - umm - flags.  See above for more info.
  230.         UWORD   frq_dirnamescolor       ;These five colors will all default
  231.         UWORD   frq_filenamescolor      ;to color one if you don't specify
  232.         UWORD   frq_devicenamescolor    ;a color (ie; if you specify color zero).
  233.         UWORD   frq_fontnamescolor      ;If you want color zero to be used, specify
  234.         UWORD   frq_fontsizescolor      ;color 32, or some other too large number
  235.                                         ;which mods down to zero.
  236.  
  237.         UWORD   frq_detailcolor         ;If both of these colors are specified as
  238.         UWORD   frq_blockcolor          ;zero then the block pen will be set to one.
  239.  
  240.         UWORD   frq_gadgettextcolor     ;The color for the text of the five boolean gadgets.  Defaults to 1.
  241.         UWORD   frq_textmessagecolor    ;The color for the message at the screen top.  Defaults to 1.
  242.         UWORD   frq_stringnamecolor     ;The color for the words Drawer, File, Hide and Show.  Defaults to 3.
  243.         UWORD   frq_stringgadgetcolor   ;The color for the borders of the string gadgets.  Defaults to 3.
  244.                                         ;Unfortunately it is not possible to specify
  245.                                         ;the color of the actual text in an Intuition
  246.                                         ;string gadget.
  247.         UWORD   frq_boxbordercolor      ;The color for the boxes around the file and directory areas.  Defaults to 3.
  248.         UWORD   frq_gadgetboxcolor      ;The color for the boxes around the five boolean gadgets.  Defaults to 3.
  249.  
  250.         STRUCT  frq_RFU_Stuff,36                ;This area, which is reserved for
  251.                                                 ;future use, should all be zero.
  252.  
  253.         STRUCT  frq_DirDateStamp,ds_SIZEOF      ; A copy of the cached directories date stamp.
  254.                                                 ; There should never be any need to change this.
  255.  
  256.         UWORD   frq_WindowLeftEdge;             ;These two fields are only used when the
  257.         UWORD   frq_WindowTopEdge;              ;FRQABSOLUTEXY flag is set.  They specify
  258.                                                 ;the location of the upper left hand
  259.                                                 ;corner of the window.
  260.  
  261.         UWORD   frq_FontYSize                   ;These fields are used to return the selected
  262.         UWORD   frq_FontStyle                   ;font size and style, only applicable when the
  263.                                                 ;font bit is set.
  264.  
  265.         ;If you set the extended select bit and the user extended selects, the list of filenames will start from here.
  266.         APTR    frq_ExtendedSelect              ; Linked list of ESStructures if more than one filename is chosen.
  267.         ;All of the following variables you shouldn't need to touch.  They contain fields that the file
  268.         ;requester sets and likes to preserve over calls, just to make life easier for the user.
  269.         STRUCT  frq_Hide,WILDLENGTH+2           ; Wildcards for files to hide.
  270.         STRUCT  frq_Show,WILDLENGTH+2           ; Wildcards for files to show.
  271.         WORD    frq_FileBufferPos               ; Cursor's  position  and first
  272.         WORD    frq_FileDispPos                 ; displayed character number in
  273.         WORD    frq_DirBufferPos                ; the three string gadgets.  No
  274.         WORD    frq_DirDispPos                  ; need  to initialized these if
  275.         WORD    frq_HideBufferPos               ; you don't want to.
  276.         WORD    frq_HideDispPos
  277.         WORD    frq_ShowBufferPos
  278.         WORD    frq_ShowDispPos
  279.  
  280. ;         The  following  fields are PRIVATE!  Don't go messing with them or
  281. ; wierd  things may/will happen.  If this isn't enough of a warning, go read
  282. ; the one in intuition.h, that should scare you off.
  283.  
  284.         APTR    frq_Memory                      ; Memory allocated for dir entries.
  285.         APTR    frq_Memory2                     ; Used for currently hidden files.
  286.         APTR    frq_Lock                        ; Contains lock on directories being read across calls.
  287.         STRUCT  frq_PrivateDirBuffer,DSIZE+2    ; Used for keeping a record of which
  288.                                                 ; directory we have file names for.
  289.         APTR    frq_FileInfoBlock
  290.         WORD    frq_NumEntries
  291.         WORD    frq_NumHiddenEntries
  292.         WORD    frq_filestartnumber
  293.         WORD    frq_devicestartnumber
  294.         LABEL   frq_SIZEOF
  295.  
  296.  
  297.  
  298.  
  299.  
  300.  
  301.  
  302. ;         This is used with the RealTimeScroll function.
  303.  
  304.  STRUCTURE      ScrollStruct,0
  305.         ULONG   ss_TopEntryNumber       ;This is the ordinal number of the first
  306.                                         ;displayed entry.
  307.         ULONG   ss_NumEntries           ;This is the total number of entries in
  308.                                         ;the list.
  309.         UWORD   ss_LineSpacing          ;This is how many pixels high each entry is.
  310.         ULONG   ss_NumLines             ;This is how many entries can be displayed simultaneously.
  311.         APTR    ss_PropGadget           ;This is a pointer to the prop gadget being monitored.
  312.  
  313.         APTR    ss_RedrawAll            ;This routine is used to redraw all of the
  314.                                         ;entries when the user moves far enough
  315.                                         ;that scrolling will take too long.
  316.  
  317.         APTR    ss_ReadMore             ;An optional routine that is called when
  318.                                         ;the scroll routine is waiting for movement.
  319.                                         ;This allows reading of new data while real
  320.                                         ;time scrolling.
  321.         APTR    ss_ScrollAndDraw        ;This routine is called when the data needs
  322.                                         ;to be scrolled and updated.  This routine is
  323.                                         ;passed four long parameters (on the stack and
  324.                                         ;in D0-D3) which are, respectively:
  325.                                         ;D0 - entry number of first line to be drawn.
  326.                                         ;D1 - pixel offset to draw first line at.
  327.                                         ;D2 - amount to scroll before doing any drawing.
  328.                                         ;D3 - number of lines of data to draw.
  329.         WORD    versionnumber           ;Make SURE this is set to zero.
  330.         LONG    rfu1                    ;Make SURE you leave these two zeroed also.
  331.         LONG    rfu2                    ;Make SURE you leave these two zeroed also.
  332.         LABEL   ss_SIZEOF
  333.  
  334.  
  335.  
  336.  
  337.  
  338.  STRUCTURE      Arrows,0
  339.         STRUCT  ArrowUp,20
  340.         STRUCT  ArrowDown,20
  341.         STRUCT  ArrowLeft,18
  342.         STRUCT  ArrowRight,18
  343.         STRUCT  Letter_R,20
  344.         STRUCT  Letter_G,20
  345.         STRUCT  Letter_B,20
  346.         STRUCT  Letter_H,20
  347.         STRUCT  Letter_S,20
  348.         STRUCT  Letter_V,20
  349.         LABEL   chipstuff_SIZEOF
  350.  
  351. ; These are the positions relative to the rl_Images pointer.
  352. ;ie
  353. ;       MOVE.L  rl_Images(A6),A0
  354. ;       ADD.L   #ArrowLeft,A0           ;A0 now points at the left arrow.
  355.  
  356.  
  357.  STRUCTURE      ReqLib,LIB_SIZE
  358.         APTR    rl_SysLib
  359.         APTR    rl_DosLib               ;These must be kept in the same order,
  360.         APTR    rl_IntuiLib             ;the library expunge code depends on it.
  361.         APTR    rl_GfxLib               ;
  362.         APTR    rl_SegList
  363.         APTR    rl_Images               ;pointer to the arrow images.
  364.         BYTE    rl_Flags
  365.         BYTE    rl_Pad
  366.         APTR    rl_ConsoleDev           ;for RawKeyToAscii
  367.         APTR    rl_ConsoleHandle        ;so we can close the device later
  368.         LABEL   MyLib_Sizeof
  369.  
  370.  
  371.  
  372.  
  373.  
  374.  
  375.         LIBINIT
  376.         LIBDEF  _LVOCenter              ;1e
  377.  
  378.         LIBDEF  _LVOSetSize             ;24
  379.         LIBDEF  _LVOSetLocation         ;2a
  380.         LIBDEF  _LVOReadLocation        ;30
  381.  
  382.         LIBDEF  _LVOFormat              ;36
  383.  
  384.         LIBDEF  _LVOFakeFunction1       ;3c   Old function.  Don't use.
  385.         LIBDEF  _LVOFakeFunction2       ;42   Old function.  Don't use.
  386.  
  387.         LIBDEF  _LVOFakeFunction3       ;48   Old function.  Don't use.
  388.         LIBDEF  _LVOFakeFunction4       ;4e   Old function.  Don't use.
  389.  
  390.         LIBDEF  _LVOFileRequester       ;54
  391.  
  392.         LIBDEF  _LVOColorRequester      ;5a
  393.  
  394.         LIBDEF  _LVODrawBox             ;60
  395.  
  396.         LIBDEF  _LVOMakeButton          ;66
  397.         LIBDEF  _LVOMakeScrollBar       ;6c
  398.  
  399.         LIBDEF  _LVOPurgeFiles          ;72
  400.  
  401.         LIBDEF  _LVOGetFontHeightAndWidth ;78
  402.  
  403.         LIBDEF  _LVOMakeGadget          ;7e
  404.         LIBDEF  _LVOMakeString          ;84
  405.         LIBDEF  _LVOMakeProp            ;8a
  406.  
  407.         LIBDEF  _LVOLinkGadget          ;90
  408.         LIBDEF  _LVOLinkStringGadget    ;96
  409.         LIBDEF  _LVOLinkPropGadget      ;9c
  410.  
  411.         LIBDEF  _LVOGetString           ;a2
  412.  
  413.         LIBDEF  _LVORealTimeScroll      ;a8
  414.  
  415.         LIBDEF  _LVOTextRequest         ;ae
  416.  
  417.         LIBDEF  _LVOGetLong             ;b4
  418.  
  419.         LIBDEF  _LVORawKeyToAscii       ;ba
  420.  
  421.         LIBDEF  _LVOExtendedColorRequester ;c0
  422.  
  423.         LIBDEF  _LVONewGetString        ;c6
  424.  
  425.  
  426.  
  427. REQNAME MACRO
  428.         DC.B    'req.library',0
  429.         ENDM
  430.  
  431. ; This macro will open the RequesterLibrary for you. At the end, A6 will
  432. ;contain the library and D0/A0 will be correct. (What dos passed you)
  433.  
  434. OpenReq MACRO
  435.         BRA.S   opnrq
  436.  
  437. dname   DC.B    'dos.library',0
  438. rlibmsg DC.B    'You need V1+ of '
  439. ReqName REQNAME
  440.         DC.B    10,13,0
  441. ;;;rliblng      EQU     *-rlibmsg
  442. rliblng EQU     30
  443.         DS.W    0
  444.         EVEN
  445.  
  446. opnrq:
  447.         MOVEM.L d0/a0,-(sp)
  448.         MOVE.L  4,A6
  449.         LEA.L   ReqName,a1
  450.         MOVEQ.L #ReqVersion,d0
  451.         SYS     OpenLibrary
  452.         TST.L   d0
  453.         BNE.S   itsokay
  454.         LEA     dname,A1
  455.         SYS     OpenLibrary
  456.         TST.L   D0
  457.         BEQ.S   1$
  458.         MOVE.L  D0,A6
  459.         SYS     Output
  460.         MOVE.L  d0,d1
  461.         BEQ.S   1$                      ;No output. Phooey.
  462.         MOVE.L  #rlibmsg,d2             ;Tell user he needs to find library.
  463.         MOVE.L  #rliblng,D3
  464.         SYS     Write
  465. 1$:     ADDQ    #8,sp
  466.         RTS
  467.  
  468. itsokay:
  469.         MOVE.L  D0,A6
  470.         MOVEM.L (SP)+,D0/A0
  471.         ENDM
  472.  
  473.  
  474.  
  475.         ENDC
  476.