TStringFuncFactory.php 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. /*
  3. * Licensed to the Apache Software Foundation (ASF) under one
  4. * or more contributor license agreements. See the NOTICE file
  5. * distributed with this work for additional information
  6. * regarding copyright ownership. The ASF licenses this file
  7. * to you under the Apache License, Version 2.0 (the
  8. * "License"); you may not use this file except in compliance
  9. * with the License. You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing,
  14. * software distributed under the License is distributed on an
  15. * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  16. * KIND, either express or implied. See the License for the
  17. * specific language governing permissions and limitations
  18. * under the License.
  19. *
  20. */
  21. namespace Thrift\Factory;
  22. use Thrift\StringFunc\Mbstring;
  23. use Thrift\StringFunc\Core;
  24. class TStringFuncFactory
  25. {
  26. private static $_instance;
  27. /**
  28. * Get the Singleton instance of TStringFunc implementation that is
  29. * compatible with the current system's mbstring.func_overload settings.
  30. *
  31. * @return TStringFunc
  32. */
  33. public static function create()
  34. {
  35. if (!self::$_instance) {
  36. self::_setInstance();
  37. }
  38. return self::$_instance;
  39. }
  40. private static function _setInstance()
  41. {
  42. /**
  43. * Cannot use str* functions for byte counting because multibyte
  44. * characters will be read a single bytes.
  45. *
  46. * See: http://us.php.net/manual/en/mbstring.overload.php
  47. */
  48. if (ini_get('mbstring.func_overload') & 2) {
  49. self::$_instance = new Mbstring();
  50. }
  51. /**
  52. * mbstring is not installed or does not have function overloading
  53. * of the str* functions enabled so use PHP core str* functions for
  54. * byte counting.
  55. */
  56. else {
  57. self::$_instance = new Core();
  58. }
  59. }
  60. }