Ver Fonte

Merge remote-tracking branch 'sajattack/master'

Jeremy Soller há 7 anos atrás
pai
commit
c6a31f709b
4 ficheiros alterados com 28 adições e 3 exclusões
  1. 1 0
      Cargo.lock
  2. 2 0
      src/stdio/Cargo.toml
  3. 24 3
      src/stdio/src/lib.rs
  4. 1 0
      tests/error.c

+ 1 - 0
Cargo.lock

@@ -446,6 +446,7 @@ version = "0.1.0"
 dependencies = [
  "cbindgen 0.5.0",
  "platform 0.1.0",
+ "string 0.1.0",
  "va_list 0.1.0",
 ]
 

+ 2 - 0
src/stdio/Cargo.toml

@@ -10,3 +10,5 @@ cbindgen = { path = "../../cbindgen" }
 [dependencies]
 platform = { path = "../platform" }
 va_list = { path = "../../va_list", features = ["no_std"] }
+string = { path = "../string" }
+errno = { path = "../errno"}

+ 24 - 3
src/stdio/src/lib.rs

@@ -4,10 +4,16 @@
 
 extern crate platform;
 extern crate va_list as vl;
+extern crate string;
+extern crate errno;
 
-use core::slice;
+use core::str;
+use core::fmt::Write;
 
 use platform::types::*;
+use platform::c_str;
+use platform::errno;
+use errno::STR_ERROR;
 use vl::VaList as va_list;
 
 mod printf;
@@ -203,8 +209,23 @@ pub extern "C" fn pclose(stream: *mut FILE) -> c_int {
 }
 
 #[no_mangle]
-pub extern "C" fn perror(s: *const c_char) {
-    unimplemented!();
+pub unsafe extern "C" fn perror(s: *const c_char) {
+    let mut buf: [u8; 256] = [0; 256];
+
+    let mut sw = platform::StringWriter(buf.as_mut_ptr(), buf.len());
+
+    if errno >= 0 && errno < STR_ERROR.len() as c_int {
+        sw.write_str(STR_ERROR[errno as usize]);
+    } else {
+        sw.write_fmt(format_args!("Unknown error {}", errno));
+    }
+
+    let mut w = platform::FileWriter(2);
+    w.write_fmt(format_args!(
+        "{}: {}\n",
+        str::from_utf8_unchecked(c_str(s)),
+        str::from_utf8_unchecked(c_str(buf.as_mut_ptr() as *mut c_char))
+    ));
 }
 
 #[no_mangle]

+ 1 - 0
tests/error.c

@@ -6,4 +6,5 @@
 int main(int argc, char** argv) {
     chdir("nonexistent");
     printf("errno: %d = %s\n", errno, strerror(errno));
+    perror("perror");
 }