Bug 401190 - nsNavHistory should implement nsIDownloadHistory. r=dietrich, a=mconnor

This commit is contained in:
sdwilsh@shawnwilsher.com 2007-12-21 18:27:11 -08:00
parent 17360fb8d6
commit cf89a0ca7c
4 changed files with 137 additions and 0 deletions

View File

@ -181,6 +181,7 @@ NS_INTERFACE_MAP_BEGIN(nsNavHistory)
NS_INTERFACE_MAP_ENTRY(nsINavHistoryService) NS_INTERFACE_MAP_ENTRY(nsINavHistoryService)
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsIGlobalHistory2, nsIGlobalHistory3) NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsIGlobalHistory2, nsIGlobalHistory3)
NS_INTERFACE_MAP_ENTRY(nsIGlobalHistory3) NS_INTERFACE_MAP_ENTRY(nsIGlobalHistory3)
NS_INTERFACE_MAP_ENTRY(nsIDownloadHistory)
NS_INTERFACE_MAP_ENTRY(nsIBrowserHistory) NS_INTERFACE_MAP_ENTRY(nsIBrowserHistory)
NS_INTERFACE_MAP_ENTRY(nsIObserver) NS_INTERFACE_MAP_ENTRY(nsIObserver)
NS_INTERFACE_MAP_ENTRY(nsISupportsWeakReference) NS_INTERFACE_MAP_ENTRY(nsISupportsWeakReference)
@ -3500,6 +3501,27 @@ nsNavHistory::IdleTimerCallback(nsITimer* aTimer, void* aClosure)
(void)history->OnIdle(); (void)history->OnIdle();
} }
// nsIDownloadHistory **********************************************************
NS_IMETHODIMP
nsNavHistory::AddDownload(nsIURI* aSource, nsIURI* aReferrer,
PRTime aStartTime)
{
PRInt64 visitID, sessionID = 0;
// If we've already visited this page, we won't need to send a notification
// about having a new visited link. We do this because docshell doesn't mark
// downloads running through exthandler as visited, so we get to do it.
if (!FindLastVisit(aSource, &visitID, &sessionID)) {
nsCOMPtr<nsIObserverService> os =
do_GetService("@mozilla.org/observer-service;1");
if (os)
(void)os->NotifyObservers(aSource, NS_LINK_VISITED_EVENT_TOPIC, nsnull);
}
return AddVisit(aSource, aStartTime, aReferrer, TRANSITION_DOWNLOAD, PR_FALSE,
sessionID, &visitID);
}
// nsIObserver ***************************************************************** // nsIObserver *****************************************************************
NS_IMETHODIMP NS_IMETHODIMP

View File

@ -56,6 +56,7 @@
#include "nsIDateTimeFormat.h" #include "nsIDateTimeFormat.h"
#include "nsIGlobalHistory.h" #include "nsIGlobalHistory.h"
#include "nsIGlobalHistory3.h" #include "nsIGlobalHistory3.h"
#include "nsIDownloadHistory.h"
#include "nsIPrefService.h" #include "nsIPrefService.h"
#include "nsIPrefBranch.h" #include "nsIPrefBranch.h"
#include "nsIObserver.h" #include "nsIObserver.h"
@ -101,6 +102,7 @@ class nsNavHistory : public nsSupportsWeakReference,
public nsIObserver, public nsIObserver,
public nsIBrowserHistory, public nsIBrowserHistory,
public nsIGlobalHistory3, public nsIGlobalHistory3,
public nsIDownloadHistory,
public nsIAutoCompleteSearch, public nsIAutoCompleteSearch,
public nsIAutoCompleteSimpleResultListener public nsIAutoCompleteSimpleResultListener
{ {
@ -114,6 +116,7 @@ public:
NS_DECL_NSINAVHISTORYSERVICE NS_DECL_NSINAVHISTORYSERVICE
NS_DECL_NSIGLOBALHISTORY2 NS_DECL_NSIGLOBALHISTORY2
NS_DECL_NSIGLOBALHISTORY3 NS_DECL_NSIGLOBALHISTORY3
NS_DECL_NSIDOWNLOADHISTORY
NS_DECL_NSIBROWSERHISTORY NS_DECL_NSIBROWSERHISTORY
NS_DECL_NSIOBSERVER NS_DECL_NSIOBSERVER
NS_DECL_NSIAUTOCOMPLETESEARCH NS_DECL_NSIAUTOCOMPLETESEARCH

View File

@ -5,6 +5,7 @@
#include "nsNavHistory.h" #include "nsNavHistory.h"
#include "nsNavBookmarks.h" #include "nsNavBookmarks.h"
#include "nsFaviconService.h" #include "nsFaviconService.h"
#include "nsDocShellCID.h"
NS_GENERIC_FACTORY_CONSTRUCTOR_INIT(nsNavHistory, Init) NS_GENERIC_FACTORY_CONSTRUCTOR_INIT(nsNavHistory, Init)
NS_GENERIC_FACTORY_CONSTRUCTOR(nsAnnoProtocolHandler) NS_GENERIC_FACTORY_CONSTRUCTOR(nsAnnoProtocolHandler)
@ -29,6 +30,11 @@ static const nsModuleComponentInfo components[] =
"@mozilla.org/autocomplete/search;1?name=history", "@mozilla.org/autocomplete/search;1?name=history",
nsNavHistoryConstructor }, nsNavHistoryConstructor },
{ "Download Navigation History",
NS_NAVHISTORYSERVICE_CID,
NS_DOWNLOADHISTORY_CONTRACTID,
nsNavHistoryConstructor },
{ "Page Annotation Service", { "Page Annotation Service",
NS_ANNOTATIONSERVICE_CID, NS_ANNOTATIONSERVICE_CID,
NS_ANNOTATIONSERVICE_CONTRACTID, NS_ANNOTATIONSERVICE_CONTRACTID,

View File

@ -0,0 +1,106 @@
/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim:set ts=2 sw=2 sts=2 et: */
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is mozilla.org code.
*
* The Initial Developer of the Original Code is
* Mozilla Corporation.
* Portions created by the Initial Developer are Copyright (C) 2007
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Shawn Wilsher <me@shawnwilsher.com> (Original Author)
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
// Get history service
try {
var histsvc = Cc["@mozilla.org/browser/nav-history-service;1"].
getService(Ci.nsINavHistoryService);
} catch(ex) {
do_throw("Could not get history service\n");
}
/**
* Checks to see that a URI is in the database.
*
* @param aURI
* The URI to check.
* @returns true if the URI is in the DB, false otherwise.
*/
function uri_in_db(aURI) {
var options = histsvc.getNewQueryOptions();
options.maxResults = 1;
options.resultType = options.RESULTS_AS_URI;
options.includeHidden = true;
var query = histsvc.getNewQuery();
query.uri = aURI;
var result = histsvc.executeQuery(query, options);
var root = result.root;
root.containerOpen = true;
return (root.childCount == 1);
}
// main
function run_test() {
// Test that when we get nsIDownloadHistory that it's the one places
// implements.
var dh = Cc["@mozilla.org/browser/download-history;1"].
getService(Ci.nsIDownloadHistory);
do_check_true(dh instanceof Ci.nsINavHistoryService);
// now to make sure all the functionality works!
const NS_LINK_VISITED_EVENT_TOPIC = "link-visited";
var ios = Cc["@mozilla.org/network/io-service;1"].
getService(Ci.nsIIOService);
var testURI = ios.newURI("http://google.com/", null, null);
do_check_false(uri_in_db(testURI));
var topicReceived = false;
var obs = {
observe: function tlvo_observe(aSubject, aTopic, aData)
{
if (NS_LINK_VISITED_EVENT_TOPIC == aTopic) {
do_check_eq(testURI, aSubject);
topicReceived = true;
}
}
};
var os = Cc["@mozilla.org/observer-service;1"].
getService(Ci.nsIObserverService);
os.addObserver(obs, NS_LINK_VISITED_EVENT_TOPIC, false);
var referrerURI = ios.newURI("http://yahoo.com", null, null);
do_check_false(uri_in_db(referrerURI));
do_check_false(uri_in_db(testURI));
dh.addDownload(testURI, referrerURI, Date.now() * 1000);
do_check_true(topicReceived);
do_check_true(uri_in_db(testURI));
do_check_true(uri_in_db(referrerURI));
}