working further on Marc2017 compatibility
This commit is contained in:
parent
3a448ccb7d
commit
2c4df2f070
26
src/mesh.f90
26
src/mesh.f90
|
@ -75,8 +75,9 @@ module mesh
|
||||||
integer(pInt), private :: &
|
integer(pInt), private :: &
|
||||||
MarcVersion, & !< Version of input file format (Marc only)
|
MarcVersion, & !< Version of input file format (Marc only)
|
||||||
hypoelasticTableStyle, & !< Table style (Marc only)
|
hypoelasticTableStyle, & !< Table style (Marc only)
|
||||||
initialcondTableStyle, & !< Table style (Marc only)
|
initialcondTableStyle !< Table style (Marc only)
|
||||||
Marc_matNumber !< Material number of hypoelastic material (Marc only)
|
integer(pInt), dimension(:), allocatable, private :: &
|
||||||
|
Marc_matNumber !< array of material numbers for hypoelastic material (Marc only)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
integer(pInt), dimension(2), private :: &
|
integer(pInt), dimension(2), private :: &
|
||||||
|
@ -1612,7 +1613,7 @@ subroutine mesh_marc_get_tableStyles(fileUnit)
|
||||||
620 end subroutine mesh_marc_get_tableStyles
|
620 end subroutine mesh_marc_get_tableStyles
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief Figures out material number of hypoelastic material and sores it as Marc_matNumber
|
!> @brief Figures out material number of hypoelastic material and stores it in Marc_matNumber array
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine mesh_marc_get_matNumber(fileUnit)
|
subroutine mesh_marc_get_matNumber(fileUnit)
|
||||||
use IO, only: &
|
use IO, only: &
|
||||||
|
@ -1625,21 +1626,31 @@ subroutine mesh_marc_get_matNumber(fileUnit)
|
||||||
integer(pInt), intent(in) :: fileUnit
|
integer(pInt), intent(in) :: fileUnit
|
||||||
|
|
||||||
integer(pInt), allocatable, dimension(:) :: chunkPos
|
integer(pInt), allocatable, dimension(:) :: chunkPos
|
||||||
integer(pInt) :: i
|
integer(pInt) :: i, j, data_blocks
|
||||||
character(len=300) line
|
character(len=300) line
|
||||||
|
|
||||||
610 FORMAT(A300)
|
610 FORMAT(A300)
|
||||||
|
|
||||||
rewind(fileUnit)
|
rewind(fileUnit)
|
||||||
|
|
||||||
|
data_blocks = 1_pInt
|
||||||
do
|
do
|
||||||
read (fileUnit,610,END=620) line
|
read (fileUnit,610,END=620) line
|
||||||
chunkPos = IO_stringPos(line)
|
chunkPos = IO_stringPos(line)
|
||||||
if ( IO_lc(IO_stringValue(line,chunkPos,1_pInt)) == 'hypoelastic') then
|
if ( IO_lc(IO_stringValue(line,chunkPos,1_pInt)) == 'hypoelastic') then
|
||||||
do i=1_pInt,1_pInt+hypoelasticTableStyle ! Skip 1 or 2 lines
|
read (fileUnit,610,END=620) line
|
||||||
|
if (len(trim(line))/=0_pInt) then
|
||||||
|
chunkPos = IO_stringPos(line)
|
||||||
|
data_blocks = IO_intValue(line,chunkPos,1_pInt)
|
||||||
|
endif
|
||||||
|
do i=1_pInt,data_blocks ! read all data blocks
|
||||||
read (fileUnit,610,END=620) line
|
read (fileUnit,610,END=620) line
|
||||||
|
chunkPos = IO_stringPos(line)
|
||||||
|
Marc_matNumber = (/Marc_matNumber, IO_intValue(line,chunkPos,1_pInt)/)
|
||||||
|
do j=1_pint,2_pInt + hypoelasticTableStyle ! read 2 or 3 remaining lines of data block
|
||||||
|
read (fileUnit,610,END=620) line
|
||||||
|
enddo
|
||||||
enddo
|
enddo
|
||||||
Marc_matNumber = IO_intValue(line,chunkPos,1_pInt)
|
|
||||||
exit
|
exit
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
|
@ -1810,9 +1821,8 @@ subroutine mesh_marc_count_cpElements(fileUnit)
|
||||||
if ( IO_lc(IO_stringValue(line,chunkPos,1_pInt)) == 'connectivity') then
|
if ( IO_lc(IO_stringValue(line,chunkPos,1_pInt)) == 'connectivity') then
|
||||||
read (fileUnit,610,END=620) line
|
read (fileUnit,610,END=620) line
|
||||||
chunkPos = IO_stringPos(line)
|
chunkPos = IO_stringPos(line)
|
||||||
if (IO_intValue(line,chunkPos,6_pInt)==Marc_matNumber) then
|
if (any(Marc_matNumber==IO_intValue(line,chunkPos,6_pInt))) then
|
||||||
mesh_NcpElems = mesh_NcpElems + IO_countNumericalDataLines(fileUnit)
|
mesh_NcpElems = mesh_NcpElems + IO_countNumericalDataLines(fileUnit)
|
||||||
exit
|
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
|
|
Loading…
Reference in New Issue