forked from mirrors/gecko-dev
		
	 01583602a9
			
		
	
	
		01583602a9
		
	
	
	
	
		
			
			The bulk of this commit was generated with a script, executed at the top
level of a typical source code checkout.  The only non-machine-generated
part was modifying MFBT's moz.build to reflect the new naming.
CLOSED TREE makes big refactorings like this a piece of cake.
 # The main substitution.
find . -name '*.cpp' -o -name '*.cc' -o -name '*.h' -o -name '*.mm' -o -name '*.idl'| \
    xargs perl -p -i -e '
 s/nsRefPtr\.h/RefPtr\.h/g; # handle includes
 s/nsRefPtr ?</RefPtr</g;   # handle declarations and variables
'
 # Handle a special friend declaration in gfx/layers/AtomicRefCountedWithFinalize.h.
perl -p -i -e 's/::nsRefPtr;/::RefPtr;/' gfx/layers/AtomicRefCountedWithFinalize.h
 # Handle nsRefPtr.h itself, a couple places that define constructors
 # from nsRefPtr, and code generators specially.  We do this here, rather
 # than indiscriminantly s/nsRefPtr/RefPtr/, because that would rename
 # things like nsRefPtrHashtable.
perl -p -i -e 's/nsRefPtr/RefPtr/g' \
     mfbt/nsRefPtr.h \
     xpcom/glue/nsCOMPtr.h \
     xpcom/base/OwningNonNull.h \
     ipc/ipdl/ipdl/lower.py \
     ipc/ipdl/ipdl/builtin.py \
     dom/bindings/Codegen.py \
     python/lldbutils/lldbutils/utils.py
 # In our indiscriminate substitution above, we renamed
 # nsRefPtrGetterAddRefs, the class behind getter_AddRefs.  Fix that up.
find . -name '*.cpp' -o -name '*.h' -o -name '*.idl' | \
    xargs perl -p -i -e 's/nsRefPtrGetterAddRefs/RefPtrGetterAddRefs/g'
if [ -d .git ]; then
    git mv mfbt/nsRefPtr.h mfbt/RefPtr.h
else
    hg mv mfbt/nsRefPtr.h mfbt/RefPtr.h
fi
--HG--
rename : mfbt/nsRefPtr.h => mfbt/RefPtr.h
		
	
			
		
			
				
	
	
		
			128 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			128 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
 | |
| /* vim: set ts=8 sts=2 et sw=2 tw=80: */
 | |
| /* This Source Code Form is subject to the terms of the Mozilla Public
 | |
|  * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 | |
|  * You can obtain one at http://mozilla.org/MPL/2.0/. */
 | |
| 
 | |
| #include "mozilla/dom/FileSystemBase.h"
 | |
| 
 | |
| #include "DeviceStorageFileSystem.h"
 | |
| #include "nsCharSeparatedTokenizer.h"
 | |
| #include "OSFileSystem.h"
 | |
| 
 | |
| namespace mozilla {
 | |
| namespace dom {
 | |
| 
 | |
| // static
 | |
| already_AddRefed<FileSystemBase>
 | |
| FileSystemBase::FromString(const nsAString& aString)
 | |
| {
 | |
|   if (StringBeginsWith(aString, NS_LITERAL_STRING("devicestorage-"))) {
 | |
|     // The string representation of devicestorage file system is of the format:
 | |
|     // devicestorage-StorageType-StorageName
 | |
| 
 | |
|     nsCharSeparatedTokenizer tokenizer(aString, char16_t('-'));
 | |
|     tokenizer.nextToken();
 | |
| 
 | |
|     nsString storageType;
 | |
|     if (tokenizer.hasMoreTokens()) {
 | |
|       storageType = tokenizer.nextToken();
 | |
|     }
 | |
| 
 | |
|     nsString storageName;
 | |
|     if (tokenizer.hasMoreTokens()) {
 | |
|       storageName = tokenizer.nextToken();
 | |
|     }
 | |
| 
 | |
|     RefPtr<DeviceStorageFileSystem> f =
 | |
|       new DeviceStorageFileSystem(storageType, storageName);
 | |
|     return f.forget();
 | |
|   }
 | |
|   return RefPtr<OSFileSystem>(new OSFileSystem(aString)).forget();
 | |
| }
 | |
| 
 | |
| FileSystemBase::FileSystemBase()
 | |
|   : mShutdown(false)
 | |
|   , mRequiresPermissionChecks(true)
 | |
| {
 | |
| }
 | |
| 
 | |
| FileSystemBase::~FileSystemBase()
 | |
| {
 | |
| }
 | |
| 
 | |
| void
 | |
| FileSystemBase::Shutdown()
 | |
| {
 | |
|   mShutdown = true;
 | |
| }
 | |
| 
 | |
| nsPIDOMWindow*
 | |
| FileSystemBase::GetWindow() const
 | |
| {
 | |
|   return nullptr;
 | |
| }
 | |
| 
 | |
| already_AddRefed<nsIFile>
 | |
| FileSystemBase::GetLocalFile(const nsAString& aRealPath) const
 | |
| {
 | |
|   MOZ_ASSERT(XRE_IsParentProcess(),
 | |
|              "Should be on parent process!");
 | |
|   nsAutoString localPath;
 | |
|   FileSystemUtils::NormalizedPathToLocalPath(aRealPath, localPath);
 | |
|   localPath = mLocalRootPath + localPath;
 | |
|   nsCOMPtr<nsIFile> file;
 | |
|   nsresult rv = NS_NewLocalFile(localPath, false, getter_AddRefs(file));
 | |
|   if (NS_WARN_IF(NS_FAILED(rv))) {
 | |
|     return nullptr;
 | |
|   }
 | |
|   return file.forget();
 | |
| }
 | |
| 
 | |
| bool
 | |
| FileSystemBase::GetRealPath(BlobImpl* aFile, nsAString& aRealPath) const
 | |
| {
 | |
|   MOZ_ASSERT(XRE_IsParentProcess(),
 | |
|              "Should be on parent process!");
 | |
|   MOZ_ASSERT(aFile, "aFile Should not be null.");
 | |
| 
 | |
|   aRealPath.Truncate();
 | |
| 
 | |
|   nsAutoString filePath;
 | |
|   ErrorResult rv;
 | |
|   aFile->GetMozFullPathInternal(filePath, rv);
 | |
|   if (NS_WARN_IF(rv.Failed())) {
 | |
|     return false;
 | |
|   }
 | |
| 
 | |
|   return LocalPathToRealPath(filePath, aRealPath);
 | |
| }
 | |
| 
 | |
| bool
 | |
| FileSystemBase::IsSafeFile(nsIFile* aFile) const
 | |
| {
 | |
|   return false;
 | |
| }
 | |
| 
 | |
| bool
 | |
| FileSystemBase::IsSafeDirectory(Directory* aDir) const
 | |
| {
 | |
|   return false;
 | |
| }
 | |
| 
 | |
| bool
 | |
| FileSystemBase::LocalPathToRealPath(const nsAString& aLocalPath,
 | |
|                                     nsAString& aRealPath) const
 | |
| {
 | |
|   nsAutoString path;
 | |
|   FileSystemUtils::LocalPathToNormalizedPath(aLocalPath, path);
 | |
|   if (!FileSystemUtils::IsDescendantPath(mNormalizedLocalRootPath, path)) {
 | |
|     aRealPath.Truncate();
 | |
|     return false;
 | |
|   }
 | |
|   aRealPath = Substring(path, mNormalizedLocalRootPath.Length());
 | |
|   return true;
 | |
| }
 | |
| 
 | |
| } // namespace dom
 | |
| } // namespace mozilla
 |