diff options
| author | Marco Paland <info@paland.com> | 2018-06-05 11:00:23 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-06-05 11:00:23 +0200 | 
| commit | aa9d7a9a5413a867ff484436edf25a65dbe9c2d0 (patch) | |
| tree | 1a1cd508faaf775eadef05899f3342a973ba985c | |
| parent | 0116b7491693306e613491b7ccc44743da6d60cb (diff) | |
| parent | d40951182f051899acf66f11d55c526003b266c8 (diff) | |
| download | printf-aa9d7a9a5413a867ff484436edf25a65dbe9c2d0.tar.gz printf-aa9d7a9a5413a867ff484436edf25a65dbe9c2d0.tar.bz2 printf-aa9d7a9a5413a867ff484436edf25a65dbe9c2d0.zip  | |
Merge pull request #18 from sgoll/fctprintf-user-data
feat(printf): add user pointer to fctprintf()
| -rw-r--r-- | README.md | 2 | ||||
| -rw-r--r-- | printf.c | 19 | ||||
| -rw-r--r-- | printf.h | 3 | 
3 files changed, 14 insertions, 10 deletions
@@ -52,7 +52,7 @@ int snprintf(char* buffer, size_t count, const char* format, ...);  int vsnprintf(char* buffer, size_t count, const char* format, va_list va);
  // call output function (instead of buffer)
 -int fctprintf(void (*out)(char character), const char* format, ...);
 +int fctprintf(void (*out)(char character, void* user), void* user, const char* format, ...);
  ```
 @@ -77,6 +77,13 @@  typedef void (*out_fct_type)(char character, char* buffer, size_t idx, size_t maxlen);
 +// wrapper used as buffer
 +typedef struct {
 +  void (*fct)(char character, void* user);
 +  void* user;
 +} out_fct_wrap_type;
 +
 +
  // internal buffer output
  static inline void _out_buffer(char character, char* buffer, size_t idx, size_t maxlen)
  {
 @@ -105,10 +112,8 @@ static inline void _out_char(char character, char* buffer, size_t idx, size_t ma  static inline void _out_fct(char character, char* buffer, size_t idx, size_t maxlen)
  {
    (void)idx; (void)maxlen;
 -  typedef struct tag_out_fct_wrap_type {
 -    void (*fct)(char character);
 -  } out_fct_wrap_type;
 -  ((out_fct_wrap_type*)buffer)->fct(character);  // buffer is the output fct pointer
 +  // buffer is the output fct pointer
 +  ((out_fct_wrap_type*)buffer)->fct(character, ((out_fct_wrap_type*)buffer)->user);
  }
 @@ -691,13 +696,11 @@ int vsnprintf(char* buffer, size_t count, const char* format, va_list va)  }
 -int fctprintf(void (*out)(char character), const char* format, ...)
 +int fctprintf(void (*out)(char character, void* user), void* user, const char* format, ...)
  {
    va_list va;
    va_start(va, format);
 -  const struct tag_out_fct_wrap {
 -    void (*fct)(char character);
 -  } out_fct_wrap = { out };
 +  const out_fct_wrap_type out_fct_wrap = { out, user };
    const int ret = _vsnprintf(_out_fct, (char*)&out_fct_wrap, (size_t)-1, format, va);
    va_end(va);
    return ret;
 @@ -84,10 +84,11 @@ int vsnprintf(char* buffer, size_t count, const char* format, va_list va);   * printf with output function
   * You may use this as dynamic alternative to printf() with its fixed _putchar() output
   * \param out An output function which takes one character
 + * \param user A pointer to user data passed to output function
   * \param format A string that specifies the format of the output
   * \return The number of characters that are sent to the output function, not counting the terminating null character
   */
 -int fctprintf(void (*out)(char character), const char* format, ...);
 +int fctprintf(void (*out)(char character, void* user), void* user, const char* format, ...);
  #ifdef __cplusplus
  | 
