Follow-on fix for bug 457825. Use sheet principal for agent and user sheets. r=dbaron...
[wine-gecko.git] / embedding / qa / testembed / MostRecentUrls.cpp
blobe960096dbc2310712522d2ce0b8b3eb60c8172d8
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
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/
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.
15 * The Original Code is mozilla.org code.
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.
22 * Contributor(s):
23 * Rod Spears <rods@netscape.com>
25 * Alternatively, the contents of this file may be used under the terms of
26 * either the GNU General Public License Version 2 or later (the "GPL"), or
27 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
28 * in which case the provisions of the GPL or the LGPL are applicable instead
29 * of those above. If you wish to allow use of your version of this file only
30 * under the terms of either the GPL or the LGPL, and not to allow others to
31 * use your version of this file under the terms of the MPL, indicate your
32 * decision by deleting the provisions above and replace them with the notice
33 * and other provisions required by the GPL or the LGPL. If you do not delete
34 * the provisions above, a recipient may use your version of this file under
35 * the terms of any one of the MPL, the GPL or the LGPL.
37 * ***** END LICENSE BLOCK ***** */
40 // CMostRecentUrls object is responsible for keeping track of the
41 // 16 most recently used URLs. It stores this list in a file named
42 // "urls.txt" on a per profile basis in the user's profile directory
44 // The constructor loads the URL list
45 // The destructor saves the URL list
48 #include "StdAfx.h"
49 #include "nsIFile.h"
50 #include "nsILocalFile.h"
51 #include "nsAppDirectoryServiceDefs.h"
52 #include "MostRecentUrls.h"
54 //--------------------------------------------------------
55 //-- CMostRecentUrls
56 //--------------------------------------------------------
57 CMostRecentUrls::CMostRecentUrls() :
58 mNumURLs(0)
60 for (int i=0;i<MAX_URLS;i++) {
61 mURLs[i] = NULL;
64 FILE * fd = GetFD("r");
65 if (fd) {
66 char line[512];
67 while (fgets(line, 512, fd)) {
68 if (strlen(line) > 1) {
69 line[strlen(line)-1] = 0;
70 mURLs[mNumURLs++] = _strdup(line);
73 fclose(fd);
78 FILE * CMostRecentUrls::GetFD(const char * aMode)
80 FILE * fd = nsnull;
81 nsCOMPtr<nsIFile> file;
82 nsresult rv = NS_GetSpecialDirectory(NS_APP_USER_PROFILE_50_DIR, getter_AddRefs(file));
83 if (NS_SUCCEEDED(rv)) {
84 nsCOMPtr<nsILocalFile> local_file(do_QueryInterface(file));
85 local_file->AppendNative(NS_LITERAL_CSTRING("urls.txt"));
86 local_file->OpenANSIFileDesc(aMode, &fd);
89 return fd;
92 CMostRecentUrls::~CMostRecentUrls()
94 FILE * fd = GetFD("w");
95 if (fd) {
96 for (int i=0;i<MAX_URLS;i++) {
97 if(mURLs[i])
98 fprintf(fd, "%s\n", mURLs[i]);
100 fclose(fd);
103 for (int i=0;i<MAX_URLS;i++) {
104 if(mURLs[i])
105 free(mURLs[i]);
109 char * CMostRecentUrls::GetURL(int aInx)
111 if (aInx < mNumURLs) {
112 return mURLs[aInx];
115 return NULL;
118 void CMostRecentUrls::AddURL(const char * aURL)
120 TCHAR szTemp[512];
121 strcpy(szTemp, aURL);
123 // check to see if an existing url matches the one passed in
124 int i = 0;
125 for (; i<MAX_URLS-1; i++)
127 if(mURLs[i])
129 if(strcmpi(mURLs[i], szTemp) == 0)
130 break;
134 // if there was a match "i" will point to matching url entry
135 // if not i will be MAX_URLS-1
137 // move all url entries before this one down
138 for (; i>0; i--)
140 if(mURLs[i])
141 free(mURLs[i]);
143 if(mURLs[i-1])
144 mURLs[i] = _strdup(mURLs[i-1]);
147 // place this url at the top
148 if(mURLs[0])
149 free(mURLs[0]);
150 mURLs[0] = _strdup(szTemp);