Provided by: libbson-perl_1.12.2-1_all 
      
    
NAME
       BSON::Types - Helper functions to wrap BSON type classes
VERSION
       version v1.12.2
SYNOPSIS
           use BSON::Types ':all';
           $int32   = bson_int32(42);
           $double  = bson_double(3.14159);
           $decimal = bson_decimal("24.01");
           $time    = bson_time(); # now
           ...
DESCRIPTION
       This module provides helper functions for BSON type wrappers.  Type wrappers use objects corresponding to
       BSON types to represent data that would have ambiguous type or don't have a native Perl representation
       For example, because Perl scalars can represent strings, integers or floating point numbers, the
       serialization rules depend on various heuristics.  By wrapping a Perl scalar with a class, such as
       BSON::Int32, users can specify exactly how a scalar should serialize to BSON.
FUNCTIONS
   bson_bytes
           $bytes = bson_bytes( $byte_string );
           $bytes = bson_bytes( $byte_string, $subtype );
       This function returns a BSON::Bytes object wrapping the provided string.  A numeric subtype may be
       provided as a second argument, but this is not recommended for new applications.
   bson_code
           $code = bson_code( $javascript );
           $code = bson_code( $javascript, $hashref );
       This function returns a BSON::Code object wrapping the provided Javascript code.  An optional hashref
       representing variables in scope for the function may be given as well.
   bson_dbref
           $dbref = bson_dbref( $object_id, $collection_name );
       This function returns a BSON::DBRef object wrapping the provided Object ID and collection name.
   bson_decimal128
           $decimal = bson_decimal128( "0.12" );
           $decimal = bson_decimal128( "1.23456789101112131415116E-412" );
       This function returns a BSON::Decimal128 object wrapping the provided decimal string.  Unlike floating
       point values, this preserves exact decimal precision.
   bson_doc
           $doc = bson_doc( first => "hello, second => "world" );
       This function returns a BSON::Doc object, which preserves the order of the provided key-value pairs.
   bson_array
           $doc = bson_array(...);
       This function returns a BSON::Array object, which preserves the order of the provided list of elements.
   bson_double
           $double = bson_double( 1.0 );
       This function returns a BSON::Double object wrapping a native double value.  This ensures it serializes
       to BSON as a double rather than a string or integer given Perl's lax typing for scalars.
   bson_int32
           $int32 = bson_int32( 42 );
       This function returns a BSON::Int32 object wrapping a native integer value.  This ensures it serializes
       to BSON as an Int32 rather than a string or double given Perl's lax typing for scalars.
   bson_int64
           $int64 = bson_int64( 0 ); # 64-bit zero
       This function returns a BSON::Int64 object, wrapping a native integer value.  This ensures it serializes
       to BSON as an Int64 rather than a string or double given Perl's lax typing for scalars.
   bson_maxkey
           $maxkey = bson_maxkey();
       This function returns a singleton representing the "maximum key" BSON type.
   bson_minkey
           $minkey = bson_minkey();
       This function returns a singleton representing the "minimum key" BSON type.
   bson_oid
           $oid = bson_oid();         # generate a new one
           $oid = bson_oid( $bytes ); # from 12-byte packed OID
           $oid = bson_oid( $hex   ); # from 24 hex characters
       This function returns a BSON::OID object wrapping a 12-byte MongoDB Object ID.  With no arguments, a new,
       unique Object ID is generated instead.  If 24 hexadecimal characters are given, they will be packed into
       a 12-byte Object ID.
   bson_raw
           $raw = bson_raw( $bson_encoded );
       This function returns a BSON::Raw object wrapping an already BSON-encoded document.
   bson_regex
           $regex = bson_regex( $pattern );
           $regex = bson_regex( $pattern, $flags );
       This function returns a BSON::Regex object wrapping a PCRE pattern and optional flags.
   bson_string
           $string = bson_string( "08544" );
       This function returns a BSON::String object, wrapping a native string value.  This ensures it serializes
       to BSON as a UTF-8 string rather than an integer or double given Perl's lax typing for scalars.
   bson_time
           $time = bson_time( $seconds_from_epoch );
       This function returns a BSON::Time object representing a UTC date and time to millisecond precision.  The
       argument must be given as a number of seconds relative to the Unix epoch (positive or negative).  The
       number may be a floating point value for fractional seconds.  If no argument is provided, the current
       time from Time::HiRes is used.
   bson_timestamp
           $timestamp = bson_timestamp( $seconds_from_epoch, $increment );
       This function returns a BSON::Timestamp object.  It is not recommended for general use.
   bson_bool (DISCOURAGED)
           # for consistency with other helpers
           $bool = bson_bool( $expression );
           # preferred for efficiency
           use boolean;
           $bool = boolean( $expression );
       This function returns a boolean object (true or false) based on the provided expression (or false if no
       expression is provided).  It is provided for consistency so that all BSON types have a corresponding
       helper function.
       For efficiency, use "boolean::boolean()" directly, instead.
AUTHORS
       •   David Golden <david@mongodb.com>
       •   Stefan G. <minimalist@lavabit.com>
COPYRIGHT AND LICENSE
       This software is Copyright (c) 2020 by Stefan G. and MongoDB, Inc.
       This is free software, licensed under:
         The Apache License, Version 2.0, January 2004
perl v5.30.3                                       2020-08-14                                   BSON::Types(3pm)