Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

47 lines
1.4 KiB

C Copyright(C) 1999-2020 National Technology & Engineering Solutions
C of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
C NTESS, the U.S. Government retains certain rights in this software.
C
C See packages/seacas/LICENSE for details
SUBROUTINE MXLOOK (MNGET, VOID, LVOID, NVOIDS, VROW, LASTER)
IMPLICIT INTEGER (A-Z)
INCLUDE 'params.inc'
C This routine looks for space in the void table.
C***********************************************************************
C MNGET Amount of space requested.
C VOID Void table.
C LVOID Dimension of void table.
C NVOIDS Number of voids.
DIMENSION VOID(LVOID,2)
C VROW Row number that contains void to satisfy space request.
C LASTER Error return.
C***********************************************************************
C CHECK TO SEE IF A VOID WILL CONTAIN THE MEMORY REQUEST.
VROW = 0
VLEN = 0
DO 100 I = 1, NVOIDS
IF (VOID(I,2) .GE. MNGET) THEN
C THIS VOID HAS ENOUGH ROOM - FIND THE SMALLEST VOID THAT
C IS LARGE ENOUGH.
IF (VLEN .EQ. 0 .OR. VOID(I,2) .LT. VLEN) THEN
VROW = I
VLEN = VOID(I,2)
END IF
END IF
100 CONTINUE
IF (VROW .NE. 0) THEN
LASTER = SUCCESS
ELSE
LASTER = NOGET
END IF
RETURN
END