File: putstr.f

package info (click to toggle)
nastran 0.1.95-2
  • links: PTS, VCS
  • area: non-free
  • in suites: bookworm, bullseye
  • size: 122,540 kB
  • sloc: fortran: 284,409; sh: 771; makefile: 324
file content (74 lines) | stat: -rw-r--r-- 2,969 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
        SUBROUTINE PUTSTR ( BLOCK )
********************************************************
*
*       FORMAT OF THE I/O MATRIX CONTROL TABLE
*
*    WORD    QUARTER            DESCRIPTION
*       1       -       GINO FILE NAME
*       2       -       TYPE OF ELEMENTS (1,2,3,4) - REFERS TO TYPE
*                       BEING WRITTEN (BLDPK--) TO THE BUFFER OR
*                       TYPE OF ELEMENTS READ (INTPK--) FROM THE BUFFER
*       3       -       TRAILERS TO BE INCLUDED (0=NO,1=YES) ON WRITE
*                       TO BUFFER OR ARE INCLUDED ON READ FROM BUFFER
*       4       -       ROW NUMBER
*       5       -       INDEX TO STRING (RELATIVE TO /XNSTRN/)
*       6       -       NUMBER OF ELEMENTS AVAIL. OR  RESIDE IN STRING
*       7       -       NUMBER OF ELEMENTS WRITTEN TO STRING BY USER
*       8       -       BEGIN/END FLAG (-1, FIRST CALL FOR COLUMN,
*                       =0, INTERMEDIATE CALL; =1, LAST CALL)
*       9       -       INTERIM FLAG FOR COLUMN ('C','P','X')
*       10      -       COUNT OF NON-ZERO WORDS PER COLUMN
*       11      -       NUMBER OF WORDS PER ELEMENT (SEE WORD 2)
*       12      -       COLUMN NUMBER
*       13      -       TYPE OF INPUT (BLDPK) OR OUTPUT (INTPK)
*       14      -       DIVISOR FOR COMPUTING BLOCK(5)
*       15      -       ROW NUMBER ON INPUT (BLDPK)
*
**********************************************************************
      INCLUDE 'DSIOF.COM'
      INCLUDE 'XNSTRN.COM'
        INTEGER BLOCK( 15 ), IDIV( 4 )
        DATA    IDIV / 1, 2, 1, 2 /
        NAME = BLOCK( 1 )
        CALL DSGEFL
        LIM  = INDBAS + NBUFF + 2
        IF ( BLOCK( 8 ) .EQ. -1 ) GO TO 10
        NWORDS = BLOCK( 11 )
        IFLG = BLOCK( 9 )
        GO TO 30
10      NWORDS = NWRDEL( BLOCK( 2 ) )
        BLOCK( 14 ) = IDIV( BLOCK( 2 ) )
        BLOCK( 11 ) = NWORDS
        BLOCK(  8 ) = 0
        BLOCK(  9 ) = IDSC
        IFLG = IDSC
        IF ( ( LIM-INDCBP-6-BLOCK(3)*2 ).GE. NWORDS ) GO TO 20
        IBASE( INDCBP ) = IDSEB
        CALL DSWRNB
        LIM  = INDBAS + NBUFF + 2
20      IBASE( INDCBP+1 ) = IDSCH +  BLOCK( 3 )*MULQ3 + BLOCK( 2 )
        IBASE( INDCBP+2 ) = BLOCK( 12 )
        INDCBP = INDCBP + 2
30      NLR = IABS( MOD( INDCBP+2, BLOCK( 14 ) ) )
        NELM = ( LIM - INDCBP - NLR - 6 - BLOCK( 3 )*2 ) / NWORDS
        IF ( NELM .GE. 1 ) GO TO 50
        IFLG = BLOCK( 9 )
        IF ( IFLG .EQ. IDSX ) GO TO 40
        IFLG = IDSP
        BLOCK( 9 ) = IDSX
40      IBASE( INDCLR ) = IDSSB + IFLG + ( INDCBP - INDCLR )
        IBASE( INDCBP + 1 ) = IDSRT + IFLG + ( INDCLR-INDBAS+1 )
        IBASE( INDCBP + 2 ) = IDSEB
        INDCLR = INDCBP + 2
        CALL DSWRNB
        LIM  = INDBAS + NBUFF + 2
        GO TO 30
50      BLOCK( 6 ) = NELM
        BLOCK( 7 ) = 0
        BLOCK( 5 ) = ( INDCBP+NLR+2 ) / BLOCK( 14 ) + 1
        IF ( NLR .EQ. 0 ) GO TO 70
        IBASE( INDCBP + 1 ) = IDSSD
        INDCBP = INDCBP + 1
70      CALL DSSDCB
        RETURN
        END