summaryrefslogtreecommitdiff
path: root/zip/ZipArchive/FileInfo.h
blob: 0ae405e52b46f64812dc3dc0cff2e20566ddd5ad (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
////////////////////////////////////////////////////////////////////////////////
// This source file is part of the ZipArchive Library Open Source distribution 
// and is Copyrighted 2000 - 2022 by Artpol Software - Tadeusz Dracz
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
// 
// For the licensing details refer to the License.txt file.
//
// Web Site: https://www.artpol-software.com
////////////////////////////////////////////////////////////////////////////////

/**
* \file FileInfo.h
*	Includes the ZipArchiveLib::CFileInfo class.
*
*/

#if !defined(ZIPARCHIVE_FILEINFO_DOT_H)
#define ZIPARCHIVE_FILEINFO_DOT_H

#if _MSC_VER > 1000
	#pragma once
#endif

#include "stdafx.h"
#include "ZipExport.h"
#include "ZipPlatform.h"

namespace ZipArchiveLib
{
	/**
		A structure holding a file or a directory information.
	*/
	struct ZIP_API CFileInfo
	{
	public:
		/**
			Initializes a new instance of the CFileInfo class.
		*/
		CFileInfo()
		{
			m_uSize = 0;
			m_uAttributes = 0;
			m_tCreationTime = m_tModificationTime = m_tLastAccessTime = (time_t)0;
		}
		ZIP_FILE_USIZE m_uSize;		///< The file size.
		DWORD m_uAttributes;		///< The file system attributes.
		time_t m_tCreationTime;		///< The file creation time.
		time_t m_tModificationTime;	///< The file modification time.
		time_t m_tLastAccessTime;	///< The file last access time.

		/**
			Returns the value indicating whether the current CFileInfo
			object represents a directory or a regular file.

			\return 
				\c true, if the current CFileInfo object represents 
				a directory; \c false, if it represents a regular file.
		*/
		bool IsDirectory() const
		{
			return ZipPlatform::IsDirectory(m_uAttributes);
		}
	};
}
#endif