2 * This file is part of the Nice GLib ICE library.
4 * (C) 2006, 2007 Collabora Ltd.
5 * Contact: Dafydd Harries
6 * (C) 2006, 2007 Nokia Corporation. All rights reserved.
7 * Contact: Kai Vehmanen
9 * The contents of this file are subject to the Mozilla Public License Version
10 * 1.1 (the "License"); you may not use this file except in compliance with
11 * the License. You may obtain a copy of the License at
12 * http://www.mozilla.org/MPL/
14 * Software distributed under the License is distributed on an "AS IS" basis,
15 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
16 * for the specific language governing rights and limitations under the
19 * The Original Code is the Nice GLib ICE library.
21 * The Initial Developers of the Original Code are Collabora Ltd and Nokia
22 * Corporation. All Rights Reserved.
25 * Dafydd Harries, Collabora Ltd.
28 * Alternatively, the contents of this file may be used under the terms of the
29 * the GNU Lesser General Public License Version 2.1 (the "LGPL"), in which
30 * case the provisions of LGPL are applicable instead of those above. If you
31 * wish to allow use of your version of this file only under the terms of the
32 * LGPL and not to allow others to use your version of this file under the
33 * MPL, indicate your decision by deleting the provisions above and replace
34 * them with the notice and other provisions required by the LGPL. If you do
35 * not delete the provisions above, a recipient may use your version of this
36 * file under either the MPL or the LGPL.
45 #include "random-glib.h"
47 static NiceRNG
* (*nice_rng_new_func
) (void) = NULL
;
50 * Creates a new random number generator instance.
55 if (nice_rng_new_func
== NULL
)
56 return nice_rng_glib_new ();
58 return nice_rng_new_func ();
62 * Sets a new generator function.
65 nice_rng_set_new_func (NiceRNG
* (*func
) (void))
67 nice_rng_new_func
= func
;
71 * Frees the random number generator instance.
76 nice_rng_free (NiceRNG
*rng
)
82 * Generates random octets.
85 * @param len number of octets to product
86 * @param buf buffer to store the results
89 nice_rng_generate_bytes (NiceRNG
*rng
, guint len
, gchar
*buf
)
91 rng
->generate_bytes (rng
, len
, buf
);
95 * Generates a random unsigned integer.
98 * @param low closed lower bound
99 * @param high open upper bound
102 nice_rng_generate_int (NiceRNG
*rng
, guint low
, guint high
)
104 return rng
->generate_int (rng
, low
, high
);
108 * Generates a stream of octets containing only characters
109 * with ASCII codecs of 0x41-5A (A-Z), 0x61-7A (a-z),
110 * 0x30-39 (0-9), 0x2b (+) and 0x2f (/). This matches
111 * the definition of 'ice-char' in ICE Ispecification,
112 * section 15.1 (ID-16).
115 * @param len number of octets to product
116 * @param buf buffer to store the results
119 nice_rng_generate_bytes_print (NiceRNG
*rng
, guint len
, gchar
*buf
)
123 "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
124 "abcdefghijklmnopqrstuvwxyz"
128 for (i
= 0; i
< len
; i
++)
129 buf
[i
] = chars
[nice_rng_generate_int (rng
, 0, strlen (chars
))];