Skip to content

Commit 78ffd6a

Browse files
committed
---
yaml --- r: 97270 b: refs/heads/dist-snap c: 03b5102 h: refs/heads/master v: v3
1 parent fa46f26 commit 78ffd6a

File tree

39 files changed

+1078
-437
lines changed

39 files changed

+1078
-437
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ refs/heads/try: c274a6888410ce3e357e014568b43310ed787d36
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
88
refs/heads/try2: 147ecfdd8221e4a4d4e090486829a06da1e0ca3c
9-
refs/heads/dist-snap: fe300870807ccd364b2f40c42c2043833c1f0783
9+
refs/heads/dist-snap: 03b510297c5c8ecd9b76ad2aa6d5a2ebcf70c13b
1010
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596
1111
refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503
1212
refs/heads/try3: 9387340aab40a73e8424c48fd42f0c521a4875c0

branches/dist-snap/.gitignore

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -75,6 +75,10 @@ src/.DS_Store
7575
/doc/latex
7676
/doc/std
7777
/doc/extra
78+
/doc/green
79+
/doc/native
80+
/doc/rustc
81+
/doc/syntax
7882
/nd/
7983
/llvm/
8084
version.md

branches/dist-snap/doc/rust.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -615,7 +615,7 @@ the behavior of the compiler.
615615
// Additional metadata attributes
616616
#[ desc = "Project X" ];
617617
#[ license = "BSD" ];
618-
#[ author = "Jane Doe" ];
618+
#[ comment = "This is a comment on Project X." ];
619619
620620
// Specify the output type
621621
#[ crate_type = "lib" ];

branches/dist-snap/src/libextra/getopts.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,7 @@
3131
//!
3232
//! ~~~{.rust}
3333
//! extern mod extra;
34-
//! use extra::getopts::*;
34+
//! use extra::getopts::{optopt,optflag,getopts,Opt};
3535
//! use std::os;
3636
//!
3737
//! fn do_work(inp: &str, out: Option<~str>) {

branches/dist-snap/src/libextra/num/rational.rs

Lines changed: 60 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@
1414
use std::cmp;
1515
use std::from_str::FromStr;
1616
use std::num::{Zero,One,ToStrRadix,FromStrRadix,Round};
17-
use super::bigint::BigInt;
17+
use super::bigint::{BigInt, BigUint, Sign, Plus, Minus};
1818

1919
/// Represents the ratio between 2 numbers.
2020
#[deriving(Clone)]
@@ -107,6 +107,27 @@ impl<T: Clone + Integer + Ord>
107107
}
108108
}
109109

110+
impl Ratio<BigInt> {
111+
/// Converts a float into a rational number
112+
pub fn from_float<T: Float>(f: T) -> Option<BigRational> {
113+
if !f.is_finite() {
114+
return None;
115+
}
116+
let (mantissa, exponent, sign) = f.integer_decode();
117+
let bigint_sign: Sign = if sign == 1 { Plus } else { Minus };
118+
if exponent < 0 {
119+
let one: BigInt = One::one();
120+
let denom: BigInt = one << ((-exponent) as uint);
121+
let numer: BigUint = FromPrimitive::from_u64(mantissa).unwrap();
122+
Some(Ratio::new(BigInt::from_biguint(bigint_sign, numer), denom))
123+
} else {
124+
let mut numer: BigUint = FromPrimitive::from_u64(mantissa).unwrap();
125+
numer = numer << (exponent as uint);
126+
Some(Ratio::from_integer(BigInt::from_biguint(bigint_sign, numer)))
127+
}
128+
}
129+
}
130+
110131
/* Comparisons */
111132

112133
// comparing a/b and c/d is the same as comparing a*d and b*c, so we
@@ -621,4 +642,42 @@ mod test {
621642
test(s);
622643
}
623644
}
645+
646+
#[test]
647+
fn test_from_float() {
648+
fn test<T: Float>(given: T, (numer, denom): (&str, &str)) {
649+
let ratio: BigRational = Ratio::from_float(given).unwrap();
650+
assert_eq!(ratio, Ratio::new(
651+
FromStr::from_str(numer).unwrap(),
652+
FromStr::from_str(denom).unwrap()));
653+
}
654+
655+
// f32
656+
test(3.14159265359f32, ("13176795", "4194304"));
657+
test(2f32.pow(&100.), ("1267650600228229401496703205376", "1"));
658+
test(-2f32.pow(&100.), ("-1267650600228229401496703205376", "1"));
659+
test(1.0 / 2f32.pow(&100.), ("1", "1267650600228229401496703205376"));
660+
test(684729.48391f32, ("1369459", "2"));
661+
test(-8573.5918555f32, ("-4389679", "512"));
662+
663+
// f64
664+
test(3.14159265359f64, ("3537118876014453", "1125899906842624"));
665+
test(2f64.pow(&100.), ("1267650600228229401496703205376", "1"));
666+
test(-2f64.pow(&100.), ("-1267650600228229401496703205376", "1"));
667+
test(684729.48391f64, ("367611342500051", "536870912"));
668+
test(-8573.5918555, ("-4713381968463931", "549755813888"));
669+
test(1.0 / 2f64.pow(&100.), ("1", "1267650600228229401496703205376"));
670+
}
671+
672+
#[test]
673+
fn test_from_float_fail() {
674+
use std::{f32, f64};
675+
676+
assert_eq!(Ratio::from_float(f32::NAN), None);
677+
assert_eq!(Ratio::from_float(f32::INFINITY), None);
678+
assert_eq!(Ratio::from_float(f32::NEG_INFINITY), None);
679+
assert_eq!(Ratio::from_float(f64::NAN), None);
680+
assert_eq!(Ratio::from_float(f64::INFINITY), None);
681+
assert_eq!(Ratio::from_float(f64::NEG_INFINITY), None);
682+
}
624683
}

branches/dist-snap/src/libextra/time.rs

Lines changed: 96 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -12,17 +12,16 @@
1212

1313
use std::io::Reader;
1414
use std::io::mem::BufReader;
15+
use std::libc;
1516
use std::num;
1617
use std::str;
1718

1819
static NSEC_PER_SEC: i32 = 1_000_000_000_i32;
1920

20-
pub mod rustrt {
21+
mod rustrt {
2122
use super::Tm;
2223

2324
extern {
24-
pub fn rust_get_time(sec: &mut i64, nsec: &mut i32);
25-
pub fn rust_precise_time_ns(ns: &mut u64);
2625
pub fn rust_tzset();
2726
pub fn rust_gmtime(sec: i64, nsec: i32, result: &mut Tm);
2827
pub fn rust_localtime(sec: i64, nsec: i32, result: &mut Tm);
@@ -31,6 +30,31 @@ pub mod rustrt {
3130
}
3231
}
3332

33+
#[cfg(unix, not(target_os = "macos"))]
34+
mod imp {
35+
use std::libc::{c_int, timespec};
36+
37+
// Apparently android provides this in some other library?
38+
#[cfg(not(target_os = "android"))]
39+
#[link(name = "rt")]
40+
extern {}
41+
42+
extern {
43+
pub fn clock_gettime(clk_id: c_int, tp: *mut timespec) -> c_int;
44+
}
45+
46+
}
47+
#[cfg(target_os = "macos")]
48+
mod imp {
49+
use std::libc::{timeval, timezone, c_int, mach_timebase_info};
50+
51+
extern {
52+
pub fn gettimeofday(tp: *mut timeval, tzp: *mut timezone) -> c_int;
53+
pub fn mach_absolute_time() -> u64;
54+
pub fn mach_timebase_info(info: *mut mach_timebase_info) -> c_int;
55+
}
56+
}
57+
3458
/// A record specifying a time value in seconds and nanoseconds.
3559
3660

@@ -64,11 +88,45 @@ impl Ord for Timespec {
6488
*/
6589
pub fn get_time() -> Timespec {
6690
unsafe {
67-
let mut sec = 0i64;
68-
let mut nsec = 0i32;
69-
rustrt::rust_get_time(&mut sec, &mut nsec);
91+
let (sec, nsec) = os_get_time();
7092
return Timespec::new(sec, nsec);
7193
}
94+
95+
#[cfg(windows)]
96+
unsafe fn os_get_time() -> (i64, i32) {
97+
static NANOSECONDS_FROM_1601_TO_1970: u64 = 11644473600000000;
98+
99+
let mut time = libc::FILETIME {
100+
dwLowDateTime: 0,
101+
dwHighDateTime: 0,
102+
};
103+
libc::GetSystemTimeAsFileTime(&mut time);
104+
105+
// A FILETIME contains a 64-bit value representing the number of
106+
// hectonanosecond (100-nanosecond) intervals since 1601-01-01T00:00:00Z.
107+
// http://support.microsoft.com/kb/167296/en-us
108+
let ns_since_1601 = ((time.dwHighDateTime as u64 << 32) |
109+
(time.dwLowDateTime as u64 << 0)) / 10;
110+
let ns_since_1970 = ns_since_1601 - NANOSECONDS_FROM_1601_TO_1970;
111+
112+
((ns_since_1970 / 1000000) as i64,
113+
((ns_since_1970 % 1000000) * 1000) as i32)
114+
}
115+
116+
#[cfg(target_os = "macos")]
117+
unsafe fn os_get_time() -> (i64, i32) {
118+
use std::ptr;
119+
let mut tv = libc::timeval { tv_sec: 0, tv_usec: 0 };
120+
imp::gettimeofday(&mut tv, ptr::mut_null());
121+
(tv.tv_sec as i64, tv.tv_usec * 1000)
122+
}
123+
124+
#[cfg(not(target_os = "macos"), not(windows))]
125+
unsafe fn os_get_time() -> (i64, i32) {
126+
let mut tv = libc::timespec { tv_sec: 0, tv_nsec: 0 };
127+
imp::clock_gettime(libc::CLOCK_REALTIME, &mut tv);
128+
(tv.tv_sec as i64, tv.tv_nsec as i32)
129+
}
72130
}
73131

74132

@@ -77,10 +135,38 @@ pub fn get_time() -> Timespec {
77135
* in nanoseconds since an unspecified epoch.
78136
*/
79137
pub fn precise_time_ns() -> u64 {
80-
unsafe {
81-
let mut ns = 0u64;
82-
rustrt::rust_precise_time_ns(&mut ns);
83-
ns
138+
return os_precise_time_ns();
139+
140+
#[cfg(windows)]
141+
fn os_precise_time_ns() -> u64 {
142+
let mut ticks_per_s = 0;
143+
assert_eq!(unsafe {
144+
libc::QueryPerformanceFrequency(&mut ticks_per_s)
145+
}, 1);
146+
let ticks_per_s = if ticks_per_s == 0 {1} else {ticks_per_s};
147+
let mut ticks = 0;
148+
assert_eq!(unsafe {
149+
libc::QueryPerformanceCounter(&mut ticks)
150+
}, 1);
151+
152+
return (ticks as u64 * 1000000000) / (ticks_per_s as u64);
153+
}
154+
155+
#[cfg(target_os = "macos")]
156+
fn os_precise_time_ns() -> u64 {
157+
let time = unsafe { imp::mach_absolute_time() };
158+
let mut info = libc::mach_timebase_info { numer: 0, denom: 0 };
159+
unsafe { imp::mach_timebase_info(&mut info); }
160+
return time * ((info.numer / info.denom) as u64);
161+
}
162+
163+
#[cfg(not(windows), not(target_os = "macos"))]
164+
fn os_precise_time_ns() -> u64 {
165+
let mut ts = libc::timespec { tv_sec: 0, tv_nsec: 0 };
166+
unsafe {
167+
imp::clock_gettime(libc::CLOCK_MONOTONIC, &mut ts);
168+
}
169+
return (ts.tv_sec as u64) * 1000000000 + (ts.tv_nsec as u64)
84170
}
85171
}
86172

branches/dist-snap/src/libnative/io/mod.rs

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -166,8 +166,8 @@ impl rtio::IoFactory for IoFactory {
166166
fn tcp_bind(&mut self, addr: SocketAddr) -> IoResult<~RtioTcpListener> {
167167
net::TcpListener::bind(addr).map(|s| ~s as ~RtioTcpListener)
168168
}
169-
fn udp_bind(&mut self, _addr: SocketAddr) -> IoResult<~RtioUdpSocket> {
170-
Err(unimpl())
169+
fn udp_bind(&mut self, addr: SocketAddr) -> IoResult<~RtioUdpSocket> {
170+
net::UdpSocket::bind(addr).map(|u| ~u as ~RtioUdpSocket)
171171
}
172172
fn unix_bind(&mut self, _path: &CString) -> IoResult<~RtioUnixListener> {
173173
Err(unimpl())

0 commit comments

Comments
 (0)