unit.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include <strings.h>
  5. #include "pci.h"
  6. #include "pcilib.h"
  7. #include "unit.h"
  8. #include "error.h"
  9. static pcilib_unit_transform_t pcilib_unit_transform_null = { NULL, NULL };
  10. pcilib_unit_t pcilib_find_unit_by_name(pcilib_t *ctx, const char *name) {
  11. pcilib_unit_t i;
  12. for(i = 0; ctx->units[i].name; i++) {
  13. if (!strcasecmp(ctx->units[i].name, name))
  14. return i;
  15. }
  16. return PCILIB_UNIT_INVALID;
  17. }
  18. pcilib_unit_transform_t *pcilib_find_transform_by_unit_names(pcilib_t *ctx, const char *from, const char *to) {
  19. int i;
  20. pcilib_unit_t unit;
  21. if ((!from)||(!to))
  22. return NULL;
  23. if (!strcasecmp(from, to))
  24. return &pcilib_unit_transform_null;
  25. unit = pcilib_find_unit_by_name(ctx, from);
  26. if (unit == PCILIB_UNIT_INVALID) return NULL;
  27. for (i = 0; ctx->units[unit].transforms[i].unit; i++) {
  28. if (!strcasecmp(ctx->units[unit].transforms[i].unit, to))
  29. return &ctx->units[unit].transforms[i];
  30. }
  31. return NULL;
  32. }
  33. int pcilib_add_units(pcilib_t *ctx, size_t n, const pcilib_unit_description_t *desc) {
  34. if (!n) {
  35. for (n = 0; desc[n].name; n++);
  36. }
  37. if ((ctx->num_units + n + 1) > ctx->alloc_units) {
  38. size_t size;
  39. pcilib_unit_description_t *units;
  40. for (size = ctx->alloc_units; size < 2 * (n + ctx->num_units + 1); size <<= 1);
  41. units = (pcilib_unit_description_t*)realloc(ctx->units, size * sizeof(pcilib_unit_description_t));
  42. if (!units) return PCILIB_ERROR_MEMORY;
  43. ctx->units = units;
  44. ctx->alloc_units = size;
  45. ctx->model_info.units = units;
  46. }
  47. memcpy(ctx->units + ctx->num_units, desc, n * sizeof(pcilib_unit_description_t));
  48. memset(ctx->units + ctx->num_units + n, 0, sizeof(pcilib_unit_description_t));
  49. ctx->num_units += n;
  50. return 0;
  51. }
  52. int pcilib_transform_unit(pcilib_t *ctx, pcilib_unit_transform_t *trans, pcilib_value_t *value) {
  53. int err;
  54. err = pcilib_py_eval_string(ctx, trans->transform, value);
  55. if (err) return err;
  56. value->unit = trans->unit;
  57. return 0;
  58. }
  59. int pcilib_transform_unit_by_name(pcilib_t *ctx, const char *to, pcilib_value_t *value) {
  60. pcilib_unit_transform_t *trans;
  61. if (!value->unit) {
  62. pcilib_warning("Can't transform unit of the value with unspecified unit");
  63. return PCILIB_ERROR_INVALID_ARGUMENT;
  64. }
  65. trans = pcilib_find_transform_by_unit_names(ctx, value->unit, to);
  66. if (!trans) {
  67. pcilib_warning("Can't transform unit (%s) to (%s)", value->unit, to);
  68. return PCILIB_ERROR_NOTSUPPORTED;
  69. }
  70. return pcilib_transform_unit(ctx, trans, value);
  71. }