~ubuntu-branches/ubuntu/natty/pyside/natty-proposed

« back to all changes in this revision

Viewing changes to doc/codesnippets/doc/src/snippets/qelapsedtimer/main.cpp

  • Committer: Bazaar Package Importer
  • Author(s): Didier Raboud
  • Date: 2011-02-18 18:01:00 UTC
  • mfrom: (1.2.3 upstream) (6.1.6 experimental)
  • Revision ID: james.westby@ubuntu.com-20110218180100-vaczjij7g08fzfme
Tags: 1.0.0~rc1-1
* New 1.0.0~rc1 upstream release
  - Bump the B-D chain versions:
    + apiextractor to 0.10.0-2~
    + generatorrunner to 0.6.6
    + shiboken to 1.0.0~rc1
* Update patches to ~rc1.
* debian/watch: update to handle Release Candidates too.
* Bump XS-Python-Version to >= 2.6.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/****************************************************************************
 
2
**
 
3
** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
 
4
** All rights reserved.
 
5
** Contact: Nokia Corporation (qt-info@nokia.com)
 
6
**
 
7
** This file is part of the QtNetwork module of the Qt Toolkit.
 
8
**
 
9
** $QT_BEGIN_LICENSE:BSD$
 
10
** You may use this file under the terms of the BSD license as follows:
 
11
**
 
12
** "Redistribution and use in source and binary forms, with or without
 
13
** modification, are permitted provided that the following conditions are
 
14
** met:
 
15
**   * Redistributions of source code must retain the above copyright
 
16
**     notice, this list of conditions and the following disclaimer.
 
17
**   * Redistributions in binary form must reproduce the above copyright
 
18
**     notice, this list of conditions and the following disclaimer in
 
19
**     the documentation and/or other materials provided with the
 
20
**     distribution.
 
21
**   * Neither the name of Nokia Corporation and its Subsidiary(-ies) nor
 
22
**     the names of its contributors may be used to endorse or promote
 
23
**     products derived from this software without specific prior written
 
24
**     permission.
 
25
**
 
26
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 
27
** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 
28
** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 
29
** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 
30
** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 
31
** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 
32
** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 
33
** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 
34
** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
35
** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 
36
** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
 
37
** $QT_END_LICENSE$
 
38
**
 
39
****************************************************************************/
 
40
#include <QtCore>
 
41
 
 
42
void slowOperation1()
 
43
{
 
44
    static char buf[256];
 
45
    for (int i = 0; i < (1<<20); ++i)
 
46
        buf[i % sizeof buf] = i;
 
47
}
 
48
 
 
49
void slowOperation2(int) { slowOperation1(); }
 
50
 
 
51
void startExample()
 
52
{
 
53
//![0]
 
54
    timer = QElapsedTimer()
 
55
    timer.start()
 
56
 
 
57
    slowOperation1()
 
58
 
 
59
    sys.stderr.write("The slow operation took" + timer.elapsed() + "milliseconds")
 
60
//![0]
 
61
}
 
62
 
 
63
//![1]
 
64
def executeSlowOperations(timeout):
 
65
    timer = QElapsedTimer()
 
66
    timer.start()
 
67
    slowOperation1()
 
68
 
 
69
    remainingTime = timeout - timer.elapsed()
 
70
    if remainingTime > 0:
 
71
        slowOperation2(remainingTime)
 
72
//![1]
 
73
 
 
74
//![2]
 
75
def executeOperationsForTime(ms):
 
76
    timer = QElapsedTimer()
 
77
    timer.start()
 
78
 
 
79
    while not timer.hasExpired(ms):
 
80
        slowOperation1()
 
81
//![2]
 
82
 
 
83
int restartExample()
 
84
{
 
85
//![3]
 
86
    timer = QElapsedTimer()
 
87
 
 
88
    count = 1
 
89
    timer.start()
 
90
 
 
91
    while True:
 
92
        count *= 2
 
93
        slowOperation2(count)
 
94
        if timer.restart() < 250:
 
95
            break
 
96
 
 
97
    return count
 
98
//![3]
 
99
}
 
100
 
 
101
int main(int argc, char **argv)
 
102
{
 
103
    QCoreApplication app(argc, argv);
 
104
 
 
105
    startExample();
 
106
    restartExample();
 
107
    executeSlowOperations(5);
 
108
    executeOperationsForTime(5);
 
109
}