1. 15 11月, 2014 1 次提交
    • M
      Lua: Add bitop · 1e501d9f
      Matt Stancliff 提交于
      A few people have written custom C commands because bit
      manipulation isn't exposed through Lua.  Let's give
      them Mike Pall's bitop.
      
      This adds bitop 1.0.2 (2012-05-08) from http://bitop.luajit.org/
      
      bitop is imported as "bit" into the global namespace.
      
      New Lua commands: bit.tobit, bit.tohex, bit.bnot, bit.band, bit.bor, bit.bxor,
      bit.lshift, bit.rshift, bit.arshift, bit.rol, bit.ror, bit.bswap
      
      Verification of working (the asserts would abort on error, so (nil) is correct):
      127.0.0.1:6379> eval "assert(bit.tobit(1) == 1); assert(bit.band(1) == 1); assert(bit.bxor(1,2) == 3); assert(bit.bor(1,2,4,8,16,32,64,128) == 255)" 0
      (nil)
      127.0.0.1:6379> eval 'assert(0x7fffffff == 2147483647, "broken hex literals"); assert(0xffffffff == -1 or 0xffffffff == 2^32-1, "broken hex literals"); assert(tostring(-1) == "-1", "broken tostring()"); assert(tostring(0xffffffff) == "-1" or tostring(0xffffffff) == "4294967295", "broken tostring()")' 0
      (nil)
      
      Tests also integrated into the scripting tests and can be run with:
      ./runtest --single unit/scripting
      
      Tests are excerpted from `bittest.lua` included in the bitop distribution.
      1e501d9f
  2. 06 10月, 2014 2 次提交
  3. 01 9月, 2014 1 次提交
  4. 27 8月, 2014 4 次提交
    • M
      Reject MOVE to non-integer DBs · 25a4699a
      Matt Stancliff 提交于
      Previously, "MOVE key somestring" would move the key to
      DB 0 which is just unexpected and wrong.
      String as DB == error.
      
      Test added too.
      
      Modified by @antirez in order to use the getLongLongFromObject() API
      instead of strtol().
      
      Fixes #1428
      25a4699a
    • M
      pubsub: Return integers for NUMSUB, not strings · 09a39764
      Matt Stancliff 提交于
      Also adds test for numsub — due to tcl being tcl,
      it doesn't capture the "numberness" of the fix,
      but now we at least have one test case for numsub.
      
      Closes #1561
      09a39764
    • J
      Handle large getrange requests · 07b2779b
      Jan-Erik Rediger 提交于
      Previously the end was casted to a smaller type
      which resulted in a wrong check and failed
      with values larger than handled by unsigned.
      
      Closes #1847, #1844
      07b2779b
    • M
      scripting: no eval with negative key count · 4024220f
      Matt Stancliff 提交于
      Negative key count causes segfault in Lua functions.
      
      Fixes #1842
      Closes #1843
      4024220f
  5. 22 7月, 2014 1 次提交
  6. 18 7月, 2014 2 次提交
  7. 10 7月, 2014 3 次提交
  8. 18 6月, 2014 1 次提交
  9. 16 6月, 2014 2 次提交
    • A
      Scripting: regression test for issue #1811. · 258f3cd3
      antirez 提交于
      258f3cd3
    • A
      Fix semantics of Lua calls to SELECT. · ca6b95df
      antirez 提交于
      Lua scripts are executed in the context of the currently selected
      database (as selected by the caller of the script).
      
      However Lua scripts are also free to use the SELECT command in order to
      affect other DBs. When SELECT is called frm Lua, the old behavior, before
      this commit, was to automatically set the Lua caller selected DB to the
      last DB selected by Lua. See for example the following sequence of
      commands:
      
          SELECT 0
          SET x 10
          EVAL "redis.call('select','1')" 0
          SET x 20
      
      Before this commit after the execution of this sequence of commands,
      we'll have x=10 in DB 0, and x=20 in DB 1.
      
      Because of the problem above, there was a bug affecting replication of
      Lua scripts, because of the actual implementation of replication. It was
      possible to fix the implementation of Lua scripts in order to fix the
      issue, but looking closely, the bug is the consequence of the behavior
      of Lua ability to set the caller's DB.
      
      Under the old semantics, a script selecting a different DB, has no simple
      ways to restore the state and select back the previously selected DB.
      Moreover the script auhtor must remember that the restore is needed,
      otherwise the new commands executed by the caller, will be executed in
      the context of a different DB.
      
      So this commit fixes both the replication issue, and this hard-to-use
      semantics, by removing the ability of Lua, after the script execution,
      to force the caller to switch to the DB selected by the Lua script.
      
      The new behavior of the previous sequence of commadns is to just set
      X=20 in DB 0. However Lua scripts are still capable of writing / reading
      from different DBs if needed.
      
      WARNING: This is a semantical change that will break programs that are
      conceived to select the client selected DB via Lua scripts.
      
      This fixes issue #1811.
      ca6b95df
  10. 11 6月, 2014 1 次提交
    • M
      Scripting: Fix regression from #1118 · ba76daa4
      Matt Stancliff 提交于
      The new check-for-number behavior of Lua arguments broke
      users who use large strings of just integers.
      
      The Lua number check would convert the string to a number, but
      that breaks user data because
      Lua numbers have limited precision compared to an arbitrarily
      precise number wrapped in a string.
      
      Regression fixed and new test added.
      
      Fixes #1118 again.
      ba76daa4
  11. 09 6月, 2014 1 次提交
    • M
      Fix blocking operations from missing new lists · b4f9761d
      Matt Stancliff 提交于
      Behrad Zari discovered [1] and Josiah reported [2]: if you block
      and wait for a list to exist, but the list creates from
      a non-push command, the blocked client never gets notified.
      
      This commit adds notification of blocked clients into
      the DB layer and away from individual commands.
      
      Lists can be created by [LR]PUSH, SORT..STORE, RENAME, MOVE,
      and RESTORE.  Previously, blocked client notifications were
      only triggered by [LR]PUSH.  Your client would never get
      notified if a list were created by SORT..STORE or RENAME or
      a RESTORE, etc.
      
      Blocked client notification now happens in one unified place:
        - dbAdd() triggers notification when adding a list to the DB
      
      Two new tests are added that fail prior to this commit.
      
      All test pass.
      
      Fixes #1668
      
      [1]: https://groups.google.com/forum/#!topic/redis-db/k4oWfMkN1NU
      [2]: #1668
      b4f9761d
  12. 06 6月, 2014 1 次提交
  13. 05 6月, 2014 1 次提交
  14. 22 5月, 2014 1 次提交
  15. 20 5月, 2014 1 次提交
  16. 19 5月, 2014 1 次提交
  17. 07 5月, 2014 1 次提交
    • A
      Scripting test: check that Lua can call commands rewirting argv. · 80b96bc4
      antirez 提交于
      SPOP, tested in the new test, is among the commands rewritng the
      client->argv argument vector (it gets rewritten as SREM) for command
      replication purposes.
      
      Because of recent optimizations to client->argv caching in the context
      of the Lua internal Redis client, it is important to test for SPOP to be
      callable from Lua without bad effects to the other commands.
      80b96bc4
  18. 23 4月, 2014 1 次提交
  19. 18 4月, 2014 3 次提交
  20. 17 4月, 2014 1 次提交
  21. 16 4月, 2014 3 次提交
  22. 05 3月, 2014 2 次提交
  23. 27 2月, 2014 5 次提交