mirror of https://github.com/grpc/grpc.git
commit
c866f7281f
30 changed files with 158 additions and 157 deletions
@ -1,61 +0,0 @@ |
|||||||
/*
|
|
||||||
* |
|
||||||
* Copyright 2015, Google Inc. |
|
||||||
* All rights reserved. |
|
||||||
* |
|
||||||
* Redistribution and use in source and binary forms, with or without |
|
||||||
* modification, are permitted provided that the following conditions are |
|
||||||
* met: |
|
||||||
* |
|
||||||
* * Redistributions of source code must retain the above copyright |
|
||||||
* notice, this list of conditions and the following disclaimer. |
|
||||||
* * Redistributions in binary form must reproduce the above |
|
||||||
* copyright notice, this list of conditions and the following disclaimer |
|
||||||
* in the documentation and/or other materials provided with the |
|
||||||
* distribution. |
|
||||||
* * Neither the name of Google Inc. nor the names of its |
|
||||||
* contributors may be used to endorse or promote products derived from |
|
||||||
* this software without specific prior written permission. |
|
||||||
* |
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
|
||||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
|
||||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
|
||||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
|
||||||
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
|
||||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
|
||||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
|
||||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
|
||||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
|
||||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
|
||||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|
||||||
* |
|
||||||
*/ |
|
||||||
|
|
||||||
#ifndef GRPC_INTERNAL_CORE_IOMGR_TIMER_INTERNAL_H |
|
||||||
#define GRPC_INTERNAL_CORE_IOMGR_TIMER_INTERNAL_H |
|
||||||
|
|
||||||
#include "src/core/iomgr/exec_ctx.h" |
|
||||||
#include <grpc/support/sync.h> |
|
||||||
#include <grpc/support/time.h> |
|
||||||
|
|
||||||
/* iomgr internal api for dealing with timers */ |
|
||||||
|
|
||||||
/* Check for timers to be run, and run them.
|
|
||||||
Return non zero if timer callbacks were executed. |
|
||||||
Drops drop_mu if it is non-null before executing callbacks. |
|
||||||
If next is non-null, TRY to update *next with the next running timer |
|
||||||
IF that timer occurs before *next current value. |
|
||||||
*next is never guaranteed to be updated on any given execution; however, |
|
||||||
with high probability at least one thread in the system will see an update |
|
||||||
at any time slice. */ |
|
||||||
|
|
||||||
int grpc_timer_check(grpc_exec_ctx* exec_ctx, gpr_timespec now, |
|
||||||
gpr_timespec* next); |
|
||||||
void grpc_timer_list_init(gpr_timespec now); |
|
||||||
void grpc_timer_list_shutdown(grpc_exec_ctx* exec_ctx); |
|
||||||
|
|
||||||
/* the following must be implemented by each iomgr implementation */ |
|
||||||
|
|
||||||
void grpc_kick_poller(void); |
|
||||||
|
|
||||||
#endif /* GRPC_INTERNAL_CORE_IOMGR_TIMER_INTERNAL_H */ |
|
@ -1,4 +1,22 @@ |
|||||||
Google Summer of Code 2016 gRPC Ideas |
# gRPC Summer of Code Project Ideas |
||||||
===================================== |
|
||||||
|
|
||||||
(Skeleton for now.) |
C Core: |
||||||
|
|
||||||
|
1. Port gRPC to one of (Free, Net, Open) BSD platforms and create packages for them. Add kqueue support in the process. |
||||||
|
2. Fix gRPC C-core's URI parser. The current parser does not qualify as a standard parser according to [RFC3986]( https://tools.ietf.org/html/rfc3986). Write test suites to verify this and make changes necessary to make the URI parser compliant. |
||||||
|
3. HPACK compression efficiency evaluation - Figure out how to benchmark gRPC's compression efficiency (both in terms of bytes on the wire and cpu cycles). Implement benchmarks. Potentially extend this to other standalone implementations -- Java and Go. |
||||||
|
|
||||||
|
|
||||||
|
gRPC Python: |
||||||
|
|
||||||
|
1. Evaluate the port of gRPC's Python implementation to PyPy. Investigate the state of [Cython support](http://docs.cython.org/src/userguide/pypy.html) to do this or potentially explore cffi |
||||||
|
2. Develop and test Python 3.5 Support for gRPC. Make necessary changes to port gRPC and package it for supported platforms. |
||||||
|
|
||||||
|
gRPC Ruby/Java: |
||||||
|
|
||||||
|
1. jRuby support for gRPC. Develop a jRuby wrapper for gRPC based on grpc-java and ensure that it is API compatible with the existing Ruby implementation and passes all tests. |
||||||
|
|
||||||
|
|
||||||
|
Other: |
||||||
|
|
||||||
|
1. Develop a Wireshark plugin for the gRPC protocol. Provide documentation and tutorials for this plugin. Bonus: consider set-up and use with the mobile clients. |
||||||
|
Loading…
Reference in new issue