about summary refs log tree commit diff
path: root/src/rt/rust_uv.cpp
AgeCommit message (Collapse)AuthorLines
2013-09-18Implement process bindings to libuvAlex Crichton-0/+35
This is a re-landing of #8645, except that the bindings are *not* being used to power std::run just yet. Instead, this adds the bindings as standalone bindings inside the rt::io::process module. I made one major change from before, having to do with how pipes are created/bound. It's much clearer now when you can read/write to a pipe, as there's an explicit difference (different types) between an unbound and a bound pipe. The process configuration now takes unbound pipes (and consumes ownership of them), and will return corresponding pipe structures back if spawning is successful (otherwise everything is destroyed normally).
2013-09-16std: bind uv_fs_readdir(), flesh out DirectoryInfo and docs/cleanupJeff Olson-0/+9
2013-09-16std: adding file::{stat,mkdir,rmdir}, FileInfo and FileReader/FileWriterJeff Olson-21/+21
add ignores for win32 tests on previous file io stuff...
2013-09-16merge cleanupJeff Olson-21/+21
2013-09-16std/rt: in-progress file io workJeff Olson-0/+42
std: remove unneeded field from RequestData struct std: rt::uv::file - map us_fs_stat & start refactoring calls into FsRequest std: stubbing out stat calls from the top-down into uvio std: us_fs_* operations are now by-val self methods on FsRequest std: post-rebase cleanup std: add uv_fs_mkdir|rmdir + tests & minor test cleanup in rt::uv::file WORKING: fleshing out FileStat and FileInfo + tests std: reverting test files.. refactoring back and cleanup...
2013-09-06Upgrade libuv to the current master (again)Alex Crichton-9/+2
This is a reopening of the libuv-upgrade part of #8645. Hopefully this won't cause random segfaults all over the place. The windows regression in testing should also be fixed (it shouldn't build the whole compiler twice). A notable difference from before is that gyp is now a git submodule instead of always git-cloned at make time. This allows bundling for releases more easily. Closes #8850
2013-09-05std::rt: Add libuv bindings for getaddrinfoBrian Anderson-0/+5
2013-08-29Revert "auto merge of #8645 : alexcrichton/rust/issue-6436-run-non-blocking, ↵Brian Anderson-36/+9
r=brson" This reverts commit b8d1fa399402c71331aefd634d710004e00b73a6, reversing changes made to f22b4b169854c8a4ba86c16ee43327d6bcf94562. Conflicts: mk/rt.mk src/libuv
2013-08-27Implement process bindings to libuvAlex Crichton-0/+34
Closes #6436
2013-08-27Upgrade libuv to the current master + our patchesAlex Crichton-9/+2
There were two main differences with the old libuv and the master version: 1. The uv_last_error function is now gone. The error code returned by each function is the "last error" so now a UvError is just a wrapper around a c_int. 2. The repo no longer includes a makefile, and the build system has change. According to the build directions on joyent/libuv, this now downloads a `gyp` program into the `libuv/build` directory and builds using that. This shouldn't add any dependences on autotools or anything like that. Closes #8407 Closes #6567 Closes #6315
2013-08-22make check appeasementJeff Olson-1/+1
2013-08-22rt: re-adding lines erroneous stripped out in merge conflictJeff Olson-0/+9
2013-08-22std: stripping unneeded fcntl.h include from rust_uv.cppJeff Olson-1/+0
2013-08-22std: remove fcntl const bindings + making valgrind clean w/ no owned vecsJeff Olson-36/+0
2013-08-22std: add read and unlink to low-level FileDescriptor + end-to-end CRUD testJeff Olson-5/+30
2013-08-22std: working tests for low-level libuv open, write and close operationsJeff Olson-4/+43
2013-08-19Instruct event loops to ignore SIGPIPE when constructed.Eric Reed-0/+9
libuv does not always catch SIGPIPE.
2013-08-16rt: Remove unused uv helpersBrian Anderson-93/+0
2013-08-09Remove the C++ runtime. SayonaraBrian Anderson-136/+0
2013-07-25libstd: Implement some missing udp methods.Luqman Aden-0/+6
2013-07-25libstd: Implement {peer, socket}_name for new rt tcp & udp.Luqman Aden-38/+22
2013-07-08Merge remote-tracking branch 'mozilla/master'Brian Anderson-1/+2
Conflicts: src/libextra/test.rs src/libstd/rt/global_heap.rs src/libstd/unstable/lang.rs src/libstd/vec.rs
2013-07-03Add x64 windows to platform.mk and mingw64 header fixes.Luqman Aden-1/+2
2013-07-02IPv6 support for UDP and TCP.Eric Reed-0/+94
2013-06-25satisfy the formatting checkEric Reed-2/+2
2013-06-14Added a utility function to extract the udp handle from udp send requests.Eric Reed-0/+5
2013-06-13Corrected libuv UDP bindings.Eric Reed-0/+37
2013-05-15core::rt: Add uv timer bindingsBrian Anderson-1/+1
2013-04-19librustc: WIP patch for using the return value.Patrick Walton-2/+1
2013-03-18core: Simplify uvll bindings and strip out currently-unused bitsBrian Anderson-0/+48
No more mapping uv structs to Rust structs
2013-03-11core: Add rt mod and add the new scheduler codeBrian Anderson-16/+25
2013-02-10rt/std: update of libuv API glue for libuv submodule updateJeff Olson-6/+6
2013-01-23std: Convert uv_global_loop to use pipesBrian Anderson-9/+0
2012-12-10Add license boilerplate to more files.Graydon Hoare-0/+10
2012-10-20uv: implement a way to get client's ip/port.Luqman Aden-0/+22
2012-06-29std: uv::ll fixes for 32bit linuxJeff Olson-2/+0
2012-06-29std/rt: cleanup and adding sockaddr_in6 mapping for win32Jeff Olson-5/+7
2012-06-29std: addressing #2656 (ipv6 support in net::tcp)Jeff Olson-15/+18
.. there are some additional FIXME nags in net_tcp (L 1012) about blocking because libuv is holding unsafe ptrs to task local data. the proposed fix going is not really feasible w/ the current design, IMO, but i'll leave it there in case someone really wants to make the case without creating more hassle than it's worth.
2012-06-29rt: get rid of unused helpers for AF_INET and add bool-based ones, insteadJeff Olson-10/+5
2012-06-29rt: whitespace cleanup in rust_uvJeff Olson-15/+15
2012-06-29rt: adding uv_freeaddrinfo binding and tweek signature for uv_getaddrinfoJeff Olson-2/+8
2012-06-29rt: more helper functions to get uv_getaddrinfo goingJeff Olson-0/+17
2012-06-29rt: more sizeof helpers + misc consts for uv_getaddrinfoJeff Olson-0/+30
2012-06-29rt: add remaining ip string parser/formatter helpers from uvJeff Olson-0/+20
2012-06-27More keyword paring and migration in runtime, docs, code modes.Graydon Hoare-23/+23
2012-05-22std: splitting out tcp server API + testsJeff Olson-2/+2
- we now have two interfaces for the TCP/IP server/listener workflow, based on different user approaches surrounding how to deal with the flow of accept a new tcp connection: 1. the "original" API closely mimics the low-level libuv API, in that we have an on_connect_cb that the user provides *that is ran on the libuv thread*. In this callback, the user can accept() a connection, turning it into a tcp_socket.. of course, before accepting, they have the option of passing it to a new task, provided they *make the cb block until the accept is done* .. this is because, in libuv, you have to do the uv_accept call in the span of that on_connect_cb callback that gets fired when a new connection comes in. thems the breaks.. I wanted to just get rid of this API, because the general proposition of users always running code on the libuv thread sounds like an invitation for many future headaches. the API restriction to have to choose to immediately accept a connection (and allow the user to block libuv as needed) isn't too bad for power users who could conceive of circumstances where they would drop an incoming TCP connection and know what they're doing, in general. but as a general API, I thought this was a bit cumbersome, so I ended up devising.. 2. an API that is initiated with a call to `net::tcp::new_listener()` .. has a similar signature to `net::tcp::listen()`, except that is just returns an object that sort of behaves like a `comm::port`. Users can block on the `tcp_conn_port` to receive new connections, either in the current task or in a new task, depending on which API route they take (`net::tcp::conn_recv` or `net::tcp::conn_recv_spawn` respectively).. there is also a `net::tcp::conn_peek` function that will do a peek on the underlying port to see if there are pending connections. The main difference, with this API, is that the low-level libuv glue is going to *accept every connection attempt*, along with the overhead that that brings. But, this is a much more hassle-free API for 95% of use cases and will probably be the one that most users will want to reach for.
2012-05-22std: splitting out tcp server API WIPJeff Olson-2/+2
2012-05-22rt: adding rust_uv_* binding for kernel malloc and free'ing :/Jeff Olson-0/+10
I need these in the context of doing various malloc/free operations for libuv structs that need to live in the heap, because of API workflow (there's no stack to put them in). This has cropped up several times when impl'ing the high-level API for things like timers, but I've decided to take the plunge and use this approach for the net::tcp module. Technically, this can be avoided by spawning a new task that contains the needed memory structures on its stack and then having it block for the duration of the time we need that memory to be valid (this is what I did in std::timer). Exposing this API provides a much lower overhead way to address the issue, albeit with safety concerns. The main mitigation policy should be to use malloc/free with libuv handles only when the handles, are then associated with a resource or class-with-dtor. So we have a finite lifetime for the object and can gaurantee a free(), barring a runtime crash (in which case you have bigger problems!)
2012-04-27rt/std: whitespace cleanup + work on hl/global_loop docsJeff Olson-1/+1
2012-04-27rt: remove unneccesary c++ functions and rust_kernel data, re: global loopJeff Olson-10/+0