[PATCH 1/2]vbscript: Implemented builtin function CInt(try 3)

Jacek Caban jacek at codeweavers.com
Fri Apr 26 03:27:09 CDT 2013


Hi Zhan,

It's better, thanks, but still needs more work.

On 04/25/13 23:37, Zhan Jianyu wrote:
>  }
>  
> +
> +

While we're at this, please put more attention into whitespace changes,
esp. useless ones.

>  static HRESULT to_double(VARIANT *v, double *ret)
>  {
>      switch(V_VT(v)) {
> @@ -217,6 +221,27 @@ static HRESULT to_string(VARIANT *v, BSTR *ret)
>      return S_OK;
>  }
>  
> +
> +static HRESULT banker_rounding(double dbval, int *result_val)
> +{
> +     double frac_part;
> +     double int_part; 
> +
> +     *result_val = round(dbval);

This has two problems:
- you don't handle values that are out of int range by assigning double
value to int
- round is not portable. As I mentioned you before, Wine needs to be C89
compatible. If we need some features that are not part of C89, we need
to be careful about that and it often requires things like configure
checks. In case of round, replacing it with floor(x+0.5) does the trick
pretty well.

Cheers,
Jacek



More information about the wine-devel mailing list