| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  | subroutine packgrid(grid,ng,text)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   parameter (NGBASE=180*180)
 | 
					
						
							|  |  |  |   character*4 grid
 | 
					
						
							| 
									
										
										
										
											2012-11-28 01:57:45 +00:00
										 |  |  |   character*1 c1
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  |   logical text
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   text=.false.
 | 
					
						
							|  |  |  |   if(grid.eq.'    ') go to 90               !Blank grid is OK
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  | ! First, handle signal reports in the original range, -01 to -30 dB
 | 
					
						
							|  |  |  |   if(grid(1:1).eq.'-') then
 | 
					
						
							|  |  |  |      read(grid(2:3),*,err=800,end=800) n
 | 
					
						
							|  |  |  |      if(n.ge.1 .and. n.le.30) then
 | 
					
						
							|  |  |  |         ng=NGBASE+1+n
 | 
					
						
							|  |  |  |         go to 900
 | 
					
						
							|  |  |  |      endif
 | 
					
						
							|  |  |  |      go to 10
 | 
					
						
							|  |  |  |   else if(grid(1:2).eq.'R-') then
 | 
					
						
							|  |  |  |      read(grid(3:4),*,err=800,end=800) n
 | 
					
						
							|  |  |  |      if(n.ge.1 .and. n.le.30) then
 | 
					
						
							|  |  |  |         ng=NGBASE+31+n
 | 
					
						
							|  |  |  |         go to 900
 | 
					
						
							|  |  |  |      endif
 | 
					
						
							|  |  |  |      go to 10
 | 
					
						
							|  |  |  | ! Now check for RO, RRR, or 73 in the message field normally used for grid
 | 
					
						
							|  |  |  |   else if(grid(1:4).eq.'RO  ') then
 | 
					
						
							|  |  |  |      ng=NGBASE+62
 | 
					
						
							|  |  |  |      go to 900
 | 
					
						
							|  |  |  |   else if(grid(1:4).eq.'RRR ') then
 | 
					
						
							|  |  |  |      ng=NGBASE+63
 | 
					
						
							|  |  |  |      go to 900
 | 
					
						
							|  |  |  |   else if(grid(1:4).eq.'73  ') then
 | 
					
						
							|  |  |  |      ng=NGBASE+64
 | 
					
						
							|  |  |  |      go to 900
 | 
					
						
							|  |  |  |   endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Now check for extended-range signal reports: -50 to -31, and 0 to +49.
 | 
					
						
							|  |  |  | 10 n=99
 | 
					
						
							| 
									
										
										
										
											2012-11-28 01:57:45 +00:00
										 |  |  |   c1=grid(1:1)
 | 
					
						
							| 
									
										
										
										
											2012-11-29 19:01:48 +00:00
										 |  |  |   read(grid,*,err=20,end=20) n
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  |   go to 30
 | 
					
						
							| 
									
										
										
										
											2012-11-29 19:01:48 +00:00
										 |  |  | 20 read(grid(2:4),*,err=30,end=30) n
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  | 30 if(n.ge.-50 .and. n.le.49) then
 | 
					
						
							| 
									
										
										
										
											2012-11-28 01:57:45 +00:00
										 |  |  |      if(c1.eq.'R') then
 | 
					
						
							|  |  |  |         write(grid,1002) n+50
 | 
					
						
							|  |  |  | 1002    format('LA',i2.2)
 | 
					
						
							|  |  |  |      else
 | 
					
						
							|  |  |  |         write(grid,1003) n+50
 | 
					
						
							|  |  |  | 1003    format('KA',i2.2)
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  |      endif
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  |      go to 40
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  |   endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  | ! Maybe it's free text ?
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  |   if(grid(1:1).lt.'A' .or. grid(1:1).gt.'R') text=.true.
 | 
					
						
							|  |  |  |   if(grid(2:2).lt.'A' .or. grid(2:2).gt.'R') text=.true.
 | 
					
						
							|  |  |  |   if(grid(3:3).lt.'0' .or. grid(3:3).gt.'9') text=.true.
 | 
					
						
							|  |  |  |   if(grid(4:4).lt.'0' .or. grid(4:4).gt.'9') text=.true.
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  |   if(text) go to 900
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  | ! OK, we have a properly formatted grid locator
 | 
					
						
							|  |  |  | 40 call grid2deg(grid//'mm',dlong,dlat)
 | 
					
						
							| 
									
										
										
										
											2013-05-23 13:33:29 +00:00
										 |  |  |   long=int(dlong)
 | 
					
						
							|  |  |  |   lat=int(dlat+ 90.0)
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  |   ng=((long+180)/2)*180 + lat
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  |   go to 900
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 90 ng=NGBASE + 1
 | 
					
						
							| 
									
										
										
										
											2012-11-28 14:33:18 +00:00
										 |  |  |   go to 900
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 800 text=.true.
 | 
					
						
							|  |  |  | 900 continue
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-28 01:57:45 +00:00
										 |  |  |   return
 | 
					
						
							| 
									
										
										
										
											2012-10-25 13:01:37 +00:00
										 |  |  | end subroutine packgrid
 |