1 /****************************************************************************
3 ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
4 ** All rights reserved.
5 ** Contact: http://www.qt-project.org/
7 ** This file is part of the test suite of the Qt Toolkit.
9 ** $QT_BEGIN_LICENSE:LGPL$
10 ** GNU Lesser General Public License Usage
11 ** This file may be used under the terms of the GNU Lesser General Public
12 ** License version 2.1 as published by the Free Software Foundation and
13 ** appearing in the file LICENSE.LGPL included in the packaging of this
14 ** file. Please review the following information to ensure the GNU Lesser
15 ** General Public License version 2.1 requirements will be met:
16 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
18 ** In addition, as a special exception, Nokia gives you certain additional
19 ** rights. These rights are described in the Nokia Qt LGPL Exception
20 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
22 ** GNU General Public License Usage
23 ** Alternatively, this file may be used under the terms of the GNU General
24 ** Public License version 3.0 as published by the Free Software Foundation
25 ** and appearing in the file LICENSE.GPL included in the packaging of this
26 ** file. Please review the following information to ensure the GNU General
27 ** Public License version 3.0 requirements will be met:
28 ** http://www.gnu.org/copyleft/gpl.html.
31 ** Alternatively, this file may be used in accordance with the terms and
32 ** 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;