Figure 1 illustrates these values:
PROC STORGRP
SELECT(&ANYVOL)
WHEN('REF=SD')
IF &DSTYPE = 'TEMP' & &&DSORG ^= 'VS' THEN
SET &STORGRP = 'VIOSG','MAIN3380','MAIN3390','SPIL3380','SPIL3390'
ELSE
SET &STORGRP = 'MAIN3380','MAIN3390','SPIL3380','SPIL3390'
WHEN('REF=ST')
SET &STORGRP = &STORGRP
OTHERWISE
.
.
.
END
END
Figure 2 illustrates these values:
PROC 0 STORCLAS
FILTLIST AUTH_USER INCLUDE('SYSPROG1','SYSPROG2','STGADMIN','SYSADMIN')
IF &ANYVOL = 'REF=NS' & &HLQ ^= 'SYS1' THEN
IF &USER ^= &AUTH_USER THEN
DO
WRITE 'INVALID USE OF VOL=REF TO A NON-SMS-MANAGED DATA SET'
WRITE 'AS OF 12/31/04 ALLOCATION WILL BE FAILED FOR ' &DSN
END
.
.
.
END
As of the date shown in Figure 2, you might change the ACS routine to fail the uses of VOL=REF that are not valid, as shown in Figure 3.
PROC 1 STORCLAS
FILTLIST AUTH_USER INCLUDE('SYSPROG1','SYSPROG2','STGADMIN','SYSADMIN')
IF &ANYVOL = 'REF=NS' & &HLQ ^= 'SYS1' THEN
IF &USER ^= &AUTH_USER THEN
DO
WRITE 'INVALID USE OF VOL=REF TO A NON-SMS-MANAGED DATA SET'
WRITE 'DATA SET ' &DSN ' MUST BE SMS-MANAGED'
EXIT CODE(4)
END
.
.
.
END