Skip to content

Commit

Permalink
Change README to Markdown
Browse files Browse the repository at this point in the history
  • Loading branch information
pietern committed Oct 11, 2010
1 parent 3dfacba commit 8b8b7af
Showing 1 changed file with 21 additions and 21 deletions.
42 changes: 21 additions & 21 deletions README → README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,17 @@ at the same time it uses an high level printf-alike API in order to make it
much higher level than otherwise suggested by its minimal code base and the
lack of explicit bindings for every Redis command.

Hiredis only supports the Redis new protocol, so you can use it with any
Hiredis only supports the new Redis protocol, so you can use it with any
Redis version >= 1.2.0.

HIREDIS API
-----------

Hiredis exports only three function calls:

redisReply *redisConnect(int *fd, char *ip, int port);
redisReply *redisCommand(int fd, char *format, ...);
void freeReplyObject(redisReply *r);
redisReply *redisConnect(int *fd, char *ip, int port);
redisReply *redisCommand(int fd, char *format, ...);
void freeReplyObject(redisReply *r);

The first function is used in order to create a connection to the Redis server:

Expand All @@ -37,18 +37,18 @@ is not NULL:
}

When a reply object returns an error, the reply->type is set to the value
REDIS_REPLY_ERROR, and reply->reply points to a C string with the description
`REDIS_REPLY_ERROR`, and reply->reply points to a C string with the description
of the error.

In the above example we don't check for reply->type as redisConnect() can
only return NULL or a reply object that is actually an error.
In the above example we don't check for reply->type as `redisConnect()` can
only return `NULL` or a reply object that is actually an error.

As you can see redisConnect() will just set (by reference) the fd variable
As you can see `redisConnect()` will just set (by reference) the `fd` variable
to the file descriptor of the open socket connected to our Redis server.

Calls to redisCommand() will require this file descriptor as first argument.
Calls to `redisCommand()` will require this file descriptor as first argument.

SENDING COMMNADS
SENDING COMMANDS
----------------

Commands are sent using a printf-alike format. In the simplest form it is
Expand All @@ -61,7 +61,7 @@ printf-alike fashion:

reply = redisComand("SET foo %s", somevalue);

If your arguments are binary safe, you can use %b that receives the pointer
If your arguments are binary safe, you can use "%b" that receives the pointer
to the buffer and a size_t integer with the length of the buffer.

reply = redisCommand("SET %s %b", "foo", somevalue, somevalue_length);
Expand All @@ -76,35 +76,35 @@ The following example is valid:
USING REPLIES
-------------

redisCommand() returns a reply object. In order to use this object you
`redisCommand()` returns a reply object. In order to use this object you
need to test the reply->type field, that can be one of the following types:

REDIS_REPLY_ERROR
* `REDIS_REPLY_ERROR`:
The command returned an error string, that can be read accessing to
the reply->reply field.

REDIS_REPLY_STRING
* `REDIS_REPLY_STRING`:
The command returned a string, that can be read accessing to the
reply->reply field. The string is always nul-termined, but when you
reply->reply field. The string is always null-terminated, but when you
need to work with binary-safe strings you can obtain the exact length
of the reply with: sdslen(reply->reply).
of the reply with: `sdslen(reply->reply)`.

REDIS_REPLY_ARRAY
* `REDIS_REPLY_ARRAY`:
The command returned an array of reply->elements elements.
Every element is a redisReply object, stored at redis->element[..index..]
Redis may reply with nexted arrays but this is fully supported.
Redis may reply with nested arrays but this is fully supported.

REDIS_REPLY_INTEGER
* `REDIS_REPLY_INTEGER`:
The command replies with an integer. It's possible to access this integer
using the reply->integer field that is of type "long long".

REDIS_REPLY_NIL
* `REDIS_REPLY_NIL`:
The command replies with a NIL special object. There is no data to access.

FREEING REPLIES
---------------

Replies should be freed using the freeReplyObject() function.
Replies should be freed using the `freeReplyObject()` function.
Note that this function will take care of freeing sub-replies objects
contained in arrays and nested arrays, so there is no need for the user to
free the sub replies (it is actually harmful and will corrupt the memory).
Expand Down

0 comments on commit 8b8b7af

Please sign in to comment.