2 * This file is part of the Nice GLib ICE library.
4 * (C) 2006-2008 Collabora Ltd.
5 * Contact: Dafydd Harries
6 * (C) 2006-2008 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.
26 * Youness Alaoui, Collabora Ltd.
29 * Alternatively, the contents of this file may be used under the terms of the
30 * the GNU Lesser General Public License Version 2.1 (the "LGPL"), in which
31 * case the provisions of LGPL are applicable instead of those above. If you
32 * wish to allow use of your version of this file only under the terms of the
33 * LGPL and not to allow others to use your version of this file under the
34 * MPL, indicate your decision by deleting the provisions above and replace
35 * them with the notice and other provisions required by the LGPL. If you do
36 * not delete the provisions above, a recipient may use your version of this
37 * file under either the MPL or the LGPL.
46 #include "random-glib.h"
48 static NiceRNG
* (*nice_rng_new_func
) (void) = NULL
;
51 * Creates a new random number generator instance.
56 if (nice_rng_new_func
== NULL
)
57 return nice_rng_glib_new ();
59 return nice_rng_new_func ();
63 * Sets a new generator function.
66 nice_rng_set_new_func (NiceRNG
* (*func
) (void))
68 nice_rng_new_func
= func
;
72 * Frees the random number generator instance.
77 nice_rng_free (NiceRNG
*rng
)
83 * Generates random octets.
86 * @param len number of octets to product
87 * @param buf buffer to store the results
90 nice_rng_generate_bytes (NiceRNG
*rng
, guint len
, gchar
*buf
)
92 rng
->generate_bytes (rng
, len
, buf
);
96 * Generates a random unsigned integer.
99 * @param low closed lower bound
100 * @param high open upper bound
103 nice_rng_generate_int (NiceRNG
*rng
, guint low
, guint high
)
105 return rng
->generate_int (rng
, low
, high
);
109 * Generates a stream of octets containing only characters
110 * with ASCII codecs of 0x41-5A (A-Z), 0x61-7A (a-z),
111 * 0x30-39 (0-9), 0x2b (+) and 0x2f (/). This matches
112 * the definition of 'ice-char' in ICE Ispecification,
113 * section 15.1 (ID-16).
116 * @param len number of octets to product
117 * @param buf buffer to store the results
120 nice_rng_generate_bytes_print (NiceRNG
*rng
, guint len
, gchar
*buf
)
124 "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
125 "abcdefghijklmnopqrstuvwxyz"
129 for (i
= 0; i
< len
; i
++)
130 buf
[i
] = chars
[nice_rng_generate_int (rng
, 0, strlen (chars
))];