parseutils.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*
  2. * copyright (c) 2009 Stefano Sabatini
  3. * This file is part of FFmpeg.
  4. *
  5. * FFmpeg is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU Lesser General Public
  7. * License as published by the Free Software Foundation; either
  8. * version 2.1 of the License, or (at your option) any later version.
  9. *
  10. * FFmpeg is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  13. * Lesser General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU Lesser General Public
  16. * License along with FFmpeg; if not, write to the Free Software
  17. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  18. */
  19. /**
  20. * @file
  21. * parsing utils
  22. */
  23. #ifndef AVFILTER_PARSEUTILS_H
  24. #define AVFILTER_PARSEUTILS_H
  25. #include "libavcodec/opt.h"
  26. /**
  27. * Unescapes the given string until a non escaped terminating char,
  28. * and returns the token corresponding to the unescaped string.
  29. *
  30. * The normal \ and ' escaping is supported. Leading and trailing
  31. * whitespaces are removed.
  32. *
  33. * @param term a 0-terminated list of terminating chars
  34. * @param buf the buffer to parse, buf will be updated to point to the
  35. * terminating char
  36. * @return the malloced unescaped string, which must be av_freed by
  37. * the user
  38. */
  39. char *av_get_token(const char **buf, const char *term);
  40. /**
  41. * Puts the RGBA values that correspond to color_string in rgba_color.
  42. *
  43. * @param color_string a string specifying a color. It can be the name of
  44. * a color (case insensitive match) or a 0xRRGGBB[AA] sequence.
  45. * The string "random" will result in a random color.
  46. * @return >= 0 in case of success, a negative value in case of
  47. * failure (for example if color_string cannot be parsed).
  48. */
  49. int av_parse_color(uint8_t *rgba_color, const char *color_string, void *log_ctx);
  50. /**
  51. * Parses the key/value pairs list in opts. For each key/value pair
  52. * found, stores the value in the field in ctx that is named like the
  53. * key. ctx must be an AVClass context, storing is done using
  54. * AVOptions.
  55. *
  56. * @param key_val_sep a 0-terminated list of characters used to
  57. * separate key from value
  58. * @param pairs_sep a 0-terminated list of characters used to separate
  59. * two pairs from each other
  60. * @return the number of successfully set key/value pairs, or a negative
  61. * value corresponding to an AVERROR code in case of error:
  62. * AVERROR(EINVAL) if opts cannot be parsed,
  63. * the error code issued by av_set_string3() if a key/value pair
  64. * cannot be set
  65. */
  66. int av_set_options_string(void *ctx, const char *opts,
  67. const char *key_val_sep, const char *pairs_sep);
  68. #endif /* AVFILTER_PARSEUTILS_H */