summaryrefslogtreecommitdiff
path: root/SRC/lsamen.f
diff options
context:
space:
mode:
Diffstat (limited to 'SRC/lsamen.f')
-rw-r--r--SRC/lsamen.f67
1 files changed, 67 insertions, 0 deletions
diff --git a/SRC/lsamen.f b/SRC/lsamen.f
new file mode 100644
index 00000000..d64dc0e0
--- /dev/null
+++ b/SRC/lsamen.f
@@ -0,0 +1,67 @@
+ LOGICAL FUNCTION LSAMEN( N, CA, CB )
+*
+* -- LAPACK auxiliary routine (version 3.1) --
+* Univ. of Tennessee, Univ. of California Berkeley and NAG Ltd..
+* November 2006
+*
+* .. Scalar Arguments ..
+ CHARACTER*( * ) CA, CB
+ INTEGER N
+* ..
+*
+* Purpose
+* =======
+*
+* LSAMEN tests if the first N letters of CA are the same as the
+* first N letters of CB, regardless of case.
+* LSAMEN returns .TRUE. if CA and CB are equivalent except for case
+* and .FALSE. otherwise. LSAMEN also returns .FALSE. if LEN( CA )
+* or LEN( CB ) is less than N.
+*
+* Arguments
+* =========
+*
+* N (input) INTEGER
+* The number of characters in CA and CB to be compared.
+*
+* CA (input) CHARACTER*(*)
+* CB (input) CHARACTER*(*)
+* CA and CB specify two character strings of length at least N.
+* Only the first N characters of each string will be accessed.
+*
+* =====================================================================
+*
+* .. Local Scalars ..
+ INTEGER I
+* ..
+* .. External Functions ..
+ LOGICAL LSAME
+ EXTERNAL LSAME
+* ..
+* .. Intrinsic Functions ..
+ INTRINSIC LEN
+* ..
+* .. Executable Statements ..
+*
+ LSAMEN = .FALSE.
+ IF( LEN( CA ).LT.N .OR. LEN( CB ).LT.N )
+ $ GO TO 20
+*
+* Do for each character in the two strings.
+*
+ DO 10 I = 1, N
+*
+* Test if the characters are equal using LSAME.
+*
+ IF( .NOT.LSAME( CA( I: I ), CB( I: I ) ) )
+ $ GO TO 20
+*
+ 10 CONTINUE
+ LSAMEN = .TRUE.
+*
+ 20 CONTINUE
+ RETURN
+*
+* End of LSAMEN
+*
+ END