On Tue, 25 Dec 2012 07:37:34 +0000 (UTC)
Andrew Turner <and...@freebsd.org> wrote:

> Author: andrew
> Date: Tue Dec 25 07:37:33 2012
> New Revision: 244673
> URL: http://svnweb.freebsd.org/changeset/base/244673
> 
> Log:
>   Fix the __glibcxx_min and __glibcxx_max macros for a signed wchar_t.
This should say:

Fix the __glibcxx_min and __glibcxx_max macros for an unsigned wchar_t.
The left shift's in the original version cause GCC to issue a warning:
warning: left shift count >= width of type

>   
>   * The __glibcxx_max macro came from GCC svn r138078, the last GPLv2
>     revision of this file.
>   * I wrote the updated __glibcxx_min macro.
> 
> Modified:
>   head/contrib/libstdc++/include/std/std_limits.h
> 
> Modified: head/contrib/libstdc++/include/std/std_limits.h
> ==============================================================================
> --- head/contrib/libstdc++/include/std/std_limits.h   Tue Dec 25
> 07:29:25 2012 (r244672) +++
> head/contrib/libstdc++/include/std/std_limits.h       Tue Dec 25
> 07:37:33 2012 (r244673) @@ -134,10 +134,11 @@ #define
> __glibcxx_signed(T)   ((T)(-1) < 0) 
>  #define __glibcxx_min(T) \
> -  (__glibcxx_signed (T) ? (T)1 << __glibcxx_digits (T) : (T)0)
> +  (__glibcxx_signed (T) ? (((T)1 << (__glibcxx_digits (T) - 1)) <<
> 1) : (T)0) 
>  #define __glibcxx_max(T) \
> -  (__glibcxx_signed (T) ? ((T)1 << __glibcxx_digits (T)) - 1 : ~(T)0)
> +  (__glibcxx_signed (T) ? \
> +   (((((T)1 << (__glibcxx_digits (T) - 1)) - 1) << 1) + 1) : ~(T)0)
>  
>  #define __glibcxx_digits(T) \
>    (sizeof(T) * __CHAR_BIT__ - __glibcxx_signed (T))
> 
> 


_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to