MAG7UD ;WOIFO/MLH - Imaging - HL7 - utilities - dates ; 11/15/2006 08:35
;;3.0;IMAGING;**49**;Mar 19, 2002;Build 2033;Apr 07, 2011
;; Per VHA Directive 2004-038, this routine should not be modified.
;; +---------------------------------------------------------------+
;; | Property of the US Government. |
;; | No permission to copy or redistribute this software is given. |
;; | Use of unreleased versions of this software requires the user |
;; | to execute a written test agreement with the VistA Imaging |
;; | Development Office of the Department of Veterans Affairs, |
;; | telephone (301) 734-0100. |
;; | The Food and Drug Administration classifies this software as |
;; | a medical device. As such, it may not be changed in any way. |
;; | Modifications to this software may result in an adulterated |
;; | medical device under 21CFR820, the use of which is considered |
;; | to be a violation of US Federal Statutes. |
;; +---------------------------------------------------------------+
;;
Q
;
STRIP0(XDATELOC) ; FUNCTION - strip zeros off HL7 dates
; input: XDATELOC variable containing any 8-digit HL7 date with or w/o TZ offset (+/-ZZZZ)
; function return: always 0 (success)
;
N MAGDATE ; -- working date
N OFSGN ; ---- offset sign
N TZ ; ------- time zone offset
;
; '*' for offset sign means there isn't one, but the date is valid
S MAGDATE=@XDATELOC
S OFSGN=$S(MAGDATE?1.N1"-"1.N:"-",MAGDATE?1.N1"+"1.N:"+",MAGDATE?1.N:"*",1:"")
I OFSGN="" Q ""
S TZ=$P(MAGDATE,OFSGN,2),MAGDATE=$P(MAGDATE,OFSGN,1)
I MAGDATE?6N1"00" S MAGDATE=MAGDATE/100
I MAGDATE?4N1"00" S MAGDATE=MAGDATE/100
S @XDATELOC=MAGDATE_$S(OFSGN'="*":OFSGN,1:"")_TZ
Q 0 ; success always
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMAG7UD 1840 printed Dec 13, 2024@01:59:22 Page 2
MAG7UD ;WOIFO/MLH - Imaging - HL7 - utilities - dates ; 11/15/2006 08:35
+1 ;;3.0;IMAGING;**49**;Mar 19, 2002;Build 2033;Apr 07, 2011
+2 ;; Per VHA Directive 2004-038, this routine should not be modified.
+3 ;; +---------------------------------------------------------------+
+4 ;; | Property of the US Government. |
+5 ;; | No permission to copy or redistribute this software is given. |
+6 ;; | Use of unreleased versions of this software requires the user |
+7 ;; | to execute a written test agreement with the VistA Imaging |
+8 ;; | Development Office of the Department of Veterans Affairs, |
+9 ;; | telephone (301) 734-0100. |
+10 ;; | The Food and Drug Administration classifies this software as |
+11 ;; | a medical device. As such, it may not be changed in any way. |
+12 ;; | Modifications to this software may result in an adulterated |
+13 ;; | medical device under 21CFR820, the use of which is considered |
+14 ;; | to be a violation of US Federal Statutes. |
+15 ;; +---------------------------------------------------------------+
+16 ;;
+17 QUIT
+18 ;
STRIP0(XDATELOC) ; FUNCTION - strip zeros off HL7 dates
+1 ; input: XDATELOC variable containing any 8-digit HL7 date with or w/o TZ offset (+/-ZZZZ)
+2 ; function return: always 0 (success)
+3 ;
+4 ; -- working date
NEW MAGDATE
+5 ; ---- offset sign
NEW OFSGN
+6 ; ------- time zone offset
NEW TZ
+7 ;
+8 ; '*' for offset sign means there isn't one, but the date is valid
+9 SET MAGDATE=@XDATELOC
+10 SET OFSGN=$SELECT(MAGDATE?1.N1"-"1.N:"-",MAGDATE?1.N1"+"1.N:"+",MAGDATE?1.N:"*",1:"")
+11 IF OFSGN=""
QUIT ""
+12 SET TZ=$PIECE(MAGDATE,OFSGN,2)
SET MAGDATE=$PIECE(MAGDATE,OFSGN,1)
+13 IF MAGDATE?6N1"00"
SET MAGDATE=MAGDATE/100
+14 IF MAGDATE?4N1"00"
SET MAGDATE=MAGDATE/100
+15 SET @XDATELOC=MAGDATE_$SELECT(OFSGN'="*":OFSGN,1:"")_TZ
+16 ; success always
QUIT 0