utils.lua 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. -------------------------------------------------------------------------------
  2. -- Spine Runtimes Software License
  3. -- Version 2.1
  4. --
  5. -- Copyright (c) 2013, Esoteric Software
  6. -- All rights reserved.
  7. --
  8. -- You are granted a perpetual, non-exclusive, non-sublicensable and
  9. -- non-transferable license to install, execute and perform the Spine Runtimes
  10. -- Software (the "Software") solely for internal use. Without the written
  11. -- permission of Esoteric Software (typically granted by licensing Spine), you
  12. -- may not (a) modify, translate, adapt or otherwise create derivative works,
  13. -- improvements of the Software or develop new applications using the Software
  14. -- or (b) remove, delete, alter or obscure any trademarks or any copyright,
  15. -- trademark, patent or other intellectual property or proprietary rights
  16. -- notices on or in the Software, including any copy thereof. Redistributions
  17. -- in binary or source form must include this license and terms.
  18. --
  19. -- THIS SOFTWARE IS PROVIDED BY ESOTERIC SOFTWARE "AS IS" AND ANY EXPRESS OR
  20. -- IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  21. -- MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
  22. -- EVENT SHALL ESOTERIC SOFTARE BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  23. -- SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  24. -- PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
  25. -- OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  26. -- WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
  27. -- OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  28. -- ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. -------------------------------------------------------------------------------
  30. local utils = {}
  31. function tablePrint (tt, indent, done)
  32. done = done or {}
  33. for key, value in pairs(tt) do
  34. local spaces = string.rep (" ", indent)
  35. if type(value) == "table" and not done [value] then
  36. done [value] = true
  37. print(spaces .. "{")
  38. utils.print(value, indent + 2, done)
  39. print(spaces .. "}")
  40. else
  41. io.write(spaces .. tostring(key) .. " = ")
  42. utils.print(value, indent + 2, done)
  43. end
  44. end
  45. end
  46. function utils.print (value, indent, done)
  47. indent = indent or 0
  48. if "nil" == type(value) then
  49. print(tostring(nil))
  50. elseif "table" == type(value) then
  51. local spaces = string.rep (" ", indent)
  52. print(spaces .. "{")
  53. tablePrint(value, indent + 2)
  54. print(spaces .. "}")
  55. elseif "string" == type(value) then
  56. print("\"" .. value .. "\"")
  57. else
  58. print(tostring(value))
  59. end
  60. end
  61. function utils.indexOf (haystack, needle)
  62. for i,value in ipairs(haystack) do
  63. if value == needle then return i end
  64. end
  65. return nil
  66. end
  67. function utils.copy (from, to)
  68. if not to then to = {} end
  69. for k,v in pairs(from) do
  70. to[k] = v
  71. end
  72. return to
  73. end
  74. return utils