You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

84 lines
3.2KB

  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. * Unescape the given string until a non escaped terminating char,
  28. * and return 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 buf the buffer to parse, buf will be updated to point to the
  34. * terminating char
  35. * @param term a 0-terminated list of terminating chars
  36. * @return the malloced unescaped string, which must be av_freed by
  37. * the user, NULL in case of allocation failure
  38. */
  39. char *av_get_token(const char **buf, const char *term);
  40. /**
  41. * Put 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. * possibly followed by "@" and a string representing the alpha
  46. * component.
  47. * The alpha component may be a string composed by "0x" followed by an
  48. * hexadecimal number or a base-10 number between 0 and 255, or a
  49. * decimal number between 0.0 and 1.0, which represents the opacity
  50. * value (0/0x00/0.0 means completely transparent, 255/0xff/1.0
  51. * completely opaque).
  52. * If the alpha component is not specified then 255 is assumed.
  53. * The string "random" will result in a random color.
  54. * @return >= 0 in case of success, a negative value in case of
  55. * failure (for example if color_string cannot be parsed).
  56. */
  57. int av_parse_color(uint8_t *rgba_color, const char *color_string, void *log_ctx);
  58. /**
  59. * Parse the key/value pairs list in opts. For each key/value pair
  60. * found, stores the value in the field in ctx that is named like the
  61. * key. ctx must be an AVClass context, storing is done using
  62. * AVOptions.
  63. *
  64. * @param key_val_sep a 0-terminated list of characters used to
  65. * separate key from value
  66. * @param pairs_sep a 0-terminated list of characters used to separate
  67. * two pairs from each other
  68. * @return the number of successfully set key/value pairs, or a negative
  69. * value corresponding to an AVERROR code in case of error:
  70. * AVERROR(EINVAL) if opts cannot be parsed,
  71. * the error code issued by av_set_string3() if a key/value pair
  72. * cannot be set
  73. */
  74. int av_set_options_string(void *ctx, const char *opts,
  75. const char *key_val_sep, const char *pairs_sep);
  76. #endif /* AVFILTER_PARSEUTILS_H */