a978a6d2f750de915f39d3f4bdc9ff1fcf136b9a
[platform/framework/web/wrt-commons.git] / examples / binary_queue / binary_queue.cpp
1 /*
2  * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  *    Licensed under the Apache License, Version 2.0 (the "License");
5  *    you may not use this file except in compliance with the License.
6  *    You may obtain a copy of the License at
7  *
8  *        http://www.apache.org/licenses/LICENSE-2.0
9  *
10  *    Unless required by applicable law or agreed to in writing, software
11  *    distributed under the License is distributed on an "AS IS" BASIS,
12  *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  *    See the License for the specific language governing permissions and
14  *    limitations under the License.
15  */
16 /*
17  * @file        binary_queue.cpp
18  * @author      Przemyslaw Dobrowolski (p.dobrowolsk@samsung.com)
19  * @version     1.0
20  * @brief       This file is the implementation file of binary queue example
21  */
22 #include <dpl/binary_queue.h>
23 #include <dpl/exception.h>
24 #include <dpl/log/log.h>
25 #include <dpl/assert.h>
26
27 int main(int argc, char *argv[])
28 {
29     (void)argc;
30     (void)argv;
31
32     DPL::BinaryQueue queue;
33     Assert(queue.Size() == 0);
34
35     for (int i=0; i<10; ++i)
36     {
37         int value = 12345;
38         queue.AppendCopy(&value, sizeof(value));
39         queue.AppendUnmanaged(malloc(100), 100);
40     }
41
42     Assert(queue.Size() == 10 * sizeof(int) + 10 * 100);
43
44     for (size_t i = 0; i < 10 * sizeof(int) + 10 * 100; ++i)
45     {
46         char buffer[1];
47         queue.Flatten(buffer, 1);
48
49         queue.FlattenConsume(NULL, 0);
50         queue.Flatten(NULL, 0);
51         queue.FlattenConsume(buffer, 1);
52     }
53
54 //    UNHANDLED_EXCEPTION_HANDLER_BEGIN
55 //    {
56 //        char a;
57 //        queue.FlattenConsume(&a, sizeof(a));
58 //    }
59 //    UNHANDLED_EXCEPTION_HANDLER_END
60
61     return 0;
62 }