apc-compat.php 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. // Copyright (C) 2016-2017 Combodo SARL
  3. //
  4. // This file is part of iTop.
  5. //
  6. // iTop is free software; you can redistribute it and/or modify
  7. // it under the terms of the GNU Affero General Public License as published by
  8. // the Free Software Foundation, either version 3 of the License, or
  9. // (at your option) any later version.
  10. //
  11. // iTop is distributed in the hope that it will be useful,
  12. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. // GNU Affero General Public License for more details.
  15. //
  16. // You should have received a copy of the GNU Affero General Public License
  17. // along with iTop. If not, see <http://www.gnu.org/licenses/>
  18. // Emulate the API of APC, over APCU
  19. // Note: for PHP < 7, this compatibility used to be provided by APCU itself (if compiled with some options)
  20. // for PHP 7+, it can be provided by the mean of apcu_bc, which is not so simple to install
  21. // The current emulation aims at skipping this complexity
  22. if (!function_exists('apc_store') && function_exists('apcu_store'))
  23. {
  24. function apc_add($key, $var, $ttl = 0)
  25. {
  26. return apcu_add($key, $var, $ttl);
  27. }
  28. function apc_cache_info($cache_type = '', $limited = false)
  29. {
  30. return apcu_cache_info($limited);
  31. }
  32. function apc_cas($key, $old, $new)
  33. {
  34. return apcu_cas($key, $old, $new);
  35. }
  36. function apc_clear_cache($cache_type = '')
  37. {
  38. return apcu_clear_cache();
  39. }
  40. function apc_dec($key, $step = 1, &$success = null)
  41. {
  42. apcu_dec($key, $step, $success);
  43. }
  44. function apc_delete($key)
  45. {
  46. return apcu_delete($key);
  47. }
  48. function apc_exists($keys)
  49. {
  50. return apcu_exists($keys);
  51. }
  52. function apc_fetch($key)
  53. {
  54. return apcu_fetch($key);
  55. }
  56. function apc_inc($key, $step = 1, &$success = null)
  57. {
  58. apcu_inc($key, $step, $success);
  59. }
  60. function apc_sma_info($limited = false)
  61. {
  62. return apcu_sma_info($limited);
  63. }
  64. function apc_store($key, $var, $ttl = 0)
  65. {
  66. return apcu_store($key, $var, $ttl);
  67. }
  68. }
  69. /**
  70. * Returns user cache info... beware of the format of the returned structure that may vary (See usages)
  71. * @return array
  72. */
  73. function apc_cache_info_compat()
  74. {
  75. if (!function_exists('apc_cache_info')) return array();
  76. $oFunction = new ReflectionFunction('apc_cache_info');
  77. if ($oFunction->getNumberOfParameters() != 2)
  78. {
  79. // Beware: APCu behaves slightly differently from APC !!
  80. // Worse: the compatibility layer integrated into APC differs from apcu-bc (testing the number of parameters is a must)
  81. // In CLI mode (PHP > 7) apc_cache_info returns null and outputs an error message.
  82. $aCacheUserData = @apc_cache_info();
  83. }
  84. else
  85. {
  86. $aCacheUserData = @apc_cache_info('user');
  87. }
  88. return $aCacheUserData;
  89. }
  90. // Cache emulation
  91. if (!function_exists('apc_store'))
  92. {
  93. require_once(APPROOT.'core/apc-emulation.php');
  94. }