mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-27 20:25:44 +00:00
efee7eec18
nsIFile::CreateUnique() has unused parameter removed unused parameter /** WARNING commercial tree has one hit for this API change */ --pete
182 lines
6.1 KiB
C++
182 lines
6.1 KiB
C++
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Version: NPL 1.1/GPL 2.0/LGPL 2.1
|
|
*
|
|
* The contents of this file are subject to the Netscape 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/NPL/
|
|
*
|
|
* 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
|
|
* Netscape Communications Corporation.
|
|
* Portions created by the Initial Developer are Copyright (C) 1999
|
|
* the Initial Developer. All Rights Reserved.
|
|
*
|
|
* Contributor(s):
|
|
*
|
|
* 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 NPL, 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 NPL, the GPL or the LGPL.
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
#include "nsIServiceManager.h"
|
|
#ifndef XPCOM_STANDALONE
|
|
#include "nsIURLParser.h"
|
|
#include "nsNetCID.h"
|
|
#endif /* XPCOM_STANDALONE */
|
|
|
|
|
|
#include "nsLocalFile.h" // includes platform-specific headers
|
|
#include "nsLocalFileUnicode.h"
|
|
|
|
#include "nsString.h"
|
|
#include "nsCOMPtr.h"
|
|
#include "nsXPIDLString.h"
|
|
|
|
#ifndef XPCOM_STANDALONE
|
|
static NS_DEFINE_CID(kURLParserCID, NS_NOAUTHURLPARSER_CID);
|
|
#endif
|
|
|
|
|
|
void NS_StartupLocalFile()
|
|
{
|
|
#ifdef XP_WIN
|
|
CoInitialize(NULL); // FIX: we should probably move somewhere higher up during startup
|
|
#endif
|
|
}
|
|
|
|
void NS_ShutdownLocalFile()
|
|
{
|
|
NS_ShutdownLocalFileUnicode();
|
|
|
|
#ifdef XP_WIN
|
|
CoUninitialize();
|
|
#endif
|
|
}
|
|
|
|
// should work on Macintosh, Unix, and Win32.
|
|
#define kMaxFilenameLength 31
|
|
|
|
NS_IMETHODIMP
|
|
nsLocalFile::CreateUnique(PRUint32 type, PRUint32 attributes)
|
|
{
|
|
nsresult rv = Create(type, attributes);
|
|
|
|
if (NS_SUCCEEDED(rv)) return NS_OK;
|
|
if (rv != NS_ERROR_FILE_ALREADY_EXISTS) return rv;
|
|
|
|
char* leafName;
|
|
rv = GetLeafName(&leafName);
|
|
|
|
if (NS_FAILED(rv)) return rv;
|
|
|
|
char* lastDot = strrchr(leafName, '.');
|
|
char suffix[kMaxFilenameLength + 1] = "";
|
|
if (lastDot)
|
|
{
|
|
strncpy(suffix, lastDot, kMaxFilenameLength); // include '.'
|
|
suffix[kMaxFilenameLength] = 0; // make sure it's null terminated
|
|
*lastDot = '\0'; // strip suffix and dot.
|
|
}
|
|
|
|
// 27 should work on Macintosh, Unix, and Win32.
|
|
const int maxRootLength = 27 - nsCRT::strlen(suffix) - 1;
|
|
|
|
if ((int)nsCRT::strlen(leafName) > (int)maxRootLength)
|
|
leafName[maxRootLength] = '\0';
|
|
|
|
for (short indx = 1; indx < 10000; indx++)
|
|
{
|
|
// start with "Picture-1.jpg" after "Picture.jpg" exists
|
|
char newName[kMaxFilenameLength + 1];
|
|
sprintf(newName, "%s-%d%s", leafName, indx, suffix);
|
|
SetLeafName(newName);
|
|
|
|
rv = Create(type, attributes);
|
|
|
|
if (NS_SUCCEEDED(rv) || rv != NS_ERROR_FILE_ALREADY_EXISTS)
|
|
{
|
|
nsMemory::Free(leafName);
|
|
return rv;
|
|
}
|
|
}
|
|
|
|
nsMemory::Free(leafName);
|
|
// The disk is full, sort of
|
|
return NS_ERROR_FILE_TOO_BIG;
|
|
}
|
|
|
|
nsresult nsLocalFile::ParseURL(const char* inURL, char **outHost, char **outDirectory,
|
|
char **outFileBaseName, char **outFileExtension)
|
|
{
|
|
nsresult rv = NS_ERROR_NOT_IMPLEMENTED;
|
|
|
|
#ifndef XPCOM_STANDALONE
|
|
NS_ENSURE_ARG(inURL);
|
|
NS_ENSURE_ARG_POINTER(outHost);
|
|
*outHost = nsnull;
|
|
NS_ENSURE_ARG_POINTER(outDirectory);
|
|
*outDirectory = nsnull;
|
|
NS_ENSURE_ARG_POINTER(outFileBaseName);
|
|
*outFileBaseName = nsnull;
|
|
NS_ENSURE_ARG_POINTER(outFileExtension);
|
|
*outFileExtension = nsnull;
|
|
|
|
nsCOMPtr<nsIURLParser> parser(do_GetService(kURLParserCID, &rv));
|
|
if (NS_FAILED(rv)) return rv;
|
|
|
|
PRUint32 pathPos, filepathPos, directoryPos, basenamePos, extensionPos;
|
|
PRInt32 pathLen, filepathLen, directoryLen, basenameLen, extensionLen;
|
|
|
|
// invoke the parser to extract the URL path
|
|
rv = parser->ParseURL(inURL, -1,
|
|
nsnull, nsnull, // dont care about scheme
|
|
nsnull, nsnull, // dont care about authority
|
|
&pathPos, &pathLen);
|
|
if (NS_FAILED(rv)) return rv;
|
|
|
|
// invoke the parser to extract filepath from the path
|
|
rv = parser->ParsePath(inURL + pathPos, pathLen,
|
|
&filepathPos, &filepathLen,
|
|
nsnull, nsnull, // dont care about param
|
|
nsnull, nsnull, // dont care about query
|
|
nsnull, nsnull); // dont care about ref
|
|
if (NS_FAILED(rv)) return rv;
|
|
|
|
filepathPos += pathPos;
|
|
|
|
// invoke the parser to extract the directory and filename from filepath
|
|
rv = parser->ParseFilePath(inURL + filepathPos, filepathLen,
|
|
&directoryPos, &directoryLen,
|
|
&basenamePos, &basenameLen,
|
|
&extensionPos, &extensionLen);
|
|
if (NS_FAILED(rv)) return rv;
|
|
|
|
if (directoryLen > 0)
|
|
*outDirectory = PL_strndup(inURL + filepathPos + directoryPos, directoryLen);
|
|
if (basenameLen > 0)
|
|
*outFileBaseName = PL_strndup(inURL + filepathPos + basenamePos, basenameLen);
|
|
if (extensionLen > 0)
|
|
*outFileExtension = PL_strndup(inURL + filepathPos + extensionPos, extensionLen);
|
|
// since we are using a no-auth url parser, there will never be a host
|
|
|
|
#endif /* XPCOM_STANDALONE */
|
|
|
|
return NS_OK;
|
|
}
|