metadata.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /*
  2. * Copyright 2016, gRPC Authors All rights reserved.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #include "internal.h"
  17. #include "cgrpc.h"
  18. #include "stdlib.h"
  19. #include "string.h"
  20. cgrpc_metadata_array *cgrpc_metadata_array_create() {
  21. cgrpc_metadata_array *metadata = (cgrpc_metadata_array *) malloc(sizeof(cgrpc_metadata_array));
  22. memset(metadata, 0, sizeof(cgrpc_metadata_array));
  23. return metadata;
  24. }
  25. void cgrpc_metadata_array_destroy(cgrpc_metadata_array *array) {
  26. grpc_metadata_array_destroy(array);
  27. }
  28. size_t cgrpc_metadata_array_get_count(cgrpc_metadata_array *array) {
  29. return array->count;
  30. }
  31. const char *cgrpc_metadata_array_copy_key_at_index(cgrpc_metadata_array *array, size_t index) {
  32. int length = GRPC_SLICE_LENGTH(array->metadata[index].key);
  33. char *str = (char *) malloc(length + 1);
  34. memcpy(str, GRPC_SLICE_START_PTR(array->metadata[index].key), length);
  35. str[length] = 0;
  36. return str;
  37. }
  38. const char *cgrpc_metadata_array_copy_value_at_index(cgrpc_metadata_array *array, size_t index) {
  39. int length = GRPC_SLICE_LENGTH(array->metadata[index].value);
  40. char *str = (char *) malloc(length + 1);
  41. memcpy(str, GRPC_SLICE_START_PTR(array->metadata[index].value), length);
  42. str[length] = 0;
  43. return str;
  44. }
  45. void cgrpc_metadata_free_copied_string(const char *string) {
  46. free(string);
  47. }
  48. int cgrpc_metadata_array_get_value_length_at_index(cgrpc_metadata_array *array, size_t index) {
  49. return GRPC_SLICE_LENGTH(array->metadata[index].value);
  50. /*
  51. int length = GRPC_SLICE_LENGTH(array->metadata[index].value);
  52. char *str = (char *) malloc(length + 1);
  53. memcpy(str, GRPC_SLICE_START_PTR(array->metadata[index].value), length);
  54. str[length] = 0;
  55. return str;
  56. */
  57. }
  58. void cgrpc_metadata_array_move_metadata(cgrpc_metadata_array *destination,
  59. cgrpc_metadata_array *source) {
  60. destination->count = source->count;
  61. destination->capacity = source->capacity;
  62. destination->metadata = source->metadata;
  63. source->count = 0;
  64. source->capacity = 0;
  65. source->metadata = NULL;
  66. }
  67. void cgrpc_metadata_array_append_metadata(cgrpc_metadata_array *metadata, const char *key, const char *value) {
  68. if (!metadata->count) {
  69. metadata->metadata = (grpc_metadata *) malloc(10 * sizeof(grpc_metadata));
  70. metadata->count = 0;
  71. metadata->capacity = 10;
  72. }
  73. if (metadata->count < metadata->capacity) {
  74. size_t i = metadata->count;
  75. metadata->metadata[i].key = grpc_slice_from_copied_string(key);
  76. metadata->metadata[i].value = grpc_slice_from_copied_string(value);
  77. metadata->count++;
  78. }
  79. }