<pre style='margin:0'>
Chris Jones (cjones051073) pushed a commit to branch fls
in repository macports-legacy-support.

</pre>
<p><a href="https://github.com/macports/macports-legacy-support/commit/2a659220423c2d1e98d9db48eee6edf38d72cc72">https://github.com/macports/macports-legacy-support/commit/2a659220423c2d1e98d9db48eee6edf38d72cc72</a></p>
<pre style="white-space: pre; background: #F8F8F8"><span style='display:block; white-space:pre;color:#808000;'>commit 2a659220423c2d1e98d9db48eee6edf38d72cc72
</span>Author: Chris Jones <jonesc@hep.phy.cam.ac.uk>
AuthorDate: Tue May 26 16:26:14 2020 +0100

<span style='display:block; white-space:pre;color:#404040;'>    Add support for fls, flsl and flsll
</span>---
 README.md                         |  2 +-
 include/MacportsLegacySupport.h   | 13 ++++++++---
 include/strings.h                 | 27 +++++++++++++++++++---
 src/strings.c                     | 47 ++++++++++++++++++++++++++++++++++++---
 test/test_ffsl.c                  | 11 +++++++--
 test/{test_ffsl.c => test_flsl.c} | 19 +++++++++++-----
 6 files changed, 101 insertions(+), 18 deletions(-)

<span style='display:block; white-space:pre;color:#808080;'>diff --git a/README.md b/README.md
</span><span style='display:block; white-space:pre;color:#808080;'>index c92c7c1..51f6a7d 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/README.md
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/README.md
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -69,7 +69,7 @@ Wrapped headers are:
</span>   </tr>
   <tr>
     <td><code>strings.h</code></td>
<span style='display:block; white-space:pre;background:#ffe0e0;'>-    <td>Adds <code>ffsl</code>(OSX10.4) and <code>ffsll</code>(macOS10.8) functions</td>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    <td>Adds <code>fls,flsl,ffsl</code>(OSX10.4) and <code>flsll,ffsll</code>(macOS10.8) functions</td>
</span>     <td>OSX10.4(8)</td>
   </tr>
   <tr>
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/include/MacportsLegacySupport.h b/include/MacportsLegacySupport.h
</span><span style='display:block; white-space:pre;color:#808080;'>index 0a582aa..fc7c370 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/include/MacportsLegacySupport.h
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/include/MacportsLegacySupport.h
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -119,10 +119,17 @@
</span> /* cossin */
 #define __MP_LEGACY_SUPPORT_COSSIN__  (__APPLE__ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1090)
 
<span style='display:block; white-space:pre;background:#e0ffe0;'>+/* ffsl */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#define __MP_LEGACY_SUPPORT_FFSL__    (__APPLE__ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1050)
</span> /* ffsll */
<span style='display:block; white-space:pre;background:#ffe0e0;'>-#define __MP_LEGACY_SUPPORT_FFSLL__           (__APPLE__ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1090)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#define __MP_LEGACY_SUPPORT_FFSLL__   (__APPLE__ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1090)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+/* fls */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#define __MP_LEGACY_SUPPORT_FLS__     (__APPLE__ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1050)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+/* flsl */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#define __MP_LEGACY_SUPPORT_FLSL__    (__APPLE__ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1050)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+/* flsll */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#define __MP_LEGACY_SUPPORT_FLSLL__   (__APPLE__ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1090)
</span> 
<span style='display:block; white-space:pre;background:#ffe0e0;'>-/* ffsl */
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-#define __MP_LEGACY_SUPPORT_FFSL__            (__APPLE__ && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1050)
</span> 
 #endif /* _MACPORTS_LEGACYSUPPORTDEFS_H_ */
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/include/strings.h b/include/strings.h
</span><span style='display:block; white-space:pre;color:#808080;'>index 932c4dc..667ed3d 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/include/strings.h
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/include/strings.h
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -24,6 +24,13 @@
</span> /* Include the primary system string.h */
 #include_next <strings.h>
 
<span style='display:block; white-space:pre;background:#e0ffe0;'>+/* ffsl */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#if __MP_LEGACY_SUPPORT_FFSL__
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+__MP__BEGIN_DECLS
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+extern int ffsl(long int);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+__MP__END_DECLS
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#endif
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span> /* ffsll */
 #if __MP_LEGACY_SUPPORT_FFSLL__
 __MP__BEGIN_DECLS
<span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -31,10 +38,24 @@ extern int ffsll(long long int);
</span> __MP__END_DECLS
 #endif
 
<span style='display:block; white-space:pre;background:#ffe0e0;'>-/* ffsl */
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-#if __MP_LEGACY_SUPPORT_FFSL__
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+/* fls */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#if __MP_LEGACY_SUPPORT_FLS__
</span> __MP__BEGIN_DECLS
<span style='display:block; white-space:pre;background:#ffe0e0;'>-extern int ffsl(long int);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+extern int fls(int);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+__MP__END_DECLS
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#endif
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+/* flsl */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#if __MP_LEGACY_SUPPORT_FLSL__
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+__MP__BEGIN_DECLS
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+extern int flsl(long int);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+__MP__END_DECLS
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#endif
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+/* flsll */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#if __MP_LEGACY_SUPPORT_FLSLL__
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+__MP__BEGIN_DECLS
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+extern int flsll(long long int);
</span> __MP__END_DECLS
 #endif
 
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/src/strings.c b/src/strings.c
</span><span style='display:block; white-space:pre;color:#808080;'>index 3aacbdb..ff408a9 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/src/strings.c
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/src/strings.c
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -1,5 +1,7 @@
</span> 
 /*-
<span style='display:block; white-space:pre;background:#e0ffe0;'>+ * SPDX-License-Identifier: BSD-3-Clause
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ *
</span>  * Copyright (c) 1990, 1993
  *     The Regents of the University of California.  All rights reserved.
  *
<span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -31,6 +33,19 @@
</span> // MP support header
 #include "MacportsLegacySupport.h"
 
<span style='display:block; white-space:pre;background:#e0ffe0;'>+#if __MP_LEGACY_SUPPORT_FFSL__
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+int ffsl(long mask)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+{
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  int bit = 0;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  if (mask != 0) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    for (bit = 1; !(mask & 1); bit++) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+      mask = (unsigned long)mask >> 1;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  return (bit);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#endif
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span> #if __MP_LEGACY_SUPPORT_FFSLL__
 int ffsll(long long mask)
 {
<span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -44,15 +59,41 @@ int ffsll(long long mask)
</span> }
 #endif
 
<span style='display:block; white-space:pre;background:#ffe0e0;'>-#if __MP_LEGACY_SUPPORT_FFSL__
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-int ffsl(long mask)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#if __MP_LEGACY_SUPPORT_FLS__
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+int fls(int mask)
</span> {
   int bit = 0;
   if (mask != 0) {
<span style='display:block; white-space:pre;background:#ffe0e0;'>-    for (bit = 1; !(mask & 1); bit++) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    for (bit = 1; mask != 1; bit++) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+      mask = (unsigned int)mask >> 1;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  return (bit);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#endif
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#if __MP_LEGACY_SUPPORT_FLSL__
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+int flsl(long mask)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+{
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  int bit = 0;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  if (mask != 0) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    for (bit = 1; mask != 1; bit++) {
</span>       mask = (unsigned long)mask >> 1;
     }
   }
   return (bit);
 }
 #endif
<span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#if __MP_LEGACY_SUPPORT_FLSLL__
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+int flsll(long long mask)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+{
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  int bit = 0;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  if (mask != 0) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    for (bit = 1; mask != 1; bit++) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+      mask = (unsigned long long)mask >> 1;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  return (bit);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#endif
</span><span style='display:block; white-space:pre;color:#808080;'>diff --git a/test/test_ffsl.c b/test/test_ffsl.c
</span><span style='display:block; white-space:pre;color:#808080;'>index 4c0a16a..934c319 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/test/test_ffsl.c
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/test/test_ffsl.c
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -21,14 +21,21 @@
</span> int main() {
 
   printf( "testing ffsl :-\n" );
<span style='display:block; white-space:pre;background:#ffe0e0;'>-  for ( int i = 0; i <= 32; ++i ) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  for ( int i = 0; i <= 8*sizeof(int); i+=4 ) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    const long int test = ( i>0 ? 1UL << (i-1) : 0);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    const int j = ffs(test);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    printf( "  Set bit %i - Found bit %i\n", i, j );
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  printf( "testing ffsl :-\n" );
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  for ( int i = 0; i <= 8*sizeof(long int); i+=4 ) {
</span>     const long int test = ( i>0 ? 1UL << (i-1) : 0);
     const int j = ffsl(test);
     printf( "  Set bit %i - Found bit %i\n", i, j );
   }
 
   printf( "testing ffsll :-\n" );
<span style='display:block; white-space:pre;background:#ffe0e0;'>-  for ( int i = 0; i <= 64; ++i ) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  for ( int i = 0; i <= 8*sizeof(long long int); i+=4 ) {
</span>     const long long int test = ( i>0 ? 1UL << (i-1) : 0 );
     const int j = ffsll(test);
     printf( "  Set bit %i - Found bit %i\n", i, j );
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/test/test_ffsl.c b/test/test_flsl.c
</span>similarity index 70%
copy from test/test_ffsl.c
copy to test/test_flsl.c
<span style='display:block; white-space:pre;color:#808080;'>index 4c0a16a..9f1f01a 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/test/test_ffsl.c
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/test/test_flsl.c
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -20,17 +20,24 @@
</span> 
 int main() {
 
<span style='display:block; white-space:pre;background:#ffe0e0;'>-  printf( "testing ffsl :-\n" );
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-  for ( int i = 0; i <= 32; ++i ) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  printf( "testing fls :-\n" );
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  for ( int i = 0; i <= 8*sizeof(int); i+=4 ) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    const int test = ( i>0 ? 1UL << (i-1) : 0);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    const int j = fls(test);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    printf( "  Set bit %i - Found bit %i\n", i, j );
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  printf( "testing flsl :-\n" );
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  for ( int i = 0; i <= 8*sizeof(long int); i+=4 ) {
</span>     const long int test = ( i>0 ? 1UL << (i-1) : 0);
<span style='display:block; white-space:pre;background:#ffe0e0;'>-    const int j = ffsl(test);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    const int j = flsl(test);
</span>     printf( "  Set bit %i - Found bit %i\n", i, j );
   }
 
<span style='display:block; white-space:pre;background:#ffe0e0;'>-  printf( "testing ffsll :-\n" );
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-  for ( int i = 0; i <= 64; ++i ) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  printf( "testing flsll :-\n" );
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+  for ( int i = 0; i <= 8*sizeof(long long int); i+=4 ) {
</span>     const long long int test = ( i>0 ? 1UL << (i-1) : 0 );
<span style='display:block; white-space:pre;background:#ffe0e0;'>-    const int j = ffsll(test);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    const int j = flsll(test);
</span>     printf( "  Set bit %i - Found bit %i\n", i, j );
   }
   
</pre><pre style='margin:0'>

</pre>