Alex Crichton
104e285eb8
core: Get coretest working
...
This mostly involved frobbing imports between realstd, realcore, and the core
being test. Some of the imports are a little counterintuitive, but it mainly
focuses around libcore's types not implementing Show while libstd's types
implement Show.
2014-05-07 08:16:42 -07:00
Alex Crichton
be0a11729e
core: Inherit the specific numeric modules
...
This implements all traits inside of core::num for all the primitive types,
removing all the functionality from libstd. The std modules reexport all of the
necessary items from the core modules.
2014-05-07 08:15:58 -07:00
Patrick Walton
0c820d4123
libstd: Rename libcore to libstd and libstd to libextra; update makefiles.
...
This only changes the directory names; it does not change the "real"
metadata names.
2013-05-22 21:57:05 -07:00
Brian Anderson
66319b0278
Register snapshots
2013-05-19 23:34:32 -07:00
Brendan Zabarauskas
a10974da2d
Use cond! macro where appropriate
2013-05-18 17:29:07 +10:00
Brendan Zabarauskas
5696081781
Implement sin_cos method for float, f64 and f32
2013-05-17 12:30:02 +10:00
Björn Steinbrink
bdc182cc41
Use static string with fail!() and remove fail!(fmt!())
...
fail!() used to require owned strings but can handle static strings
now. Also, it can pass its arguments to fmt!() on its own, no need for
the caller to call fmt!() itself.
2013-05-14 16:36:23 +02:00
Brendan Zabarauskas
3515b4996a
Remove unnecessary infinity check
2013-05-14 11:47:44 +10:00
Brendan Zabarauskas
44cb46f7bf
Add ldexp and frexp functions
2013-05-14 11:24:55 +10:00
Brendan Zabarauskas
8d4d2b00c5
Add inverse hyperbolic functions
2013-05-14 00:11:35 +10:00
Brendan Zabarauskas
4f8084a363
Make Float::classify matching more clear for f64 and f32
2013-05-13 07:57:27 +10:00
Zack Corr
cb66d8948a
Remove #[cfg(notest)] and use #[cfg(not(test))] to cooincide with #[cfg(debug)]
2013-05-08 21:11:23 +10:00
Brendan Zabarauskas
cc51186be0
Add is_normal and classify methods to Float trait
2013-05-07 20:30:51 +10:00
Brendan Zabarauskas
a9ac2b95f4
Add abs_sub method to Signed trait
2013-05-07 19:16:03 +10:00
Brendan Zabarauskas
06c5e7f383
Implement exp_m1 and ln_1p as methods for Float
...
Both expm1 and ln1p have been renamed to exp_m1 and ln_1p in order to be consistent with the underscore usage elsewhere.
The exp_m1 method is used for increased accuracy when doing floating point calculations, so this has been moved from the more general 'Exponential' trait into 'Float'.
2013-05-07 19:16:02 +10:00
Brendan Zabarauskas
9b09dce3e1
Switch to using 'ln' for the natural logarithm and 'log' for arbitrary base logarithms
2013-05-07 19:16:02 +10:00
Brendan Zabarauskas
0e2242f6d6
Add assert_approx_eq! macro
2013-05-06 21:51:48 +10:00
Brendan Zabarauskas
0211833008
Move FuzzyEq trait into core::cmp and rename it to 'ApproxEq'
2013-05-06 21:51:07 +10:00
Brian Anderson
8081e8debf
Register snapshots
2013-05-04 15:43:51 -07:00
gifnksm
cff6aba76e
libcore: Export core::from_str::FromStr from core::prelude
2013-05-02 20:42:54 +09:00
Brendan Zabarauskas
e596128bd8
Remove 'Local Variable' comments
2013-05-02 13:22:04 +10:00
Brendan Zabarauskas
ee26c7c433
Revert rename of Div to Quot
2013-05-01 15:40:05 +10:00
Brendan Zabarauskas
500078e147
Revert "Merge Exponential and Hyperbolic traits"
...
After discussions on IRC and #4819 , we have decided to revert this change. This is due to the traits expressing different ideas and because hyperbolic functions are not trivially implementable from exponential functions for floating-point types.
2013-04-29 23:50:34 +10:00
Brendan Zabarauskas
d3f494f5c3
Merge Exponential and Hyperbolic traits
...
The Hyperbolic Functions are trivially implemented in terms of `exp`, so it's simpler to group them the Exponential trait. In the future these would have default implementations.
2013-04-29 22:15:58 +10:00
Brendan Zabarauskas
c9620dc052
Move appropriate functions out of Real and into separate Algebraic, Trigonometric, Exponential and Hyperbolic traits
2013-04-29 15:33:55 +10:00
Brendan Zabarauskas
9cdf402c80
Propagate NaNs for Orderable methods impled on floating-point primitives
2013-04-27 13:13:28 +10:00
Brendan Zabarauskas
32df8ed877
Rename nextafter
to next_after
to match method name in Float
2013-04-27 10:16:09 +10:00
Brendan Zabarauskas
4cc9d0ba7e
Add additional constants to primitive floating point numbers
...
These follow the values defined in the C99 standard
2013-04-27 09:07:40 +10:00
Brendan Zabarauskas
b7cf89f6e8
Add mul_add and next_after methods to Float
2013-04-27 01:02:30 +10:00
Brendan Zabarauskas
6cc7107aa6
Add Orderable trait
...
This is a temporary trait until we have default methods. We don't want to encumber all implementors of Ord by requiring them to implement these functions, but at the same time we want to be able to take advantage of the speed of the specific numeric functions (like the `fmin` and `fmax` intrinsics).
2013-04-27 01:01:53 +10:00
Brendan Zabarauskas
4c07f5e457
Add Int, Uint and Float traits for primitive numbers
2013-04-26 10:22:08 +10:00
Brendan Zabarauskas
b62421000c
Add Bitwise, Bounded, Primitive, and PrimitiveInt traits
2013-04-26 10:02:00 +10:00
Brendan Zabarauskas
dbc2e99693
Use ///
doc-comment form instead of /** */
2013-04-26 09:55:49 +10:00
Brendan Zabarauskas
ad0b337036
Add is_zero method to Zero
2013-04-26 05:55:26 +10:00
Brendan Zabarauskas
48c24188f9
Restore Round trait and move appropriate methods out of Real
2013-04-25 11:53:04 +10:00
Brendan Zabarauskas
dcd49ccd0b
Add Fractional, Real and RealExt traits
2013-04-25 08:20:01 +10:00
Brendan Zabarauskas
d4868ee740
Use #[cfg(not(stage0))] to exclude items from stage0
...
As requested on the mailing list: https://mail.mozilla.org/pipermail/rust-dev/2013-April/003713.html
2013-04-25 08:20:00 +10:00
Brendan Zabarauskas
03932f0b84
Move impls of Num
out of core::num and clean up imports
2013-04-25 08:20:00 +10:00
Brendan Zabarauskas
aef249056e
Implement Signed and Unsigned traits and remove related predicate functions
2013-04-24 12:46:26 +10:00
Brendan Zabarauskas
01eb5e8ad3
Rename Div operator trait to Quot and Modulo operator trait to Rem
2013-04-22 01:58:53 +10:00
Huon Wilson
d9c54f8387
librustc: use LLVM intrinsics for several floating point operations.
...
Achieves at least 5x speed up for some functions!
Also, reorganise the delegation code so that the delegated function wrappers
have the #[inline(always)] annotation, and reduce the repetition of
delegate!(..).
2013-04-21 01:40:48 +10:00
Brendan Zabarauskas
939a97f5cb
Add #[inline(always)] to each operator method
2013-04-18 23:24:24 +10:00
Brendan Zabarauskas
c4685477e0
Consolidate tests of numeric operations
2013-04-14 02:53:00 +10:00
Brendan Zabarauskas
353ce872e2
Generate NumCast impls and tests using macros
2013-04-14 01:14:02 +10:00
Huon Wilson
41c6f67109
libcore: from_str_common: provide option to ignore underscores.
...
Implement the possible improvement listed in the comment on
from_str_bytes_common.
2013-04-08 16:35:39 +10:00
Patrick Walton
1e91595520
librustc: Remove fail_unless!
2013-03-29 16:39:08 -07:00
Patrick Walton
85c9fc6f8f
librustc: Remove the const
declaration form everywhere
2013-03-22 22:24:35 -07:00
Patrick Walton
be9bddd463
libcore: Remove pure
from libcore. rs=depure
2013-03-22 10:29:17 -07:00
Patrick Walton
4634f7edae
librustc: Remove all uses of static
from functions. rs=destatic
2013-03-22 10:27:39 -07:00
Patrick Walton
d7e74b5e91
librustc: Convert all uses of assert
over to fail_unless!
2013-03-07 22:37:57 -08:00