summaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
2015-03-13Added support for compiling the parser code with Microsoft Visual C compiler.tzickel
For hiredis-py and others support on windows.
2015-03-03Fix pkgconf file: escaping neededDominique Leuenberger
Due to the various processors going over the command, we need more escaping. 1) Make parses it, so $${libdir} becomes ${libdir} 2) 'shell' parses it for the 'echo command', whereas echo ${libdir} would be an empty string; escape it as \${libdir} to ensure we get what we want. Closes #312
2015-02-18Fix tests when assert() undefinedMatt Stancliff
Closes #309 (such as when -DNDEBUG disables all assert() macros) Inspired by keith-bennett-gbg, but re-rewritten to be more concise.
2015-02-12Fix pkgconf when used with DESTDIRMatt Stancliff
Closes #302
2015-01-26Release hiredis 0.12.1Matt Stancliff
Major fix: - `make install` now works properly Minor fix: - `make test` now works after `make 32bit` on a 64-bit platform - added more automated travis tests
2015-01-26Add more travis testsMatt Stancliff
Adds travis testing for 32bit builds as well as compile warnings on 64 bit and 32 bit builds.
2015-01-26Build test binary by defaultMatt Stancliff
This is the only way to force a 32-bit build of the test binary
2015-01-26Fix pkgconf build dependencyMatt Stancliff
We need to re-gen pkgconf when the version changes, and the version is kept in hiredis.h, so make pkgconf depend on hiredis.h.
2015-01-26Fix Makefile install problemsSebastian Wiedenroth
Adds DESTDIR support Fixes INSTALL_PKGCONF_PATH Properly copies {read,shs}.h now during make install Closes #297
2015-01-22Increase version to 0.12.0Matt Stancliff
2015-01-22Update changelog for 0.12.0Matt Stancliff
2015-01-22Add valgrind to TravisCI testingMatt Stancliff
2015-01-22Cleanup memory during testMatt Stancliff
2015-01-22Improve digit counting for multibulk creationMatt Stancliff
This replaces the old intlen() implementation with a slightly faster way of counting digits. Implementation taken from the same place where digits10() in redis/src/util.c came from. The old 'intlen' allowed negative inputs, but no usage in hiredis was passing negative numbers, so that ability is removed. Also, the new implementation can count higher (uint64_t) instead of limited to just int as before. Fixes #295 by replacing implementation
2015-01-08Use known-bad hostname when testing hostname failMatt Stancliff
Suggested at https://github.com/redis/hiredis/issues/294#issuecomment-69153074 This change also makes the test stop hanging for 10 to 30 seconds waiting for the resolver to timeout. Now the resolver immediately sees the hostname is bad and returns error without waiting for timeout.
2015-01-08Update test error message detection for dead hostsMatt Stancliff
Fixes #294
2015-01-06Silence _BSD_SOURCE warningsMatt Stancliff
glibc 2.20 requires _DEFAULT_SOURCE and doesn't like _BSD_SOURCE alone Also see: - https://github.com/antirez/redis/pull/2189 - https://sourceware.org/glibc/wiki/Release/2.20#Deprecation_of__BSD_SOURCE_and__SVID_SOURCE_feature_macros Thanks to badboy for pointing out the problem at https://github.com/redis/hiredis/issues/288#issuecomment-68849454
2015-01-05Cleanup tabs and end of line whitespaceMatt Stancliff
2015-01-05Update dependency list in MakefileMatt Stancliff
2015-01-05Build static library by defaultMatt Stancliff
2015-01-05Generate pkgconf during buildMatt Stancliff
The pkgconf source is localized to the Makefile, so we're not dropping an unnecessary "hiredis.pc.in" in the source directory. Closes #129 Closes #136
2015-01-05Fix errno error buffers to not clobber errorsMatt Stancliff
The strerror_r API has two flavors depending on system options. The bad flavor uses a static buffer for returning results, so if you save the pointer from strerror_r, the string you're referencing becomes useless if anybody else calls strerror_r again The good flavor does what you expect: it writes the error to your buffer. This commit uses strerror_r directly if it's a good version or copies the static buffer into our private buffer if it's a bad version. Thanks to gemorin for explaining the problem and drafting a fix. Fixes #239
2015-01-05Refactor reading code into read.ctzickel
Makes hiredis reading functions easier to include in external projects [fixed all merge conflicts against current version] Closes #249
2015-01-05Fix sds building with C++Matt Stancliff
These should really just be macros to shut up our type system.
2015-01-05Fix redisAppendCommand error resultMatt Stancliff
Previously, redisvAppendCommand() would return OOM even with formatting errors. Now we use OTHER with an error string telling the user the error was formatting related, not memory related. This also fixes a potentially worse bug where were would pass error result of -1 as an actual length to another function taking an unsigned length, which would result in crash/overallocation/errors. Now for that case, we just return an error immediately and stop processing the command. Fixes #177
2015-01-05Add GLib 2.0 adapterChristian Hergert
[Cleaned up Makefile and header includes. Didn't change crazy coding style because it's the convention for GLib systems.] Closes #83 Closes #71
2015-01-05Add empty pointer check in error cleanupNanXiao
If realloc fails, the curargv will be NULL. Closes #253
2015-01-05Add error check in redisContextInitNanXiao
Check whether the obuf or reader is empty: if one of the items is empty, free the redisContext.
2015-01-05Fix redisvFormatCommand format parsingNan Xiao
Flags can occur in any order in format string, so we can't assume any order. In original code, the redisvFormatCommand can process " %#+d" correctly, but can't process "%+#d". Closes #257
2015-01-05Add API to free hiredis (sds) formattingsMatt Stancliff
External callers may not know about sdsfree, so let's give them an easy way to know how to free their sds result.
2015-01-05Add API to free hiredis (char *) formattingsMareq
[Cleaned up: - name of function: freeRedis... -> redisFree... - return value of function (free doesn't return anything) - parameter type for function. - we don't need to free a char**, the char** is just for returning from the assignment functoin.] Closes #250
2015-01-05Fix build under kfreebsdChris Lamb
Signed-off-by: Chris Lamb <chris@chris-lamb.co.uk> [Instead of checking for "not solaris" we feature detect for availability of what we want, then remove the system that advertises compatability but doesn't actually provide it (given our assumptions about what we're guarding).] Closes #254
2015-01-05Fix clang analyzer warningMatt Stancliff
redisAsyncInitialize() can return NULL, but then we pass the return value from redisAsyncInitialize() into something dereferencing the return value, which can cause crashies.
2015-01-05Add support for SO_REUSEADDRmike
[This introduces some new API functions.] * Adds new flag to the connection context indicating SO_REUSEADDR should be set. * Adds max number of retries constant for when connect() hits EADDRNOTAVAIL. * Adds new function, redisAsyncConnectBindWithReuse(), letting clients enable this functionality. [Removed trailing whitespace in new header lines.] Closes #264
2015-01-05Improve calloc() correctnessjinguoli
[It doesn't _actually_ matter, but technically the order argument is: (number of items, size of items)] Closes #279
2015-01-05Cleanup libuv adaptertorque
This: - Removes misplaced libuv function prototype - Includes stdlib for free() Closes #251
2015-01-05Improve redisAppendCommandArgv performancemichael-grunder
OK, perhaps the second time is a charm. I forgot that I had hiredis forked from a long time ago, so the initial pull request was hosed. :) * Pulled in sdscatfmt() from Redis, and modified it to accept a size_t (%T) style format specifier. * Pulled in sdsll2str() and sdsull2str() from Redis (needed by sdscatfmt). * Added a new method, redisFormatSdsCommandArgv() which takes and sds* as the target, rather than char* (and uses sdscatfmt instead of sprintf for the construction). I get roughly the following improvement: Old: 1.044806 New: 0.481620 The benchmark code itself can be found here: https://gist.github.com/michael-grunder/c92ef31bb632b3d0ad81 Closes #260
2015-01-05Use stricter function argument typesHang Su
'const' where we can. Closes #268
2015-01-05Fix README typosChris Williams
Closes #267
2015-01-05Fix minor comment problemsGary Grossman
"sdscatpritf" -> "sdscatprintf" Example used sdsempty("text") but should say sdsnew("text") Closes #282
2015-01-05Fix README typoMohnish Thallavajhula
Closes #285
2015-01-05Free string if it is unusedJan-Erik Rediger
If the string is already in the dict, we need to free this. Original fix by @tt33415366. Fixes #256 Closes #286
2015-01-05Add syntax highlighting to README.mdRyan Jacobs
Closes #293
2014-09-19Merge pull request #274 from mattsta/fix-memory-leakSalvatore Sanfilippo
Fix getaddrinfo() memory leak
2014-09-18Fix getaddrinfo() memory leakMatt Stancliff
See antirez/redis#2012 for the leak causing unbounded memory growth.
2014-05-29Merge pull request #246 from dmelani/masterPieter Noordhuis
Less surprising behaviour in redisFree() and freeReplyObject()
2014-05-29Add tests for redisFree() and freeReplyObject()Daniel Melani
Test that redisFree() and freeReplyObject() do not crash when NULL is passed in.
2014-05-29Less surprising behaviour.Daniel Melani
Make redisFree() and freeReplyObject() less surprising by behaving just like free(). That is, don't crash when passing in NULL.
2014-04-09Fix HIREDIS_MINORPieter Noordhuis
Closes #219.
2014-04-09File descriptors can be 0Pieter Noordhuis