Open64 (mfef90, whirl2f, and IR tools)  TAG: version-openad; SVN changeset: 916
s2ul.c
Go to the documentation of this file.
00001 /*
00002 
00003   Copyright (C) 2000, 2001, Silicon Graphics, Inc.  All Rights Reserved.
00004 
00005   This program is free software; you can redistribute it and/or modify it
00006   under the terms of version 2.1 of the GNU Lesser General Public License 
00007   as published by the Free Software Foundation.
00008 
00009   This program is distributed in the hope that it would be useful, but
00010   WITHOUT ANY WARRANTY; without even the implied warranty of
00011   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  
00012 
00013   Further, this software is distributed without any warranty that it is
00014   free of the rightful claim of any third person regarding infringement 
00015   or the like.  Any license provided herein, whether implied or 
00016   otherwise, applies only to this software file.  Patent licenses, if
00017   any, provided herein do not apply to combinations of this program with 
00018   other software, or any other product whatsoever.  
00019 
00020   You should have received a copy of the GNU Lesser General Public 
00021   License along with this program; if not, write the Free Software 
00022   Foundation, Inc., 59 Temple Place - Suite 330, Boston MA 02111-1307, 
00023   USA.
00024 
00025   Contact information:  Silicon Graphics, Inc., 1600 Amphitheatre Pky,
00026   Mountain View, CA 94043, or:
00027 
00028   http://www.sgi.com
00029 
00030   For further information regarding this notice, see:
00031 
00032   http://oss.sgi.com/projects/GenInfo/NoticeExplan
00033 
00034 */
00035 
00036 
00037 
00038 #pragma ident "@(#) libf/fio/s2ul.c     92.1    06/18/99 18:41:02"
00039 #include <fortran.h>
00040 #include <cray/fmtconv.h>
00041 
00042 extern oc_func _S2UL;           /* Interface must match oc_func prototype */
00043 
00044 /*
00045  *      _S2UL() Convert Fortran logical variable to external format.
00046  *
00047  *      Entry:
00048  *              value   Address of logical variable
00049  *              fca     Address of first unpacked character
00050  *              mode    Unused
00051  *              width   Field width
00052  *              digits  Unused
00053  *              exp     Unused
00054  *              scale   Unused
00055  *
00056  *      Exit:
00057  *              result  Points to end of output field
00058  *
00059  *      Note:   This routine has the same parameters as S2UI, etc. in
00060  *              libc.
00061  */
00062 
00063 long *
00064 _S2UL(
00065 const void      *value,
00066 long            *fca,
00067 const long      *mode,
00068 const long      *width,
00069 const long      *digits,
00070 const long      *exp,
00071 const long      *scale
00072 )
00073 {
00074         int     i;
00075         long    fw, *ptr;
00076         char    ch;
00077         fw      = *width - 1;
00078 #ifdef  _F_LOG4
00079         if ((*mode & MODEHP) != 0)
00080                 ch      = _lvtob( *(_f_log4 *)value) ? 'T' : 'F';
00081         else
00082 #if     defined(_F_LOG2) && defined(__mips)
00083                 if ((*mode & MODEWP) != 0) {
00084                         ch      = _lvtob( *(_f_log2 *)value) ? 'T' : 'F';
00085         } else if ((*mode & MODEBP) != 0) {
00086                 ch      = _lvtob( *(_f_log1 *)value) ? 'T' : 'F';
00087         } else 
00088 #endif  /* _F_LOG2 and MIPS */
00089 #endif  /* _F_LOG4 */
00090         {
00091                 ch      = _lvtob( *(_f_log8 *)value) ? 'T' : 'F';
00092         }
00093 
00094         /* The following loop should vectorize */
00095 
00096         for (i = 0; i < fw; i++)
00097                 fca[i]  = (long) ' ';
00098 
00099         ptr     = fca + fw;
00100         *ptr++  = (long) ch;
00101 
00102         return (ptr);
00103 }
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines