fix for bug 107289 sr=jband r=dougt a=asa

remove libjar dependency from xpcom
step 3: make libjar implement the new interface
This commit is contained in:
alecf%netscape.com 2002-04-04 22:28:17 +00:00
Родитель 31d0733c1f
Коммит be04e57521
6 изменённых файлов: 185 добавлений и 4043 удалений

Разница между файлами не показана из-за своего большого размера Загрузить разницу

Просмотреть файл

@ -52,6 +52,7 @@ OBJS=.\$(OBJDIR)\nsZipArchive.obj \
.\$(OBJDIR)\nsJARFactory.obj \
.\$(OBJDIR)\nsJARInputStream.obj \
.\$(OBJDIR)\nsWildCard.obj \
.\$(OBJDIR)\nsXPTZipReader.obj \
$(NULL)
LCFLAGS=-DZLIB_DLL=1

Просмотреть файл

@ -1,4 +1,4 @@
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* The contents of this file are subject to the Netscape Public
* License Version 1.1 (the "License"); you may not use this file
@ -39,11 +39,20 @@
#include "nsJAR.h"
#include "nsIJARFactory.h"
#include "nsRecyclingAllocator.h"
#include "nsXPTZipLoader.h"
extern nsRecyclingAllocator *gZlibAllocator;
NS_GENERIC_FACTORY_CONSTRUCTOR(nsXPTZipLoader)
// The list of components we register
static const nsModuleComponentInfo components[] =
{
{ "XPT Zip Reader",
NS_XPTZIPREADER_CID,
NS_XPTLOADER_CONTRACTID_PREFIX "zip",
nsXPTZipLoaderConstructor
},
{ "Zip Reader",
NS_ZIPREADER_CID,
"@mozilla.org/libjar/zip-reader;1",

Просмотреть файл

@ -0,0 +1,121 @@
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.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 the XPT zip reader.
*
* The Initial Developer of the Original Code is
* Netscape Communications Corp.
* Portions created by the Initial Developer are Copyright (C) 2002
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* John Bandhauer <jband@netscape.com>
* Alec Flett <alecf@netscape.com>
*
* ***** END LICENSE BLOCK ***** */
#include "nsXPTZipLoader.h"
#include "nsIZipReader.h"
#include "nsXPIDLString.h"
#include "nsISimpleEnumerator.h"
static const char gCacheContractID[] =
"@mozilla.org/libjar/zip-reader-cache;1";
static const PRUint32 gCacheSize = 1;
nsXPTZipLoader::nsXPTZipLoader() {
NS_INIT_ISUPPORTS();
}
NS_IMPL_ISUPPORTS1(nsXPTZipLoader, nsIXPTLoader)
nsresult
nsXPTZipLoader::LoadEntry(nsILocalFile* aFile,
const char* aName,
nsIInputStream** aResult)
{
nsCOMPtr<nsIZipReader> zip = dont_AddRef(GetZipReader(aFile));
if (!zip)
return NS_OK;
return zip->GetInputStream(aName, aResult);
}
nsresult
nsXPTZipLoader::EnumerateEntries(nsILocalFile* aFile,
nsIXPTLoaderSink* aSink)
{
nsCOMPtr<nsIZipReader> zip = dont_AddRef(GetZipReader(aFile));
if (!zip) {
NS_WARNING("Could not get Zip Reader");
return NS_OK;
}
nsCOMPtr<nsISimpleEnumerator> entries;
if (NS_FAILED(zip->FindEntries("*.xpt", getter_AddRefs(entries))) ||
!entries) {
// no problem, just no .xpt files in this archive
return NS_OK;
}
PRBool hasMore;
while (NS_SUCCEEDED(entries->HasMoreElements(&hasMore)) && hasMore) {
int index=0;
nsCOMPtr<nsISupports> sup;
if (NS_FAILED(entries->GetNext(getter_AddRefs(sup))) || !sup)
return NS_ERROR_UNEXPECTED;
nsCOMPtr<nsIZipEntry> entry = do_QueryInterface(sup);
if (!entry)
return NS_ERROR_UNEXPECTED;
nsXPIDLCString itemName;
if (NS_FAILED(entry->GetName(getter_Copies(itemName))))
return NS_ERROR_UNEXPECTED;
nsCOMPtr<nsIInputStream> stream;
if (NS_FAILED(zip->GetInputStream(itemName, getter_AddRefs(stream))))
return NS_ERROR_FAILURE;
// ignore the result
aSink->FoundEntry(itemName, index++, stream);
}
return NS_OK;
}
nsIZipReader*
nsXPTZipLoader::GetZipReader(nsILocalFile* file)
{
NS_ASSERTION(file, "bad file");
if(!mCache)
{
mCache = do_CreateInstance(gCacheContractID);
if(!mCache || NS_FAILED(mCache->Init(gCacheSize)))
return nsnull;
}
nsIZipReader* reader = nsnull;
if(NS_FAILED(mCache->GetZip(file, &reader)))
return nsnull;
return reader;
}

Просмотреть файл

@ -0,0 +1,52 @@
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.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 the XPT zip reader.
*
* The Initial Developer of the Original Code is
* Netscape Communications Corp.
* Portions created by the Initial Developer are Copyright (C) 2002
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* John Bandhauer <jband@netscape.com>
* Alec Flett <alecf@netscape.com>
*
* ***** END LICENSE BLOCK ***** */
#include "nsISupports.h"
#include "nsIXPTLoader.h"
#include "nsIZipReader.h"
// {0320E073-79C7-4dae-8055-81BED8B8DB96}
#define NS_XPTZIPREADER_CID \
{ 0x320e073, 0x79c7, 0x4dae, \
{ 0x80, 0x55, 0x81, 0xbe, 0xd8, 0xb8, 0xdb, 0x96 } }
class nsXPTZipLoader : public nsIXPTLoader
{
public:
nsXPTZipLoader();
virtual ~nsXPTZipLoader() {};
NS_DECL_ISUPPORTS
NS_DECL_NSIXPTLOADER
private:
nsIZipReader* GetZipReader(nsILocalFile* aFile);
nsCOMPtr<nsIZipReaderCache> mCache;
};

Просмотреть файл

@ -25,6 +25,7 @@ MODULES_LIBJAR_LCPPSRCS = \
nsJAR.cpp \
nsJARFactory.cpp \
nsWildCard.cpp \
nsXPTZipLoader.cpp \
$(NULL)
MODULES_LIBJAR_LEXPORTS = \