VirtualBox

source: vbox/trunk/src/libs/xpcom18a4/xpcom/tests/TestAtoms.cpp@ 102345

Last change on this file since 102345 was 102345, checked in by vboxsync, 14 months ago

libs/xpcom: Replace remaining APIs from prprf.h with IPRT equivalents, bugref:10545

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.2 KB
Line 
1/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2/* ***** BEGIN LICENSE BLOCK *****
3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
4 *
5 * The contents of this file are subject to the Mozilla Public License Version
6 * 1.1 (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 * http://www.mozilla.org/MPL/
9 *
10 * Software distributed under the License is distributed on an "AS IS" basis,
11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12 * for the specific language governing rights and limitations under the
13 * License.
14 *
15 * The Original Code is mozilla.org code.
16 *
17 * The Initial Developer of the Original Code is
18 * Netscape Communications Corporation.
19 * Portions created by the Initial Developer are Copyright (C) 1998
20 * the Initial Developer. All Rights Reserved.
21 *
22 * Contributor(s):
23 *
24 * Alternatively, the contents of this file may be used under the terms of
25 * either of the GNU General Public License Version 2 or later (the "GPL"),
26 * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27 * in which case the provisions of the GPL or the LGPL are applicable instead
28 * of those above. If you wish to allow use of your version of this file only
29 * under the terms of either the GPL or the LGPL, and not to allow others to
30 * use your version of this file under the terms of the MPL, indicate your
31 * decision by deleting the provisions above and replace them with the notice
32 * and other provisions required by the GPL or the LGPL. If you do not delete
33 * the provisions above, a recipient may use your version of this file under
34 * the terms of any one of the MPL, the GPL or the LGPL.
35 *
36 * ***** END LICENSE BLOCK ***** */
37#include "nsIAtom.h"
38#include "nsString.h"
39#include "nsReadableUtils.h"
40#include "prtime.h"
41#include <stdio.h>
42
43#include <iprt/string.h>
44
45extern "C" int _CrtSetDbgFlag(int);
46
47int main(int argc, char** argv)
48{
49 FILE* fp = fopen("words.txt", "r");
50 if (nsnull == fp) {
51 printf("can't open words.txt\n");
52 return -1;
53 }
54
55 PRInt32 count = 0;
56 PRUnichar** strings = new PRUnichar*[60000];
57 nsIAtom** ids = new nsIAtom*[60000];
58 nsAutoString s1, s2;
59 PRTime start = PR_Now();
60 PRInt32 i;
61 for (i = 0; i < 30000; i++) {
62 char buf[1000];
63 char* s = fgets(buf, sizeof(buf), fp);
64 if (nsnull == s) {
65 break;
66 }
67 nsCAutoString sb;
68 sb.Assign(buf);
69 strings[count++] = ToNewUnicode(sb);
70 ToUpperCase(sb);
71 strings[count++] = ToNewUnicode(sb);
72 }
73 PRTime end0 = PR_Now();
74
75 // Find and create idents
76 for (i = 0; i < count; i++) {
77 ids[i] = NS_NewAtom(strings[i]);
78 }
79 PRUnichar qqs[1]; qqs[0] = 0;
80 nsIAtom* qq = NS_NewAtom(qqs);
81 PRTime end1 = PR_Now();
82
83 // Now make sure we can find all the idents we just made
84 for (i = 0; i < count; i++) {
85 const char *utf8String;
86 ids[i]->GetUTF8String(&utf8String);
87 nsIAtom* id = NS_NewAtom(utf8String);
88 if (id != ids[i]) {
89 id->ToString(s1);
90 ids[i]->ToString(s2);
91 printf("find failed: id='%s' ids[%d]='%s'\n",
92 NS_LossyConvertUCS2toASCII(s1).get(), i, NS_LossyConvertUCS2toASCII(s2).get());
93 return -1;
94 }
95 NS_RELEASE(id);
96 }
97 PRTime end2 = PR_Now();
98
99 // Destroy all the atoms we just made
100 NS_RELEASE(qq);
101 for (i = 0; i < count; i++) {
102 NS_RELEASE(ids[i]);
103 }
104
105 // Print out timings
106 PRTime end3 = PR_Now();
107 PRTime creates, finds, lookups, dtor, ustoms;
108 LL_I2L(ustoms, 1000);
109 LL_SUB(creates, end0, start);
110 LL_DIV(creates, creates, ustoms);
111 LL_SUB(finds, end1, end0);
112 LL_DIV(finds, finds, ustoms);
113 LL_SUB(lookups, end2, end1);
114 LL_DIV(lookups, lookups, ustoms);
115 LL_SUB(dtor, end3, end2);
116 char buf[500];
117 RTStrPrintf2(buf, sizeof(buf), "making %d ident strings took %lldms",
118 count, creates);
119 puts(buf);
120 RTStrPrintf2(buf, sizeof(buf), "%d new idents took %lldms",
121 count, finds);
122 puts(buf);
123 RTStrPrintf2(buf, sizeof(buf), "%d ident lookups took %lldms",
124 count, lookups);
125 puts(buf);
126 RTStrPrintf2(buf, sizeof(buf), "dtor took %lldusec", dtor);
127 puts(buf);
128
129 printf("%d live atoms\n", NS_GetNumberOfAtoms());
130 NS_POSTCONDITION(0 == NS_GetNumberOfAtoms(), "dangling atoms");
131
132 return 0;
133}
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette