Follow-on fix for bug 457825. Use sheet principal for agent and user sheets. r=dbaron...
[wine-gecko.git] / netwerk / cache / src / nsCache.cpp
blobe2dd6e3ca0921ed75a358386a55b69e7d189fac6
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
3 * ***** BEGIN LICENSE BLOCK *****
4 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
6 * The contents of this file are subject to the Mozilla Public License Version
7 * 1.1 (the "License"); you may not use this file except in compliance with
8 * the License. You may obtain a copy of the License at
9 * http://www.mozilla.org/MPL/
11 * Software distributed under the License is distributed on an "AS IS" basis,
12 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
13 * for the specific language governing rights and limitations under the
14 * License.
16 * The Original Code is nsCache.cpp, released
17 * March 18, 2001.
19 * The Initial Developer of the Original Code is
20 * Netscape Communications Corporation.
21 * Portions created by the Initial Developer are Copyright (C) 2001
22 * the Initial Developer. All Rights Reserved.
24 * Contributor(s):
25 * Gordon Sheridan <gordon@netscape.com>
26 * Patrick C. Beard <beard@netscape.com>
27 * Darin Fisher <darin@netscape.com>
29 * Alternatively, the contents of this file may be used under the terms of
30 * either the GNU General Public License Version 2 or later (the "GPL"), or
31 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
32 * in which case the provisions of the GPL or the LGPL are applicable instead
33 * of those above. If you wish to allow use of your version of this file only
34 * under the terms of either the GPL or the LGPL, and not to allow others to
35 * use your version of this file under the terms of the MPL, indicate your
36 * decision by deleting the provisions above and replace them with the notice
37 * and other provisions required by the GPL or the LGPL. If you do not delete
38 * the provisions above, a recipient may use your version of this file under
39 * the terms of any one of the MPL, the GPL or the LGPL.
41 * ***** END LICENSE BLOCK ***** */
43 #include "nsCache.h"
44 #include "nsReadableUtils.h"
45 #include "nsDependentSubstring.h"
46 #include "nsString.h"
49 /**
50 * Cache Service Utility Functions
53 #if defined(PR_LOGGING)
54 PRLogModuleInfo * gCacheLog = nsnull;
57 void
58 CacheLogInit()
60 if (gCacheLog) return;
61 gCacheLog = PR_NewLogModule("cache");
62 NS_ASSERTION(gCacheLog, "\nfailed to allocate cache log.\n");
66 void
67 CacheLogPrintPath(PRLogModuleLevel level, char * format, nsIFile * item)
69 nsCAutoString path;
70 nsresult rv = item->GetNativePath(path);
71 if (NS_SUCCEEDED(rv)) {
72 PR_LOG(gCacheLog, level, (format, path.get()));
73 } else {
74 PR_LOG(gCacheLog, level, ("GetNativePath failed: %x", rv));
78 #endif
81 PRUint32
82 SecondsFromPRTime(PRTime prTime)
84 PRInt64 microSecondsPerSecond, intermediateResult;
85 PRUint32 seconds;
87 LL_I2L(microSecondsPerSecond, PR_USEC_PER_SEC);
88 LL_DIV(intermediateResult, prTime, microSecondsPerSecond);
89 LL_L2UI(seconds, intermediateResult);
90 return seconds;
94 PRTime
95 PRTimeFromSeconds(PRUint32 seconds)
97 PRInt64 microSecondsPerSecond, intermediateResult;
98 PRTime prTime;
100 LL_I2L(microSecondsPerSecond, PR_USEC_PER_SEC);
101 LL_UI2L(intermediateResult, seconds);
102 LL_MUL(prTime, intermediateResult, microSecondsPerSecond);
103 return prTime;
107 nsresult
108 ClientIDFromCacheKey(const nsACString& key, char ** result)
110 nsresult rv = NS_OK;
111 *result = nsnull;
113 nsReadingIterator<char> colon;
114 key.BeginReading(colon);
116 nsReadingIterator<char> start;
117 key.BeginReading(start);
119 nsReadingIterator<char> end;
120 key.EndReading(end);
122 if (FindCharInReadable(':', colon, end)) {
123 *result = ToNewCString( Substring(start, colon));
124 if (!*result) rv = NS_ERROR_OUT_OF_MEMORY;
125 } else {
126 NS_ASSERTION(PR_FALSE, "FindCharInRead failed to find ':'");
127 rv = NS_ERROR_UNEXPECTED;
129 return rv;
133 nsresult
134 ClientKeyFromCacheKey(const nsCString& key, nsACString &result)
136 nsresult rv = NS_OK;
138 nsReadingIterator<char> start;
139 key.BeginReading(start);
141 nsReadingIterator<char> end;
142 key.EndReading(end);
144 if (FindCharInReadable(':', start, end)) {
145 ++start; // advance past clientID ':' delimiter
146 result.Assign(Substring(start, end));
147 } else {
148 NS_ASSERTION(PR_FALSE, "FindCharInRead failed to find ':'");
149 rv = NS_ERROR_UNEXPECTED;
150 result.Truncate(0);
152 return rv;