mirror of
https://github.com/unclechu/gRPC-haskell.git
synced 2024-12-24 18:59:44 +01:00
Don’t free op array values in op_array_destroy (#98)
These values are all already freed in freeOpContext and doing it twice is an error, see #91
This commit is contained in:
parent
3defd1dcc5
commit
4164623844
2 changed files with 2 additions and 31 deletions
|
@ -210,33 +210,8 @@ void op_array_destroy(grpc_op* op_array, size_t n){
|
|||
#ifdef GRPC_HASKELL_DEBUG
|
||||
printf("C wrapper: entered op_array_destroy\n");
|
||||
#endif
|
||||
for(int i = 0; i < n; i++){
|
||||
grpc_op* op = op_array + i;
|
||||
switch (op->op) {
|
||||
case GRPC_OP_SEND_INITIAL_METADATA:
|
||||
metadata_free(op->data.send_initial_metadata.metadata);
|
||||
break;
|
||||
case GRPC_OP_SEND_MESSAGE:
|
||||
grpc_byte_buffer_destroy(op->data.send_message.send_message);
|
||||
break;
|
||||
case GRPC_OP_SEND_CLOSE_FROM_CLIENT:
|
||||
break;
|
||||
case GRPC_OP_SEND_STATUS_FROM_SERVER:
|
||||
grpc_haskell_free("op_array_destroy: GRPC_OP_SEND_STATUS_FROM_SERVER",
|
||||
op->data.send_status_from_server.trailing_metadata);
|
||||
grpc_haskell_free("op_array_destroy: GRPC_OP_SEND_STATUS_FROM_SERVER",
|
||||
(char*)(op->data.send_status_from_server.status_details));
|
||||
break;
|
||||
case GRPC_OP_RECV_INITIAL_METADATA:
|
||||
break;
|
||||
case GRPC_OP_RECV_MESSAGE:
|
||||
break;
|
||||
case GRPC_OP_RECV_STATUS_ON_CLIENT:
|
||||
break;
|
||||
case GRPC_OP_RECV_CLOSE_ON_SERVER:
|
||||
break;
|
||||
}
|
||||
}
|
||||
// This only destroys the array, the values in the array
|
||||
// are freed in freeOpContext
|
||||
grpc_haskell_free("op_array_destroy", op_array);
|
||||
}
|
||||
|
||||
|
|
|
@ -47,10 +47,6 @@ deriving instance Show OpArray
|
|||
-- | Destroys an 'OpArray' of the given size.
|
||||
{#fun unsafe op_array_destroy as ^ {`OpArray', `Int'} -> `()'#}
|
||||
|
||||
-- | brackets creating and destroying an 'OpArray' with the given size.
|
||||
withOpArray :: Int -> (OpArray -> IO a) -> IO a
|
||||
withOpArray n f = bracket (opArrayCreate n) (flip opArrayDestroy n) f
|
||||
|
||||
-- | Creates an op of type GRPC_OP_SEND_INITIAL_METADATA at the specified
|
||||
-- index of the given 'OpArray', containing the given
|
||||
-- metadata. The metadata is copied and can be destroyed after calling this
|
||||
|
|
Loading…
Reference in a new issue