/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* 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 _nsMsgFilterService_H_ #define _nsMsgFilterService_H_ #include "nsIMsgFilterService.h" #include "nsCOMArray.h" class nsIMsgWindow; class nsIStringBundle; // The filter service is used to acquire and manipulate filter lists. class nsMsgFilterService : public nsIMsgFilterService { public: nsMsgFilterService(); NS_DECL_ISUPPORTS NS_DECL_NSIMSGFILTERSERVICE /* clients call OpenFilterList to get a handle to a FilterList, of existing nsMsgFilter *. These are manipulated by the front end as a result of user interaction with dialog boxes. To apply the new list call MSG_CloseFilterList. */ nsresult BackUpFilterFile(nsIFile *aFilterFile, nsIMsgWindow *aMsgWindow); nsresult AlertBackingUpFilterFile(nsIMsgWindow *aMsgWindow); nsresult ThrowAlertMsg(const char*aMsgName, nsIMsgWindow *aMsgWindow); nsresult GetStringFromBundle(const char *aMsgName, char16_t **aResult); nsresult GetFilterStringBundle(nsIStringBundle **aBundle); protected: virtual ~nsMsgFilterService(); nsCOMArray mCustomActions; // defined custom action list nsCOMArray mCustomTerms; // defined custom term list }; #endif // _nsMsgFilterService_H_