Serializer.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. <?php
  2. /**
  3. * Zend Framework
  4. *
  5. * LICENSE
  6. *
  7. * This source file is subject to the new BSD license that is bundled
  8. * with this package in the file LICENSE.txt.
  9. * It is also available through the world-wide-web at this URL:
  10. * http://framework.zend.com/license/new-bsd
  11. * If you did not receive a copy of the license and are unable to
  12. * obtain it through the world-wide-web, please send an email
  13. * to license@zend.com so we can send you a copy immediately.
  14. *
  15. * @category Zend
  16. * @package Zend_Amf
  17. * @subpackage Parse
  18. * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
  19. * @license http://framework.zend.com/license/new-bsd New BSD License
  20. * @version $Id$
  21. */
  22. /**
  23. * Base abstract class for all AMF serializers.
  24. *
  25. * @package Zend_Amf
  26. * @subpackage Parse
  27. * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
  28. * @license http://framework.zend.com/license/new-bsd New BSD License
  29. */
  30. abstract class Zend_Amf_Parse_Serializer
  31. {
  32. /**
  33. * Reference to the current output stream being constructed
  34. *
  35. * @var string
  36. */
  37. protected $_stream;
  38. /**
  39. * str* functions overloaded using mbstring.func_overload
  40. *
  41. * @var bool
  42. */
  43. protected $mbStringFunctionsOverloaded;
  44. /**
  45. * Constructor
  46. *
  47. * @param Zend_Amf_Parse_OutputStream $stream
  48. * @return void
  49. */
  50. public function __construct(Zend_Amf_Parse_OutputStream $stream)
  51. {
  52. $this->_stream = $stream;
  53. $this->_mbStringFunctionsOverloaded = function_exists('mb_strlen') && (ini_get('mbstring.func_overload') !== '') && ((int)ini_get('mbstring.func_overload') & 2);
  54. }
  55. /**
  56. * Find the PHP object type and convert it into an AMF object type
  57. *
  58. * @param mixed $content
  59. * @param int $markerType
  60. * @param mixed $contentByVal
  61. * @return void
  62. */
  63. public abstract function writeTypeMarker(&$content, $markerType = null, $contentByVal = false);
  64. }