<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>