/* -*- 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/. */ #ifndef mozilla_dom_cache_FileUtils_h #define mozilla_dom_cache_FileUtils_h #include "mozilla/Attributes.h" #include "mozilla/dom/cache/Types.h" #include "CacheCommon.h" #include "mozIStorageConnection.h" #include "nsStreamUtils.h" #include "nsTArrayForwardDeclare.h" struct nsID; class nsIFile; namespace mozilla { namespace dom { namespace cache { #define PADDING_FILE_NAME u".padding" #define PADDING_TMP_FILE_NAME u".padding-tmp" enum DirPaddingFile { FILE, TMP_FILE }; nsresult BodyCreateDir(nsIFile& aBaseDir); // Note that this function can only be used during the initialization of the // database. We're unlikely to be able to delete the DB successfully past // that point due to the file being in use. nsresult BodyDeleteDir(const QuotaInfo& aQuotaInfo, nsIFile& aBaseDir); // Returns a Result with a success value with the body id and, optionally, the // copy context. Result>, nsresult> BodyStartWriteStream( const QuotaInfo& aQuotaInfo, nsIFile& aBaseDir, nsIInputStream& aSource, void* aClosure, nsAsyncCopyCallbackFun aCallback); void BodyCancelWrite(nsISupports& aCopyContext); nsresult BodyFinalizeWrite(nsIFile& aBaseDir, const nsID& aId); Result>, nsresult> BodyOpen( const QuotaInfo& aQuotaInfo, nsIFile& aBaseDir, const nsID& aId); nsresult BodyMaybeUpdatePaddingSize(const QuotaInfo& aQuotaInfo, nsIFile& aBaseDir, const nsID& aId, uint32_t aPaddingInfo, int64_t* aPaddingSizeInOut); nsresult BodyDeleteFiles(const QuotaInfo& aQuotaInfo, nsIFile& aBaseDir, const nsTArray& aIdList); nsresult BodyDeleteOrphanedFiles(const QuotaInfo& aQuotaInfo, nsIFile& aBaseDir, const nsTArray& aKnownBodyIdList); // If aCanRemoveFiles is true, that means we are safe to touch the files which // can be accessed in other threads. // If it's not, that means we cannot remove the files which are possible to // created by other threads. Note that if the files are not expected, we should // be safe to remove them in any case. template nsresult BodyTraverseFiles(const QuotaInfo& aQuotaInfo, nsIFile& aBodyDir, const Func& aHandleFileFunc, bool aCanRemoveFiles, bool aTrackQuota = true); nsresult CreateMarkerFile(const QuotaInfo& aQuotaInfo); nsresult DeleteMarkerFile(const QuotaInfo& aQuotaInfo); bool MarkerFileExists(const QuotaInfo& aQuotaInfo); nsresult RemoveNsIFileRecursively(const QuotaInfo& aQuotaInfo, nsIFile& aFile, bool aTrackQuota = true); nsresult RemoveNsIFile(const QuotaInfo& aQuotaInfo, nsIFile& aFile, bool aTrackQuota = true); void DecreaseUsageForQuotaInfo(const QuotaInfo& aQuotaInfo, int64_t aUpdatingSize); /** * This function is used to check if the directory padding file is existed. */ bool DirectoryPaddingFileExists(nsIFile& aBaseDir, DirPaddingFile aPaddingFileType); /** * * The functions below are used to read/write/delete the directory padding file * after acquiring the mutex lock. The mutex lock is held by * CacheQuotaClient to prevent multi-thread accessing issue. To avoid deadlock, * these functions should only access by static functions in * dom/cache/QuotaClient.cpp. * */ // Returns a Result with a success value denoting the padding size. Result LockedDirectoryPaddingGet(nsIFile& aBaseDir); nsresult LockedDirectoryPaddingInit(nsIFile& aBaseDir); nsresult LockedUpdateDirectoryPaddingFile(nsIFile& aBaseDir, mozIStorageConnection& aConn, int64_t aIncreaseSize, int64_t aDecreaseSize, bool aTemporaryFileExist); nsresult LockedDirectoryPaddingFinalizeWrite(nsIFile& aBaseDir); // Returns a Result with a success value denoting the padding size. Result LockedDirectoryPaddingRestore( nsIFile& aBaseDir, mozIStorageConnection& aConn, bool aMustRestore); nsresult LockedDirectoryPaddingDeleteFile(nsIFile& aBaseDir, DirPaddingFile aPaddingFileType); } // namespace cache } // namespace dom } // namespace mozilla #endif // mozilla_dom_cache_FileUtils_h