OpenVMS Source Code Demos

BASIC_QIO_DEMO.BAS

1000	%title	"BASIC-qio-demo_xxx.bas"					!
	%ident                              "101.1"				! <<<---+---
	declare string constant	k_version = "101.1"			,	! <<<---+					&
				k_program = "BASIC-qio-demo"			!
	!=========================================================================================================================
	! Title  : BASIC-QIO-demo_xxx.bas
	! Author : Neil Rieck
	! Created: 2003.11.23
	! Purpose: To demo qio calls to an async port (this one dials a telephone pager service)
	!=========================================================================================================================
	! History:
	! -------
	! Ver Who When   What
	! --- --- ------ ---------------------------------------------------------------------------------------------------------
	! 100 NSR 031123 1. Original code
	! 101 NSR 110423 1. mini-cleanup prior to republishing to public domain
	!=========================================================================================================================
	option type=explicit							! no kid stuff
	set no prompt								! no "?" at prompts
	!
	%include "[.inc]VMS_STRUCTURES.INC"					! records for system calls, etc.
	%include "starlet"      %from %library "sys$library:basic$starlet"	! system services
	%include "$ssdef"       %from %library "sys$library:basic$starlet"	! ss$
	%include "$iodef"       %from %library "sys$library:basic$starlet"	! io$
	%include "$lnmdef"      %from %library "sys$library:basic$starlet"	! lnm$
	%include "lib$routines" %from %library "sys$library:basic$starlet"	! lib$
	%include "$libdef"      %from %library "sys$library:basic$starlet"	! lib$_normal
	!
	!	<<< home brewed functions >>>
	!
        external string function wcsm_dt_stamp()				! see end of this program
        external string function wcsm_trnlnm(string,string)			! see end of this program
        external long   function wcsm_submit_to_batch(string,string,string,	&
		string,string,string,string,string,string,string,string,string)
	!
	!	<<< constant declarations (non-system service) >>>
	!
	declare string constant	CRLF	= '13'C + '10'C			,	!				&
				Ctrl_T	= '20'C				,	! control-t			&
				Ctrl_V	= '22'C					! control-v
	!
	declare string constant	STX	= '02'C				,	! set up control characters	&
				ETX	= '03'C 			,	!		     		&
				EOT	= '04'C 			,	!				&
				ACK	= '06'C 			,	!				&
				XON	= '17'C				,	! ctrl-Q			&
				CAN	= '30'C 			,	!				&
				NAK	= '21'C 			,	!				&
				ESC1	= '27'C					!
	!
	!	<<< variable declarations >>>
	!
	declare string xmit_count$(400%)					! keeps track of xmit messages
	declare string packet$(400%)						! up to 400 messagee can be sent at one time.
	declare string illegal_num$(400%)					! keeps track of illegal pager numbers
	declare long	junk%						,	!&
			applic_debug%					,	!&
			sleep%						,	!&
		string	dump_string$						!
	declare string	junk$						,	! whatever				&
			default_node$   				,	! 					&
			pag_port$					,	! port to use for paging		&
			logging$ 					,	! logging level				&
			choice$						,	! menu choice				&
                        current_dt$					,	!                              		&
                        date_total$					,	!                              		&
			rename_time$					,	! renames pager file to .old		&
			tel_num$					,	! hold local phone number		&
			ssmr_comm$					,	! hold long distance number		&
                        mail_filename$					,	!					&
                        mail_address$					,	!					&
			area_code$					,	! used by the mail pcs section		&
									 	!	for building pcs mail address	&
		long	pass_count%					,	! which number to call			&
			file_open81%					,	! is pager_101.dat open 		&
			illegal%					,	! keeps track of illegal pager #	&
			xmit_ok%					,	! number xmitt messages			&
			page_num%					,	! which number to call			&
			ats10%						,	! abandoning pag line error		&
			notify_staff%					,	! alarm server notify			&
			test_page%					,	! test message sent			&
			temp%						,	! checks to see if message numeric 	&
			sleeper%					,	! heart beat				&
			watchdog%					,	! counts watchdog			&
			message_count%					,	! send another message			&
			total_message%					,	! count total number of messages	&
			error_handler%					,	! incase of erorr			&
			sleep_count%					,	! keep modem wake			&
			sleep_set%					,	! keep modem wake			&
			restart_count%					,	! restart counter			&
			char_count					,	!					&
			timeout_count					,	! time out count			&
			polling_count					,	!					&
			timeout_flag					,	! 1=true				&
			comm_error					,	!					&
			alloc_flag					,	! 1=true				&
			event_flag_recv					,	! event flags	read			&
			event_flag_xmit					,	!		write			&
		word	funct_bits_rtp					,	! funct bits - read timed purge	&
		word	funct_bits_rtnp					,	!		read timed no purge	&
		word	funct_bits_recv					,	! funct bits - read			&
		word	funct_bits_xmit					,	! funct bits - write			&
		string	async_port$					,	! (change state)			&
			my_file$					,	!					&
			xmit_data					,	!					&
			recv_data						!
	!
	declare string	line1$		,&
			line2$		,&
			packet$		,&
			checksum$	,&
		long	i%		,&
			checksum%	,&
			char1%		,&
			char2%		,&
			char3%
        declare rfa	rfa_8x               					! record file address
	!
	!	<<< program constants >>>
	!
	declare long constant	k_buf_siz	=  132%				! for qio recv + qio xmit
	declare string constant	k_num_list	= "0123456789"
	!
	!	<<< device specific stuff >>>
	!
	map(neil)												&
	    string	dev_buf_xmit	= k_buf_siz			,	! xmit data buffer	- xmit	&
	    string	dev_buf_Recv	= k_buf_siz			,	! recv data buffer	- recv	&
	    word	dev_ch_xmit,						! xmit channel number	- xmit	&
			dev_ch_recv,						! recv channel number	- recv	&
	    IosbRec	iosb_xmit,						! i/o status block	- xmit	&
			iosb_recv						! i/o status block	- recv
	!
	declare	long	rc%						,	! return code			&
			sys_line						! line number
	!
	!	set up terminator descriptor block for qio_read
	!
	declare TDB_Rec TDB_Var							! create terminator descriptor block for qio_read
	!
	!	fill in the descriptor block's fields
	!	note: see	"OpenVMS_7.2-1 I/O User's Reference Manual"
	!	 		"5.4.1.2 Read Function Terminators"
	!
	TDB_Var::mask_type	= 0%						! we only want the "short form" of this call
	TDB_Var::mask		= 2%^13%					! <CR> is the only terminator we wish to use
	!
	!=======================================================================
	! Title: PAGERDB_101.REC
	!=======================================================================
	declare string constant pagerdb_fs$     = "csmis$dat:pagerdb_101.dat"
	!=======================================================================
	! Map used in the pager program
	!
	!	key-0	,primary key    (d81_recv_date,d81_recv_time)   duplicates descending
	!	key-1	,alternate key  d81_pager                       duplicates
	!	key-2	,alternate key  d81_status                      duplicates changes
	!	key-3	,alternate key  d81_last_name                   duplicates changes
	!=======================================================================
	map (my_disk81)								&
	    string	d81_whole_record= 170,	!			170	&
			d81_align	=   0	! force alignment check
	map (my_disk81)								&
	    string	d81_whole_data	= 161,	!			161	&
			filler81$	=   9,	! room to grow ...	170	&
			d81_align	=   0	! force alignment check
	map (my_disk81)								&
		string	d81_last_name	=  20,	! last name of pagee	 20	&
			d81_pager	=   8,	! 			 28	&
			d81_pager_type	=   1,	! P=pcs 		 29	&
			d81_message_buf	=  96,	! message lines 1-5	125	&
			d81_recv_date	=   8,	! ccyymmdd 		133	&
			d81_recv_time	=   6,	! hhmmss		139	&
			d81_xmit_date	=   8,	! ccyymmdd		147	&
			d81_xmit_time	=   6,	! hhmmss		153	&
			d81_status	=   1,	! page sent Y/N		154	&
			d81_pin		=   7,	! pin number		161	&
			filler81$	=   9,	! room to grow ...		&
			d81_align	=   0	! force alignment check
	map (my_disk81)								&
		string	d81_last_name	=  20,	! last name of pagee	20	&
			d81_pager	=   8,	! 			28	&
			d81_pager_type	=   1,	! 			29	&
			d81_message1	=  16,	! message line #1	45	&
	    		d81_message2	=  20,	!		2	65	&
			d81_message3	=  20,	!		3	85	&
	    		d81_message4	=  20,	!		4	105	&
	    		d81_message5	=  20,	!		5	125	&
			d81_recv_date	=   8,	! ccyymmdd 		133	&
			d81_recv_time	=   6,	! hhmmss		139	&
			d81_xmit_date	=   8,	! ccyymmdd		147	&
			d81_xmit_time	=   6,	! hhmmss		153	&
			d81_status	=   1,	! page sent Y/N		154	&
			d81_pin		=   7,	! pin number		161	&
			filler81$	=   9,	! room to grow ...		&
			d81_align	=   0	! force alignment check
	!
	!=======================================================================
	!	Initialize
	!=======================================================================
1300	on error goto error_trap						! get rid of this (when-error blocks are better)
	!
	!	<<< set up function bits for QIO >>>
	!
	!	Read, Timed, w/Purge
	!
	funct_bits_rtp =	(IO$_READVBLK	or			&
				 IO$M_DSABLMBX	or			&
				 IO$M_Purge	or			&
				 IO$M_NoFILTR	or			&
				 IO$M_Timed	or			&
				 IO$M_NOECHO)
	!
	!	Read, Timed, No Purge
	!
	funct_bits_rtnp =	(IO$_READVBLK	or			&
				 IO$M_DSABLMBX	or			&
				 IO$M_NoFILTR	or			&
				 IO$M_Timed	or			&
				 IO$M_NOECHO)
	!
	!	Write (unformatted)
	!
	funct_bits_xmit =	(IO$_WRITEVBLK	or			&
				 IO$M_CanCtrlO	or			&
				 IO$M_NoFormat)
	!
	!=======================================================================
	!	Main
	!=======================================================================
1500	main:									!
	margin #0, 132								! limit wrapping of the log file
	print k_program +"_"+ k_version
	print string$(len(k_program +"_"+ k_version), asc("="))                 ! underline previous line
	applic_debug%	= 999							! start debugging with a high value
	!
	!	/// get desired async port ///
	!
	!	LIB$GET_LOGICAL logical-name [,resultant-string] [,resultant-length] [,table-name]
	!
        rc% = lib$get_logical("DEMO$ASYNC_PORT", async_port$,,"LNM$PROCESS")
	if ((rc% and 7%) <> 1%) then
		print "-e- error: "+ str$(rc%) +" while reading logical DEMO$ASYNC_PORT"
		goto fini							! adios
	end if
	print "-i- using async port: ";async_port$
	!
	!	/// get desired phone number ///
	!
        rc% = lib$get_logical("DEMO$TELEPHONE", tel_num$,,"LNM$PROCESS")
	if ((rc% and 7%) <> 1%) then
		print "-e- error: "+ str$(rc%) +" while reading logical DEMO$TELEPHONE"
		goto fini							! adios
	end if
	print "-i- using telephone number: ";tel_num$
	!
	!	<<< try to allocate the device >>>
	!
1510	allocate_port:
	rc% = sys$alloc( async_port$,,,,)
	!
	select rc%
	    case ss$_normal
	    alloc_flag = 1%
	    print "-i- Allocated Device: ";async_port$
	case else
	    print "-e- Can't allocate device: ";async_port$
	    sys_line = 2100%
	    goto sys_error
	end select
	!
	!	<<< open a read channel >>>
	!
1520	rc% = sys$assign( async_port$, dev_ch_recv,,)
	if rc% <> ss$_normal then
	    sys_line = 2200%
	    goto sys_error
	end if
	print "-i- using channel(r): ";dev_ch_recv
	!
	!	<<< open a write channel >>>
	!
1530	rc% = sys$assign( async_port$, dev_ch_xmit,,)
	if rc% <> ss$_normal then
	    sys_line = 2200%
	    goto sys_error
	end if
	print "-i- using channel(x): ";dev_ch_xmit
	!
	!	<<< get an event flag for recv >>>
	!
1540	rc% = lib$get_EF(event_flag_recv	by ref)
	if rc% <> ss$_normal then
	    sys_line = 2300%
	    goto sys_error
	end if
	print "-i- using EF(r): ";event_flag_recv
	!
	!	<<< get an event flag for xmit >>>
	!
1550	rc% = lib$get_EF(event_flag_xmit	by ref)
	if rc% <> ss$_normal then
	    sys_line = 2400%
	    goto sys_error
	end if
	print "-i- using EF(x): ";event_flag_xmit
	!
	sleep 1
	print "-i- doing 1st read with purge "
	gosub	qio_recvp							! recv with purge (good for 1st time)
	!
	!	<<< initialize the modem >>>
	!
	modem_init:
	!
	!	set up modem option R1 (reset?)
	!
	ATR1:
	sleep 1%
	print "-i- Sending AT&R1"						! setting CTS
	xmit_data = "AT&R1" + CR						! send AT&R1 to modem
	gosub	qio_xmit							! transmit section
	!
	polling_count = 0							!
	while 1									!
	    gosub	qio_recv						! recv
	    if edit$(recv_data,32+4+2) <> "" then				!
	       print "-i- Dat-00>";recv_data;"<"				!
	    end if
	    if comm_error=1 then						!
		print "-e- comm error; initing modem (modem cleanup 1)"		!
		print "-i- Sending '+++' to wake up the modem port"		!
		sleep 2								! delay 2 seconds
		xmit_data = "+++"						! send escape sequence to modem
		gosub	qio_xmit						! send escape sequence to modem
		sleep 2								! delay 2 more second2
		goto modem_init							!
	    end if
	    goto ATC0 	if mid$(recv_data,1%,3%) = "OK"				!
	    polling_count = polling_count + 1%
	    if polling_count > 10% then						! > 10 clean up modem
		print "-i- waited in loop 10 times (modem cleanup 1)"		!
		print "-i- Sending '+++' to wake up the modem port"		!
		sleep 2								! delay 2 seconds
		xmit_data = "+++"						! send escape sequence to modem
		gosub	qio_xmit						! send escape sequence to modem
		sleep 2								! delay 2 more second2
		goto modem_init							! try this again
	    end if
	next
	!
	!	set up modem option C0
	!
	atc0:
	sleep 1%
	!
	!	set up modem option C1
	!
	print "-i- Sending AT&C1"						! setting DCD
	xmit_data = "AT&C0" + CR						! send AT&C0 to modem
	gosub	qio_xmit							! transmit section
	!
	polling_count = 0							!
	while 1									! will wait in this loop
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then				! print rec data if >
	       print "-i- Dat-01>";recv_data;"<"				! nothing
	    end if
	    if comm_error=1 then						!
		print "-e- comm error; initing modem (modem cleanup 2)"		!
		print "-i- Sending '+++' to wake up the modem port"		!
		sleep 2								! delay 2 seconds
		xmit_data = "+++"						! send escape sequence to modem
		gosub	qio_xmit						! send escape sequence to modem
		sleep 2								! delay 2 more second2
		goto modem_init							!
	    end if
	    goto ATD0 	if mid$(recv_data,1%,3%) = "OK"				! checking rec data
	    polling_count = polling_count + 1%
	    if polling_count > 10% then						! > 10 clean up modem
		print "-i- waited in loop 10 times (modem cleanup 2)"		!
		print "-i- Sending '+++' to wake up the modem port"		!
		sleep 2								! delay 2 seconds
		xmit_data = "+++"						! send escape sequence to modem
		gosub	qio_xmit						! send escape sequence to modem
		sleep 2								! delay another 2 seconds
		goto modem_init							! try this again
	    end if								!
	next									!
	!
	!	set up modem option D0
	!
	ATD0:
	!
	!	set up modem option W
	!
	ATW:
	print "-i- Sending AT&W"						! send to memory
	sleep 1%
	xmit_data = "AT&W" + CR 						! send AT&W to modem
	gosub	qio_xmit							! transmit section
	!
	polling_count = 0							!
	while 1									! will wait in this loop
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then				! print rec data if >
	       print "-i- Dat-02>";recv_data;"<"				!
	    end if
	    if comm_error=1 then						!
		print "-e- comm error; initing modem (modem cleanup 3)"		!
		print "-i- Sending '+++' to wake up the modem port"		!
		sleep 2								! delay 2 seconds
		xmit_data = "+++"						! send escape sequence to modem
		gosub	qio_xmit						! send escape sequence to modem
		sleep 2								! delay 2 more second2
		goto modem_init							!
	    end if
	    goto modem_set if mid$(recv_data,1%,3%) = "OK"			! checking rec data
	    polling_count = polling_count + 1%
	    if polling_count > 10% then						! > 10 clean up modem
		print "-i- waited in loop 10 times (modem cleanup 3)"		!
		print "-i- Sending '+++' to wake up the modem port"		!
		sleep 2								! delay 2 seconds
		xmit_data = "+++"						! send escape sequence to modem
		gosub	qio_xmit						! send escape sequence to modem
		sleep 2								! delay another 2 seconds
		goto modem_init							! try this again
	    end if
	next
	modem_set:
	!
	!
	print "-i- ========== modem initialized; entering main while/next block =========="
	pass_count% = 1%							! init (prep for 1st pass thru)
	!
    !====================================================================================================
    !	<<< stay in this loop forever >>>
    !
    !	note: no code should reference applic_debug% prior to this point
    !	(but modem initialization does so debugging is always enabled before this point)
    !====================================================================================================
    !
    while 1									! This program will run every xx seconds.
	!
	!	support for logging/tracing
	!
	!	LIB$GET_LOGICAL logical-name [,resultant-string] [,resultant-length] [,table-name]
	!
        rc% = lib$get_logical("CSMIS$APPL_PAG_SERVER_LOG", logging$,,"LNM$SYSTEM_TABLE")
	logging$ = ""
	if ((rc% and 7%) <> 1%) then
		logging$ = ""
	else
		logging$ = edit$(logging$,32+2)					!
		logging$ = "2" if left$(logging$,1) = "Y"			! eg. Y/es -> 2
	end if
	when error in
	    junk% = integer(logging$)
	use
	    junk% = 0
	end when
	if applic_debug% <> junk% then
	    applic_debug% = junk%
	    print "-i- switching to debug mode: ";applic_debug%
	end if
	!
	!	<<< start >>>
	!
        line1$ = ""								!
        line2$ = ""								!
	total_message% = 0%							!
	message_count% = 0%							!
	page_num% = 0% 								! clear pager_num
	gosub pager_packet							! get pager number and messages
	!
	if applic_debug% > 0 then						!
	    if total_message% > 0% then						!
		print "-i- The total number of messages = ";			!
		print total_message%						!
	    end if								!
	end if									!
	goto no_data if total_message% = 0%					! no messages to send
	!
	restart_count% = 0%							! clear counter
	!=======================================================================
	!	<<< Restart modem >>>
	!=======================================================================
1560	restart:
	restart_count% = restart_count% + 1%					!
	xmit_data = XON								! send XON to port
	gosub   qio_xmit							!
	sleep 1									! kill some time
	!
	gosub	qio_recvp							! clean up the incoming buffer
	print "-i- Sending ATH0 (going-on-hook)" if applic_debug% > 0		! making sure modem is on hook
	xmit_data = "ATH0" + CR							! send ATH0 to modem
	gosub	qio_xmit							! transmit section
	!
	polling_count = 0							! clear polling counter
	while 1									!
	    gosub	qio_recv						! recv (waits for '<cr>' or '2 second timeout')
	    if edit$(recv_data,32+4+2) <> "" then				! any data?
		 print "-i- Dat-03>";recv_data;"<"
	    end if
	    if comm_error=1 then						!
		print "-e- comm error; restarting (modem cleanup 4)"		!
		print "-i- Sending '+++' to wake up the modem port"		!
		sleep 2								! delay 2 seconds
		xmit_data = "+++"						! send escape sequence to modem
		gosub	qio_xmit						! send escape sequence to modem
		sleep 2								! delay 2 more second2
		goto restart							!
	    end if
	    goto ATH0 	if mid$(recv_data,1%,3%) = "OK"				! jump if we got an OK
	    polling_count = polling_count + 1					!
	    if polling_count > 10 then 						! > 10 clean up modem
		print "-i- waited in loop 10 times (modem cleanup 4)"		!
		print "-i- Sending '+++' to wake up the modem port"		!
		sleep 2								! delay 2 seconds
		xmit_data = "+++"						! send escape sequence to modem
		gosub	qio_xmit						! send escape sequence to modem
		sleep 2								! delay another 2 seconds
		goto restart							! try this again
	    end if								!
	next
	!
	!	modem is now on-hook
	!
	ATH0:
	sleep 2%								! let modem settle down
	print "-i- Sending AT (attention)"	if applic_debug% > 0		! displays next command
	xmit_data = "AT" + cr							! send AT to modem
	gosub	qio_xmit							! transmit section
	!
	timeout_count = 0%							! clears counter
	while 1									! wait for response
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then				! print rec data if > nothing
		print "-i- Dat-04>";recv_data;"<"	if applic_debug% > 0
	    end if
	    if comm_error=1 then						!
		print "-e- comm error; restarting"				!
		goto restart							!
	    end if
	    goto AT_OK	if mid$(recv_data,1%,3%) = "OK"				! check for ok
	    if timeout_flag=1% then						! timeout flag set
		timeout_count = timeout_count + 1%
		if timeout_count > 20% then					! 20 tries
		   print "-i- waited 20 times; restarting"
		   goto restart
		end if
	    end if
	next
	at_ok:
	!
	!	Send the phone number of other modem
	!
	! If page_num% is set to 0% the local Bell Mobility number will be used. If it is set to a 1%,
	! then the program tries to dump the messages to the Bell Mobility data base in Toronto.
	!
	xmit_data = "ATDT" + tel_num$ + cr					! prep to dial the telephone
	sleep 2%
	gosub	qio_xmit							! transmit  number to modem
	!
	timeout_count = 0%
	while 1									! wait for rec data
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then
		print "-i- Dat-05>";recv_data;"<"	if applic_debug% > 0
	    end if
	    if comm_error=1 then						!
		print "-e- comm error; restarting"				!
		goto restart							!
	    end if
	    goto restart	if mid$(recv_data,1%,2%) = "OK"
	    goto restart	if mid$(recv_data,1%,4%) = "BUSY"
	    goto connected	if mid$(recv_data,1%,4%) = "CONN"
!~~~	    goto restart	if mid$(recv_data,2%,1%) = "N"			x ???
!~~~	    goto restart	if mid$(recv_data,1%,1%) = "N"			x ???
	    goto restart	if mid$(recv_data,1%,10) = "NO CARRIER"		!
	    goto restart	if mid$(recv_data,1%,13) = "NO CONNECTION"	!
	    if mid$(recv_data,1%,05%) = "ATS10" then
		ats10% = 1%
	        goto reset_3plus
	    end if
	    timeout_count = timeout_count + 1%
	    goto restart	if timeout_count > 20%
	next
	!
	!	Connected to other modem
	!
	connected:
	!
	print "-i- Msg> Connected to pager company #"; pass_count%	if applic_debug% > 0
	timeout_count = 0%
	!
	!
	!------------------------------------------------------------------------------------------------------------------------
	! bf_122 Notes: (980316)
	! ======================
	! when we moved this application from the uVAX-4300 to the VAX-6420, this section of code stopped working. We had to add
	! an extra call to qio_recv which eats the echoed <cr> which we just sent. Then we call qio_recv to test for the "ID="
	! prompt from the other end.
	!
	! Note: We believe this echo stuff started to happen when Bell Mobility added a mux between their modems and their paging
	! computer. At that same time they required that a <cr> be periodically sent to hold up the line when their computer is
	! slow to respond (I guess the mux can actually drop an idle line)
	!------------------------------------------------------------------------------------------------------------------------
	while 1									! wait for rec data
	    sleep 2%								! let modem settle down
	    xmit_data =  cr							!
	    gosub	qio_xmit						! send <cr> to modem
	    timeout_count = 0							!
	    gosub	qio_recv						! recv "echoed <cr>" or "ID="
	    if edit$(recv_data,32+4+2) = "" then				! if just an echoed <cr>...
		gosub	qio_recv						! then wait for "ID="
	    end if								!
	    if edit$(recv_data,32+4+2) <> "" then
		print "-i- Dat-06>";recv_data;"<"	if applic_debug% > 0
	    end if
	    if comm_error=1 then						!
		print "-e- comm error; restarting"				!
		goto restart							!
	    end if
	    goto ID		if mid$(recv_data,1%,2%) = "ID"			! this is what we want so jump to next section
	    goto ID		if mid$(recv_data,1%,2%) = "TDD"		! Quebec response ?
!~~~	    goto restart	if mid$(recv_data,2%,1%) = "N"			x
	    if mid$(recv_data,1%,05%) = "ATS10" then
		ats10% = 1%
	        goto reset_3plus
	    end if
	    goto restart	if mid$(recv_data,1%,10) = "NO CARRIER"		!
	    goto restart	if mid$(recv_data,1%,13) = "NO CONNECTION"	!
	    print " timeout_count = " + str$(timeout_count)			! added line to monitor missing pages
	    timeout_count = timeout_count + 1%					!
	    if timeout_count > 60% then						!
		notify_staff% = notify_staff% + 1%				!
		if notify_staff% > 10% then					! if not send after 10 minute notify admin/CTL
		    PRINT "-i- Entered alarm section"				!
!~~~		    mail alarm message to system admin				x
		end if								!
	        goto at_cleanup 						!
	    end if								!
	next									!
	!
	!	We just received the 'ID=' prompt so send '<esc>PG1' to Bell Mobility
	!
	id:
	print "-i- Msg> Sending <esc>PG1 <<<---***"	if applic_debug% > 0
	if edit$( WCSM_TrnLnm( "CSMIS$PROV", "LNM$SYSTEM_TABLE" ),32+4+2) = "QUEBEC"
	then
	    xmit_data = ESC1 + "PG1Bell01" + cr					! starting pager dialog (Quebec)
	else
	    xmit_data = ESC1 + "PG1" + cr					! starting pager dialog (Ontario)
	end if
	gosub	qio_xmit							! transmit section
	!
	timeout_count = 0%
	while 1									! wait for rec data
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then
		print "-i- Dat-07>";recv_data;"<"	if applic_debug% > 0
	    end if
	    if comm_error=1 then						!
		print "-e- comm error; restarting"				!
		goto restart							!
	    end if
	    goto send_packet	if mid$(recv_data,1%,2%) = "[p"			! this is what we want...
!~~~	    goto restart	if mid$(recv_data,2%,1%) = "N"			x ???
!~~~	    goto restart	if mid$(recv_data,1%,1%) = "N"			x ???
	    goto restart	if mid$(recv_data,1%,10) = "NO CARRIER"		!
	    goto restart	if mid$(recv_data,1%,13) = "NO CONNECTION"	!
	    if mid$(recv_data,1%,05%) = "ATS10" then
		ats10% = 1%
	        goto reset_3plus
	    end if
	    timeout_count = timeout_count + 1%
	    goto restart 	if timeout_count > 20%
	next
	!
	send_packet:
	!
	if total_message% > 0% then						! if > 0 the program
	    message_count% = message_count% + 1%				! has a message to
	    goto send_dis if message_count% > total_message%			! deliver
	    print "-i- Sending message "; + message_count%	if applic_debug% > 0
	end if									! the screen
	!
	print "-i- Msg> Sending Packet"	if applic_debug% > 0
	xmit_data = packet$(message_count%)
	gosub	qio_xmit							! sending message
1580										! to Bell Molility
	timeout_count = 0%
	while 1
	    gosub	qio_recv						! check receiver
	    if applic_debug% > 0 then
		if pos( recv_data, NAK, 1%) > 0%
		then
		    print "-i- Dat-08>NAK< Len:";len(recv_data)
		else
		    print "-i- Dat-08>";recv_data;"< Len:";len(recv_data)
		    if len(recv_data) = 1% then
			print "-i- Dat-08>";ASC(recv_data);"< Len:";len(recv_data)
		    end if
		end if
	    end if								!
	    if comm_error=1 then						!
		print "-e- comm error; goto NAK"				!
		goto NAK							!
	    end if								!
	    !
	    ! Moved this piece of code down below the test for NAKs. This is to satisfy Quebec Bell Mobility
	    !
	    !if mid$(recv_data, 1%, 1%) = ACK then				x message ack'ed
	    !	xmit_ok% = message_count%					x keeps track of
	    !    goto send_packet						x number of messages
	    !end if								x sent
	    goto NAK	if pos( recv_data, NAK, 1%) > 0%			!
	    goto NAK	if mid$(recv_data,1%,1%)	= CAN			! added AGD 1996-03-14
	    goto NAK	if mid$(recv_data,1%,5%)	= "Illeg"		!
	    goto NAK	if mid$(recv_data,1%,5%)	= "Too S"		!
	    goto NAK	if mid$(recv_data,1%,10)	= "NO CARRIER"		!
	    goto NAK	if mid$(recv_data,1%,13)	= "NO CONNECTION"	!
	    !
	    if mid$(recv_data,1%,05%) = "ATS10" then				!
		ats10% = 1%							!
	        goto reset_3plus						!
	    end if								!
	    if mid$(recv_data, 1%, 1%) = ACK then				! message ack'ed
		    xmit_ok% = message_count%					! keeps track of
	            goto send_packet						! number of messages
	    end if								! sent
	    timeout_count = timeout_count + 1%					!
	    print "Waiting for ACK timeout_count = " + str$(timeout_count)	!
	    goto send_dis if timeout_count > 40%				!
	    iterate								!
	next									!
	!+
	!	Message was not OK
	!-
	NAK:
	print "-e- Something is wrong please try again later..."		!
	print "-i- Dat-09>";recv_data;"<"					!
	illegal% = illegal% + 1%						! keeps track of failed
	illegal_num$(illegal%) = str$(message_count%)				! messages
	xmit_ok% = message_count%						!
	goto ACK	if mid$(recv_data,1%,10) = "NO CARRIER"			!
	goto ACK	if mid$(recv_data,1%,13) = "NO CONNECTION"		!
	goto send_packet							!
	!
	!	Message was OK
	!
	ACK:
	send_dis:
	message_count% = 0%							!
	total_message% = 0% 							!
	print "-i- Msg> Sending disconnect"	if applic_debug% > 0		!
	xmit_data = EOT + cr							! backing away from Bell
	gosub	qio_xmit							! Mobility
	!
	timeout_count = 0%							!
	while 1									!
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then				!
		print "-i- Dat-10>";recv_data;"<"	if applic_debug% > 0	!
	    end if								!
	    if comm_error=1 then						!					bf_130.1
		print "-e- comm error; goto reset_3plus"			!
		goto reset_3plus						!
	    end if								!
1590	    goto at_cleanup	if mid$(recv_data,1%,03%) = "+++"		!
	    goto at_cleanup	if mid$(recv_data,1%,10) = "NO CARRIER"		!
	    goto at_cleanup	if mid$(recv_data,1%,13) = "NO CONNECTION"	!
	    if mid$(recv_data,1%,05%) = "ATS10" then				!
		ats10% = 1%							!
	        goto reset_3plus						!
	    end if								!
	    timeout_count = timeout_count + 1%					!
	    goto reset_3plus if timeout_count > 20%				!
	next									!
	!
	!	send 3 plus signs to the modem (to get it out of data mode)
	!
	reset_3plus:								!
	sleep 2%								!
	print "-i- Sending +++ cleaning up modem port"	if applic_debug% > 0	!
	sleep 2									! produce a 2 second silent period
	xmit_data = "+++"							! send escape sequence to modem
	gosub	qio_xmit							!
	sleep 2									! produce a 2 second silent period
	!
	timeout_count = 0%							!
	while 1									!
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then				!
		print "-i- Dat-11>";recv_data;"<"	if applic_debug% > 0	!
	    end if								!
	    !
	    !	we're probably in trouble so just ignore comm errors
	    !
	    if comm_error=1 then						!					bf_130.1
		comm_error=0							!
	    end if								!
	    !
!~~~	    goto at_cleanup	if mid$(recv_data,2%,1%)	= "N"		x ???					bf_128.7
!~~~	    goto at_cleanup	if mid$(recv_data,1%,1%)	= "N"		x ???					bf_128.7
	    goto at_cleanup	if mid$(recv_data,1%,10) = "NO CARRIER"		!
	    goto at_cleanup	if mid$(recv_data,1%,13) = "NO CONNECTION"	!
	    goto at_cleanup	if mid$(recv_data,1%,3%)	= "OK"		!
	    goto at_cleanup	if mid$(recv_data,1%,3%)	= "+++"		!
	    timeout_count = timeout_count + 1%					!
	    goto at_cleanup if timeout_count > 3%				!
	next									!
	!
	!	now send the ATTENTION command
	!
	at_cleanup:								!
	sleep 2%								!
	print "-i- Sending AT cleaning up modem port"	if applic_debug% > 0	!
	xmit_data = "AT" + cr							! send AT to modem
	gosub	qio_xmit							!
	!
	timeout_count = 0%							!
	while 1									!
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then				!
		print "-i- Dat-12>";recv_data;"<"	if applic_debug% > 0	!
	    end if								!
	    if comm_error=1 then						!					bf_130.1
		print "-e- comm error; restarting"				!
		goto restart							!
	    end if								!
	    goto atz_cleanup	if mid$(recv_data,1%,3%) = "OK"			!
	    goto atz_cleanup	if mid$(recv_data,1%,10) = "NO CARRIER"		!
	    goto atz_cleanup	if mid$(recv_data,1%,13) = "NO CONNECTION"	!
	    if mid$(recv_data,1%,05%) = "ATS10" then				!
		ats10% = 1%							!
		print "-e- looping to reset_3plus"				!
	        goto reset_3plus						!
	    end if								!
	    timeout_count = timeout_count + 1%					!
	    goto atz_cleanup if timeout_count > 20%				!
	next									!
	!
1600	atz_cleanup:								!
	sleep 2%								!
	print "-i- Sending ATZ cleaning up modem port"	if applic_debug% > 0	!
	xmit_data = "ATZ" + cr							! send AT to modem
	gosub	qio_xmit							!
	!
	timeout_count = 0%							!
	while 1									!
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then				!
		print "-i- Dat-13>";recv_data;"<"	if applic_debug% > 0	!
	    end if								!
	    !
	    !	we're trying to get control so just ignore errors
	    !
	    if comm_error=1 then						!					bf_130.1
		comm_error=0							!
	    end if								!
	    goto ATH0_cleanup	if mid$(recv_data,1%,3%) = "OK"			!
	    if mid$(recv_data,1%,05%) = "ATS10" then				!
		ats10% = 1%							!
	        goto reset_3plus						!
	    end if								!
	    timeout_count = timeout_count + 1%					!
	    goto ath0_cleanup if timeout_count > 20%				!
	next									!
	!
	!	now go on hook
	!
	ATH0_cleanup:								!
	sleep 2%								!
	print "-i- Sending ATH0 (going on-hook) cleaning up modem port"	if applic_debug% > 0
	!
	xmit_data = "ATH0" + cr							! send ATH0 to modem
	gosub	qio_xmit							!
	!
	timeout_count = 0%							!
	while 1									!
	    gosub	qio_recv						! check receiver
	    if edit$(recv_data,32+4+2) <> "" then
		print "-i- Dat-14>";recv_data;"<"	if applic_debug% > 0
	    end if
	    !
	    !	we're trying tro regain control so ignore errors
	    !
	    if comm_error=1 then						!					bf_130.1
		comm_error=0							!
	    end if
	    goto pager_update	if mid$(recv_data,1%,3%) = "OK"
	    if mid$(recv_data,1%,05%) = "ATS10" then
		ats10% = 1%
	        goto reset_3plus
	    end if
		timeout_count = timeout_count + 1%
		goto pager_update if timeout_count > 20%
	next
	!
1700	pager_update:
	!
	! The following section is used to update the pagerdb_101.dat file.
	! The data file is updated with the time and date the pager was paged.
	! Also a status flag is set from "N" to "Y" to tell the program the message has been delivered.
	!
	goto no_data if  ats10% = 1%						! abandoning page update
	goto no_data if  test_page% = -99%					! test message sent
	gosub open_file81							! opening file
	notify_staff% = 0%

       	if file_open81% = 0%  then  						! file failed to open
	    print "-e- File pagerdb_101.dat didn't open"
	    goto fini								!
	end if
	illegal% = 1%
	!
	while (xmit_ok% > message_count%)					! stay in loop until  all messages are updated
	    message_count% = message_count% + 1%				!
	    when error in							!
		print "-i- message_count: ";xmit_count$(message_count%)	if applic_debug% > 0
		!
	        get #81,key#0 eq xmit_count$(message_count%),regardless		!
		error_handler% = 0%						! show that GET worked
		duplicate_rec_time:						! does another search if
		if d81_status = "Y" then					! duplicate rec time.
	            get #81%, regardless					!
		    goto duplicate_rec_time					!
		else								!
	            rfa_8x = getrfa(81%)					!
	            get #81%,rfa rfa_8x						! locks record number
		end if								!
		!
		!if d81_status = "Y" then
	        !    find #81%, regardless
	        !    rfa_8x = getrfa(81%)
	        !    get #81%,rfa rfa_8x              				x locks record number
		!else
	        !    get #81%,rfa rfa_8x					x locks record number
		!end if
		error_handler% = 0%						! show that FIND/GET worked
1900		!
		!  If the page passed, the following data is sent to the pagerdb_101.dat file
		!
		if str$(message_count%) <> illegal_num$(illegal%)		!
		then								!
                    current_dt$		= wcsm_dt_stamp      			!
                    d81_xmit_date	= left$(current_dt$,8)      		!
                    d81_xmit_time	= right$(current_dt$,9)      		!
	            d81_status		= "Y"					!
		else								!
		    illegal% = illegal% + 1					!
    		    d81_xmit_date = "PagerErr"					!
	            d81_status	=  "E"						!
		    !d81_message2 = "This is an invalid"			!
		    !d81_message3 = "pager number"				!
		end if								!
		update #81%							! update file
		error_handler% = 0%						! show that UPDATE worked
		xmit_count$(message_count%) = ""				! clear count
	    use
		error_handler% = err
		print "-e- error: "+ str$( error_handler% ) +" at line 1900" if error_handler% <> 11%
	    end when
	    !
	    goto no_data if error_handler% = 11%				! no more data
	    restore #81%,key# 0%						! go for another record
	next
	!
	no_data:
	mat illegal_num$ = nul$							! added to clear illegal page array
	xmit_ok% = 0%
	ats10% = 0%
	!
	close #81%								! close file
	!
	if pass_count% = 3% then						! if on last pass
	    !
	    !	run faster (sleep less) from 07:00 through 17:59
	    !
	    junk$ = wcsm_dt_stamp						! ccyymmddhhmmss
	    select mid$(junk$,9,2)
		case "07" to "17"
		    sleep% = 10
		case else
		    sleep% = 60
	    end select
	    !
	    print "-i- Sleeping for "+str$(sleep%)+" seconds: ";left$(junk$,8) +"."+ mid$(junk$,9,6)
	    sleep sleep%
	    pass_count% = 1%							! prep for first pass
	else
	    pass_count% = pass_count% + 1%					! prep for next pass
	end if
	total_message% = 0%
	illegal% = 0%
	sleeper% = 0%
	test_page% = 0%
    next
	!
	!=======================================================================
	! Qio_Xmit
	!=======================================================================
	qio_xmit:
	!
	dev_buf_xmit = xmit_data						! xfer data to mapped string
	char_count = len(xmit_data)						! get length of string for qio
	!
	!	<<< xmit data >>>
	!
	!	SYS$QIO [efn] ,chan ,func ,[iosb] ,[astadr] ,[astprm] ,[p1] ,[p2] ,[p3] ,[p4] ,[p5] ,[p6]
	!
8000	rc% = sys$qio(	event_flag_xmit		by value,	! efn		&
			dev_ch_xmit		by value,	! chan		&
			funct_bits_xmit		by value,	! func		&
			iosb_xmit::quad_0	by ref,		! iosb		&
						,		! ast addr	&
						,		! ast param	&
			dev_buf_xmit		by ref,		! p1=buf addr	&
			char_count		by value,	! p2=buf size	&
						,		! p3=ignored	&
						,		! p4=cr spec	&
						,		! p5=N/A	&
							)	! p6=N/A
	!
	select rc%								!
	    case    ss$_normal							!
	    case    else							!
			sys_line = 8000%					!
			goto sys_error 						!
	end select								!
	!
	if applic_debug% > 0 then						!
	    dump_string$ = xmit_data						!
	    gosub hex_dump_of_dump_string					!
	end if
	!
	return
	!=======================================================================
	! Qio_Receive w/Purge
	!=======================================================================
	qio_recvp:
	!
	funct_bits_recv = funct_bits_rtp					! read, timed, purge
	!
	goto qio_recv_common							!
	!=======================================================================
	! Qio_Receive
	!=======================================================================
	qio_recv:
	!
	funct_bits_recv = funct_bits_rtnp					! read, timed, no purge
	qio_recv_common:
	!
	dev_buf_Recv	= ""							! init buffer for next qio
	!
	!	<<< read next line >>>
	!
	!	SYS$QIO [efn] ,chan ,func ,[iosb] ,[astadr] ,[astprm] ,[p1] ,[p2] ,[p3] ,[p4] ,[p5] ,[p6]
	!
9000	rc% = sys$qiow(	event_flag_recv		by value	,	! efn			&
			dev_ch_recv		by value	,	! chan			&
			funct_bits_recv		by value	,	! func			&
			iosb_recv::quad_0	by ref		,	! iosb			&
								,	! ast addr		&
								,	! ast param		&
			dev_buf_Recv		by ref		,	! p1=buf addr		&
			k_buf_siz		by value	,	! p2=buf size		&
			2%			by value	,	! p3=timeout		&
			loc(TDB_Var::mask_type)	by value	,	! p4=read term		&
								,	! p5=prompt addr	&
								)	! p6=prompt size
	!
	timeout_flag	= 0%							! always reset this
	comm_error	= 0%							! ditto
	!
	if (rc% and 7%) = 1							! if we queued ok...
	then
	    select iosb_recv::rc						! then test the completion status	bf_129.1
		case	ss$_normal						! we must have detected a <cr>
		case    ss$_timeout						! we timed out (might have data, but no <cr>)
		    timeout_flag	= 1					! ...raise timeout flag
		case	ss$_parity						! we have a parity error
		    print "-e- parity error (recv)"
		    comm_error		= 1					!
		case else							! not sure but we'll try to cope with this
		    print "-e- ??? (recv) iosb-rc:";iosb_recv::rc		!
	    end select								!
	else									!
		sys_line = 9000%						!
		goto sys_error 							!
	end if									!
	!
	timeout_count = 0 if timeout_flag = 0					! always reset count on no-time-out
	!
	recv_data = left$(dev_buf_Recv, iosb_recv::xfer_count)			! extract data from buffer
	!
	if applic_debug% > 0 then
	    if timeout_flag=1% then						!
		print " (Recv timeout)"						!
	    else								!
		print								!
	    end if								!
	    print "                  ";						!
	    dump_string$ = left$(dev_buf_Recv, iosb_recv::xfer_count)		!
	    gosub hex_dump_of_dump_string					!
	end if									!
	!
	recv_data = edit$(recv_data, 128%+4%)					! drop trailing, drop controls (optional)
	!
	return
	!=======================================================================
	!	dump the data string in hex for analysis by humans
	!=======================================================================
	hex_dump_of_dump_string:
	declare string constant	hex_string$	= "0123456789abcdef"
	declare long	dump_i%		,&
			dump_j%		,&
			dump_k%		,&
			dump_hi%	,&
			dump_lo%	,&
		string	hex_data_string$
	!
	dump_i% = 0%								! init for 'no source data'
	dump_j% = len(dump_string$)						! test our data source
	hex_data_string$ = ""							!
	while (dump_i% < dump_j%)						! if not done...
		dump_i% = dump_i% + 1%						! advance index
		dump_k% = asc(mid$(dump_string$,dump_i%,1%))			! extract byte
		dump_hi%= integer(dump_k% / 16%)				! get high nibble
		dump_lo%= mod(dump_k%, 16%)					! get low  nibble
		hex_data_string$ = hex_data_string$ +				&
			mid$(hex_string$,dump_hi%+1%,1%)+			&
			mid$(hex_string$,dump_lo%+1%,1%)+			&
			" "							!
	next									!
	print "Hex dump>";hex_data_string$					!
	return									!
	!====================================================================================
	! This section retrieves the messages from the pager data base.
	! It also builds the packet to send Bell Mobility and generates the checksum.
	!====================================================================================
	pager_packet:
	!
	if pass_count% = 1% then						!
	    if  mid$(current_dt$,9%,4%) = rename_time$ then
		gosub open_file81
		when error in
            	    error_handler% = 0%
	            open pagerdb_fs$  as file #82%                          &
                        ,access             modify                          &
                        ,allow              modify                          &
                        ,contiguous                                         &
                        ,organization       indexed                         &
                        ,map                my_disk81                       &
                        ,connect 81
        	use
            	    error_handler% = err
        	end when
		select error_handler%
		    case 0%
		    case else
			print "-e- error Opening second channel on pagerdb.dat " + str$(error_handler%)
			goto delete_data_skip
		end select
		!
		when error in
            	    error_handler% = 0%
	 	    while 1
		        get #81%,regardless
	                rfa_8x = getrfa(81%)
	                get #82%,rfa rfa_8x					! locks record number
		        delete #82%
		    next
		use
            	    error_handler% = err
		end when
		select error_handler%
		    case 0%
		    case 11%
			print "-i- info Deleted yesterday's data"
		    case else
			print "-e- error Deleting yesterday's data " + str$(error_handler%)
		end select
		close #81%
		close #82%
		gosub open_file81
	        d81_last_name  = "DOHERTY"
	        d81_pager = "339885"
		rset d81_pager = d81_pager
	        d81_pager_type = "A"
	        d81_message1 = "Removed old Pages   "
	        d81_message2 =  left$(current_dt$,8)
	        d81_message3 = "                    "
	        d81_message4 = "                    "
	        d81_message5 = "                    "
	        current_dt$	= wcsm_dt_stamp
	        d81_recv_date	= left$(current_dt$,8)
	        d81_recv_time	= right$(current_dt$,9)
!~~~	        d81_status	= "N"
		!
	        d81_xmit_date	= left$(current_dt$,8)
	        d81_xmit_time	= right$(current_dt$,9)
	        d81_status	= "Y"
	        d81_pin		= "N194943"
	        put #81%
	        close #81%
	    end if
	end if
	!
	delete_data_skip:
	!
	gosub open_file81
	!
	current_dt$ = wcsm_dt_stamp
       	if file_open81% = 0%  then						! file failed to open
	    print "-e- File pagerdb_101.dat didn't open"
	    goto fini
	end if
	!
	!	<<< get packet >>>
	!
	get_packet:
        d81_whole_data  = ""
	when error in
	    !print "-i- info:  total_message% count = " +str$(total_message%)
	    goto new_message if total_message% > 0%
	    select pass_count%
		case = 1%
		   total_message% = 0%
	    	   restore #81%,key# 2%						! go for another record
		   error_handler% = 0%
	           d81_whole_data  = ""
                   get #81%, key# 2% eq "N", regardless				! now use it to search
	           rfa_8x = getrfa(81%)						!
		   if d81_pager_type = "P" then					!
			gosub pcs_page						!
		        goto get_packet						!
		   end if							!
 		   rset d81_pager = d81_pager					!
		   select left$(d81_pager,1)					! Only test first character
			case "4"						! used for paging SSMR
			case "2"						! used for paging Sudbury
			case else						! used for paging everyone else
	                    line1$ = "416"+edit$(d81_pager,32+4+2)		! Bell Mobility going to 10 digit dialing
	                    line2$ = d81_message1  + d81_message2 + d81_message3 + d81_message4 + d81_message5
		   end select
		case = 2%
		   total_message% = 0%
	    	   restore #81%,key# 2%						! go for another record
		   error_handler% = 0%
	           d81_whole_data  = ""
                   get #81%, key# 2% eq "N", regardless				! now use it to search
	           rfa_8x = getrfa(81%)
		   if d81_pager_type = "P" then
			gosub pcs_page
		        goto get_packet
		   end if
 		   rset d81_pager = d81_pager
!~~~		   select left$(d81_pager,2%)
		   select left$(d81_pager,1%)					! all 705 pagers start with 2
!~~~			case  "11"
			case  "2"						! paging Sudbury 705
	                    line1$ = right$(d81_pager,2%)			! subtracking the number 2
	                    line2$ = d81_message1  + d81_message2 + d81_message3 + d81_message4 + d81_message5
		   end select
		case = 3%
		   total_message% = 0%
	    	   restore #81%,key# 2%						! go for another record
		   error_handler% = 0%
	           d81_whole_data  = ""
                   get #81%, key# 2% eq "N", regardless 			! now use it to search
	           rfa_8x = getrfa(81%)
		   if d81_pager_type = "P" then
			gosub pcs_page
		        goto get_packet
		   end if
 		   rset d81_pager = d81_pager
	           rfa_8x = getrfa(81%)
!~~~		   select left$(d81_pager,2%)
		   select left$(d81_pager,1%)
			case  "4"						! used for paging SSMR
	                    line1$ = right$(d81_pager,2%)
	                    line2$ = d81_message1  + d81_message2 + d81_message3 + d81_message4 + d81_message5
		   end select
	    end select
	use
	    error_handler% = err
	end when
	!
	select error_handler%
	    case 0%
	    case else
		!print "-e- error: "+str$( error_handler% ) +" during get #81, key 2 eq 'N'"
		error_handler% = 0%
	        line1$ = ""
	        line2$ = ""
	        total_message% = 0%
	        message_count% = 0%
		close #81%
	        return
	end select
	goto build_packet
	!
	!	<<< new message >>>
	!
	new_message:
	line1$ = ""
	line2$ = ""
	when error in
	    select pass_count%
		case = 1%
	     	    error_handler% = 0%
	            d81_whole_data  = ""
            	    get #81%, regardless 					! now use it to search
	            rfa_8x = getrfa(81%)
		    if d81_pager_type = "P" then
			gosub pcs_page
		        goto new_message
		    end if
 		    rset d81_pager = d81_pager
	            rfa_8x = getrfa(81%)
!~~~		    select left$(d81_pager,2%)
		    select left$(d81_pager,1%)
!~~~			case "11"
!~~~			case "22"
			case "4"						! used for paging SSMR
			case "2"						! used for paging Sudbury
			case else						! used for paging everyone else
	                    line1$ = "416"+edit$(d81_pager,32+4+2)		! Bell Mobility going to 10 digit dialing
!~~~	                    line1$ = edit$(d81_pager,32+4+2)
	                    line2$ = d81_message1  + d81_message2 + d81_message3 + d81_message4 + d81_message5
		   end select
		case = 2%
	     	    error_handler% = 0%
	            d81_whole_data  = ""
            	    get #81%,regardless ! now use it to search
	            rfa_8x = getrfa(81%)
		    if d81_pager_type = "P" then
			gosub pcs_page
		        goto new_message
		    end if
 		    rset d81_pager = d81_pager
!~~~		    select left$(d81_pager,2%)
		    select left$(d81_pager,1%)
!~~~			case  "11"
			case  "2"						! paging Sudbury 705
	                    line1$ = right$(d81_pager,2%)			! subtracking the number 2
	                    line2$ = d81_message1  + d81_message2 + d81_message3 + d81_message4 + d81_message5
			case else
			    goto new_message
		    end select
		case = 3%
	     	    error_handler% = 0%
	            d81_whole_data  = ""
            	    get #81%,regardless						! now use it to search
	            rfa_8x = getrfa(81%)
		    if d81_pager_type = "P" then
			gosub pcs_page
		        goto new_message
		    end if
 		    rset d81_pager = d81_pager
		    select left$(d81_pager,1%)
			case  "4"						! used for paging SSMR
	                    line1$ = right$(d81_pager,2%)
	                    line2$ = d81_message1  + d81_message2 + d81_message3 + d81_message4 + d81_message5
			case else
			    goto new_message
		    end select
	    end select
	use
	    error_handler% = err
 	    d81_status = "E"  					     		! when set to "E" end of
	end when
	!
	select error_handler%
	    case 0%
	    case else
		if applic_debug% > 0 then
		    print "-i- info: "+str$( error_handler% ) +" during get #81, regardless"
		    print "-i- info: pass count "+str$( pass_count% )
		end if
		error_handler% = 0%
		line1$ = ""
		line2$ = ""
		total_message% = message_count%
		message_count% = 0%
		return
	end select
	!
	!	<<< build packet >>>
	!	modified the next few lines to stop search if page is blank
	!
	build_packet:
 	if edit$(d81_pager,32+4+2) = "" then					! if pager field is blank...
	    print "-i- info: pager field blank"	if applic_debug% > 0
	    when error in
	        get #81%,rfa rfa_8x						! lock record
	        delete #81%							! blow it away
	    use
		print "-e- error: Deleting record no pager number " + str$(err)
	    end when
	    line1$ = ""
	    line2$ = ""
	    total_message% = message_count%
	    message_count% = 0%
	    return
	end if
	!
	if line1$ + line2$ = "" then
	    print "-w- both line1$ + line2$ are blank" 	if applic_debug% > 0
	    line1$ = "blank"
	    line2$ = "blank"
	    total_message% = message_count%
	    message_count% = 0%
	    return
	end if
	!
 	if d81_status <> "N" then
	    print "-i- status <> 'N', no more messages to send " + "d81_status = " + d81_status	if applic_debug% > 0
	    line1$ = ""
	    line2$ = ""
	    total_message% = message_count%
	    message_count% = 0%
	    return
	end if
	!
	if d81_pager_type = "N"	then						! checking the first char
	    print "-i- pager type = 'N'"	if applic_debug% > 0
	    page_num% = 1%							! is a "1"
	    select left$(d81_pager,1%)
		case "4"							! used for paging SSMR (Sault Saint Marie)
                    line1$ = right$(d81_pager,2%)
		case "2"							! used for paging Sudbury
                    line1$ = right$(d81_pager,2%)
		case else							! used for paging everyone else
	            line1$ = "416"+edit$(d81_pager,32+4+2)			! Bell Mobility going to 10 digit dialing
!~~                    line1$ = edit$(d81_pager,32+4+2)
	   end select
!~~~	    line1$ = d81_pager
	    line2$ = left$(line2$,12%)
	    line2$ = edit$(line2$,32+4+2)
	end if
	!
	!	<<< wake >>>
	!
	wake:
	!
	!	940524, added edit$(4%) to prevent junk paging text
	!
	packet$ = STX + edit$(line1$,4%) + cr + edit$(Line2$,4%) + cr + ETX
	!packet$ = STX + line1$ + cr + Line2$ + cr + ETX
	!
	message_count% = message_count% + 1%
	!
	total_message% = message_count%
	!
	checksum%=0%
	for i% = 1% to len( packet$ )
	    checksum% = checksum% + asc( mid$(packet$,i%,1%) )
	next i%
	char1%		= checksum% / 256%					! 1st char
	checksum%	= checksum% - char1% * 256%
	!
	char2%		= checksum% / 16%					! 2cd char
	checksum%	= checksum% - char2% * 16%
	!
	char3%		= checksum%						! 3rd char
	!
  	checksum$	= chr$(48% + char1% ) + chr$(48% + char2% ) + chr$(48% + char3% )
	!
 	packet$(message_count%) = STX + line1$ + cr + Line2$ + cr + ETX + checksum$ + cr
	!
	! 'd81_recv_date' and 'd81_recv_time' are used to to find a record in the pagerdb_101.dat file.
	!
	xmit_count$(message_count%) = d81_recv_date + d81_recv_time
	if applic_debug% > 0 then
	    print "-i- line  : ";line1$
	    print "-i- packet: ";packet$
	end if
	!
	goto new_message
	!=======================================================================
	! Paging a PCS phone is done via smtp mail the phone number is the
	! mailing address [email protected]
	!=======================================================================
	pcs_page:
	when error in
            error_handler% = 0%
	    open pagerdb_fs$  as file #82                       &
            ,access             modify                          &
            ,allow              modify                          &
            ,contiguous                                         &
            ,organization       indexed                         &
            ,map                my_disk81                       &
            ,connect 81
        use
            error_handler% = err
        end when
	get #82%,rfa rfa_8x							! lock record number
	current_dt$	= wcsm_dt_stamp
	d81_xmit_date	= left$(current_dt$,8)
	d81_xmit_time	= right$(current_dt$,9)
	d81_status = "Y"
	rset d81_pager = edit$(d81_pager,32+4+2)				!
!	when error in
	    update #82%
!	use
!	end when
	close #82%
	select left$(d81_pager,1%)
	    case "A"
		Area_code$ = "416"
	    case "B"
		Area_code$ = "613"
	    case "C"
		Area_code$ = "514"
	    case "D"
		Area_code$ = "519"
 	    case "E"
		Area_code$ = "705"
	    case "F"
		Area_code$ = "905"
	    case "G"
		Area_code$ = "819"
	    case "H"
		Area_code$ = "418"
	end select
	!
	mail_filename$ =  "CSMIS$ROOT1:[spool]"+Area_code$+mid$(d81_pager,2%,7%)+".spl"
	open mail_filename$ for output as file #1%,  &
                                    recordsize 132
	print #1,d81_message1
	print #1,d81_message2
	print #1,d81_message3
	print #1,d81_message4
	print #1,d81_message5
	close #1
	mail_address$ = "smtp%" + '"""' + Area_code$+mid$(d81_pager,2%,7%)+"@txt.bellmobility.ca"  + '"""'
	junk% = wcsm_submit_to_batch( 										&
                                        "CSMIS$BATCH"                                   ,! batch queue                  &
                                        "CSMIS$COM:mail_queue_server.com"               ,! batch program                &
                                        "mail_queue_server.log"                         ,! batch logfile NSR 96.0813    &
                                        ""                                              ,! user                         &
                                        mail_filename$					,! p1$  print file              &
                                        mail_address$ 					,! p2$  print queue &
                                        ""                                              ,! p3$  print option            &
                                        ""		                                ,! p4$                          &
                                        ""                                              ,! p5$                          &
                                        ""                                              ,! p6$                          &
                                        ""                                              ,! p7$                          &
                                        ""                                               ! p8$                          &
                                        )

!~~~        junk% = lib$delete_file(mail_filename$ + ";*")
	return
20000	!=======================================================================
	!	Open section
	!=======================================================================
	open_file81:								!
	when error in								!
!~~~	    %include "[.fil]PAGERDB_101_OPEN81.opn"				x open pager database
	    open ( default_node$ + pagerdb_fs$ )  as #81				&
		,access		modify							&
		,allow		modify							&
		,contiguous								&
		,organization	indexed							&
		,map		my_disk81						&
		,primary key 	(d81_recv_date,d81_recv_time)	duplicates descending 	&
		,alternate key	d81_pager   			duplicates		&
		,alternate key  d81_status  			duplicates changes 	&
		,alternate key  d81_last_name  			duplicates changes
	    !
	    file_open81% = 1%							! show open
	use									!
	    print "-e- error: "+ str$(err) +" opening pager data file"		!
	    file_open81% = 0%							! show not open
	end when								!
	!
	return									!
	!=======================================================================
	!	BASIC Error Routine
	!=======================================================================
31000	Error_Trap:								!
	print
	print "-e- BASIC Error:"
	print "-e- Error = "+ str$( Err	)
	print "-e- Line  = "+ str$( Erl	)
	PRINT "-e- Text  = "+ ERT$( Err	)
	print
	!
	resume Fini								! fix stack
	!
	!	System Error Routine (note: 'rc%' must be setup before this call)
	!
	sys_error:								!
	print 									!
	print "========================================"			!
	print "-e- System Error:"
	print "-e- SysError = "+ str$( rc%	)
	print "-e- Line     = "+ str$( sys_line	)
	print "========================================"			!
	resume	fini								!
	!
31100	Fini:									!
	end									!
	!###################################################################################################################
	!
	!	<<< external functions >>>
	!
31110   %include "[.fun]wcsm_trnlnm.fun"					!
	!
31120	%include "[.fun]WCSM_submit_to_batch.fun"				!
	!
31130	%include "[.fun]Wcsm_DT_Stamp.fun"

Back to Home
Neil Rieck
Waterloo, Ontario, Canada.