blob: baf235b9009d5d6778ff997f9833185162428ef3 [file] [log] [blame]
srs5694add79a62010-01-26 15:59:58 -05001//
2// C++ Interface: diskio (platform-independent components)
3//
4// Description: Class to handle low-level disk I/O for GPT fdisk
5//
6//
7// Author: Rod Smith <rodsmith@rodsbooks.com>, (C) 2009
8//
9// Copyright: See COPYING file that comes with this distribution
10//
11//
12// This program is copyright (c) 2009 by Roderick W. Smith. It is distributed
13// under the terms of the GNU GPL version 2, as detailed in the COPYING file.
14
15#define __STDC_LIMIT_MACROS
16#define __STDC_CONSTANT_MACROS
17
srs56940a697312010-01-28 21:10:52 -050018#ifdef _WIN32
srs5694add79a62010-01-26 15:59:58 -050019#include <windows.h>
20#include <winioctl.h>
21#define fstat64 fstat
22#define stat64 stat
23#define S_IRGRP 0
24#define S_IROTH 0
25#else
26#include <sys/ioctl.h>
27#endif
srs5694add79a62010-01-26 15:59:58 -050028#include <string>
29#include <stdint.h>
30#include <errno.h>
31#include <fcntl.h>
32#include <sys/stat.h>
33#include <iostream>
34
35#include "support.h"
36#include "diskio.h"
srs5694bf8950c2011-03-12 01:23:12 -050037//#include "gpt.h"
srs5694add79a62010-01-26 15:59:58 -050038
39using namespace std;
40
41DiskIO::DiskIO(void) {
42 userFilename = "";
43 realFilename = "";
44 isOpen = 0;
45 openForWrite = 0;
srs5694add79a62010-01-26 15:59:58 -050046} // constructor
47
48DiskIO::~DiskIO(void) {
49 Close();
srs5694add79a62010-01-26 15:59:58 -050050} // destructor
51
52// Open a disk device for reading. Returns 1 on success, 0 on failure.
srs56940a697312010-01-28 21:10:52 -050053int DiskIO::OpenForRead(const string & filename) {
srs5694add79a62010-01-26 15:59:58 -050054 int shouldOpen = 1;
55
56 if (isOpen) { // file is already open
57 if (((realFilename != filename) && (userFilename != filename)) || (openForWrite)) {
58 Close();
59 } else {
60 shouldOpen = 0;
61 } // if/else
62 } // if
63
64 if (shouldOpen) {
65 userFilename = filename;
66 MakeRealName();
67 OpenForRead();
68 } // if
69
70 return isOpen;
71} // DiskIO::OpenForRead(string filename)
72
73// Open a disk for reading and writing by filename.
74// Returns 1 on success, 0 on failure.
srs56940a697312010-01-28 21:10:52 -050075int DiskIO::OpenForWrite(const string & filename) {
srs5694add79a62010-01-26 15:59:58 -050076 int retval = 0;
77
78 if ((isOpen) && (openForWrite) && ((filename == realFilename) || (filename == userFilename))) {
79 retval = 1;
80 } else {
81 userFilename = filename;
82 MakeRealName();
83 retval = OpenForWrite();
84 if (retval == 0) {
85 realFilename = userFilename = "";
86 } // if
87 } // if/else
88 return retval;
89} // DiskIO::OpenForWrite(string filename)