1 /****************************************************************************
3 ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/
6 ** This file is part of the test suite of the Qt Toolkit.
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** GNU Lesser General Public License Usage
10 ** This file may be used under the terms of the GNU Lesser General Public
11 ** License version 2.1 as published by the Free Software Foundation and
12 ** appearing in the file LICENSE.LGPL included in the packaging of this
13 ** file. Please review the following information to ensure the GNU Lesser
14 ** General Public License version 2.1 requirements will be met:
15 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
17 ** In addition, as a special exception, Nokia gives you certain additional
18 ** rights. These rights are described in the Nokia Qt LGPL Exception
19 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
21 ** GNU General Public License Usage
22 ** Alternatively, this file may be used under the terms of the GNU General
23 ** Public License version 3.0 as published by the Free Software Foundation
24 ** and appearing in the file LICENSE.GPL included in the packaging of this
25 ** file. Please review the following information to ensure the GNU General
26 ** Public License version 3.0 requirements will be met:
27 ** http://www.gnu.org/copyleft/gpl.html.
30 ** Alternatively, this file may be used in accordance with the terms and
31 ** conditions contained in a signed written agreement between you and Nokia.
40 ****************************************************************************/
42 // This JavaScript file is a single, small, imported script.
43 // It imports many other (non-nested) single, small, scripts.
45 .import "mlbsi1.js" as Mlbsi1
46 .import "mlbsi2.js" as Mlbsi2
47 .import "mlbsi3.js" as Mlbsi3
48 .import "mlbsi4.js" as Mlbsi4
49 .import "mlbsi5.js" as Mlbsi5
50 .import "mlbsi6.js" as Mlbsi6
51 .import "mlbsi7.js" as Mlbsi7
52 .import "mlbsi8.js" as Mlbsi8
53 .import "mlbsi9.js" as Mlbsi9
54 .import "mlbsi10.js" as Mlbsi10
55 .import "mlbsi11.js" as Mlbsi11
56 .import "mlbsi12.js" as Mlbsi12
57 .import "mlbsi13.js" as Mlbsi13
58 .import "mlbsi14.js" as Mlbsi14
59 .import "mlbsi15.js" as Mlbsi15
61 function testFunc(seedValue) {
62 var firstFactor = calculateFirstFactor(seedValue);
63 var secondFactor = calculateSecondFactor(seedValue);
64 var modificationTerm = calculateModificationTerm(seedValue);
66 // do some regexp matching
67 var someString = "This is a random string which we'll perform regular expression matching on to reduce considerably. This is meant to be part of a complex javascript expression whose evaluation takes considerably longer than the creation cost of QScriptValue.";
68 var regexpPattern = new RegExp("is", "i");
69 var regexpOutputLength = 0;
70 var temp = regexpPattern.exec(someString);
71 while (temp == "is") {
72 regexpOutputLength += 4;
73 regexpOutputLength *= 2;
74 temp = regexpPattern.exec(someString);
75 if (regexpOutputLength > (seedValue * 3)) {
80 // spin in a for loop for a while
83 var cumulativeTotal = 3;
84 for (i = 20; i > 1; i--) {
85 for (j = 31; j > 5; j--) {
86 var branchVariable = i + j;
87 if (branchVariable % 3 == 0) {
88 cumulativeTotal -= secondFactor;
90 cumulativeTotal += firstFactor;
93 if (cumulativeTotal > (seedValue * 50)) {
98 var retn = cumulativeTotal * 0.53;
99 retn += Mlbsi1.testFunc(seedValue);
100 retn += Mlbsi2.testFunc(seedValue);
101 retn += Mlbsi3.testFunc(seedValue);
102 retn += Mlbsi4.testFunc(seedValue);
103 retn += Mlbsi5.testFunc(seedValue);
104 retn += Mlbsi6.testFunc(retn);
105 retn += Mlbsi7.testFunc(seedValue);
106 retn += Mlbsi8.testFunc(seedValue);
107 retn += Mlbsi9.testFunc(retn);
108 retn += Mlbsi10.testFunc(seedValue);
109 retn += Mlbsi11.testFunc(seedValue);
110 retn += Mlbsi12.testFunc(seedValue);
111 retn += Mlbsi13.testFunc(seedValue);
112 retn += Mlbsi14.testFunc(seedValue);
113 retn += Mlbsi15.testFunc(seedValue);
117 function calculateFirstFactor(seedValue) {
118 var firstFactor = (0.45 * (9.3 / 3.1) - 0.90);
119 firstFactor *= (1 + (0.000017 / seedValue));
123 function calculateSecondFactor(seedValue) {
124 var secondFactor = 0.78 * (6.3 / 2.1) - (0.39 * 4);
125 secondFactor *= (1 + (0.000017 / seedValue));
129 function calculateModificationTerm(seedValue) {
130 var modificationTerm = (12 + (9*7) - 54 + 16 - ((calculateFirstFactor(seedValue) * seedValue) / 3) + (4*calculateSecondFactor(seedValue) * seedValue * 1.33)) + (calculateSecondFactor(seedValue) * seedValue);
131 modificationTerm = modificationTerm + (33/2) + 19 - (9*2) - (61*3) + 177;
132 return modificationTerm;