Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/lib/util/filesys/file.cc @ 8330

Last change on this file since 8330 was 8330, checked in by bensch, 18 years ago

moved the File-Classes

File size: 7.3 KB
RevLine 
[7609]1/*
2   orxonox - the future of 3D-vertical-scrollers
3
4   Copyright (C) 2004 orx
5
6   This program is free software; you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation; either version 2, or (at your option)
9   any later version.
10
11### File Specific:
12   main-programmer: Benjamin Grauer
13   co-programmer: ...
14*/
15
[7611]16#include "file.h"
[7609]17
[7615]18#include <sys/types.h>
19#include <sys/stat.h>
[7616]20#include <stdio.h>
[7615]21
[7616]22#include <iostream>
23#include <fstream>
24
[8293]25#ifdef __unix__
[7611]26#include <unistd.h>
27#elif __WIN32__ || _MS_DOS_
28#include <dir.h>
29#else
[8293]30//#include <direct.h>
[7611]31#endif
32
[7616]33#include <cassert>
[7611]34
[7623]35/**
36 * @brief default constructor.
37 */
[7621]38File::File()
39{
40  this->init();
41}
[7611]42
[7623]43/**
44 * @brief A File will be constructed and stated from a given FileName.
45 * @param fileName the FileName to load and stat.
46 */
[7611]47File::File(const std::string& fileName)
48{
[7616]49  this->init();
[7621]50  this->setFileName(fileName);
[7611]51}
52
[7623]53/**
54 * @brief A File will be constructed and stated from a given other File.
55 * @param file the File to get the Name from.
56 */
[7611]57File::File(const File& file)
58{
[7621]59  this->init();
60  this->setFileName(file.name());
[7611]61}
62
63File::~File()
64{
[7621]65  this->close();
66
[7616]67  if (this->_status)
68    delete this->_status;
[7611]69}
70
[7621]71
[7616]72/**
73 * @brief initializes the File
74 *
75 * Stats the File, looks if it exists and sets the hadle to 0
76 */
77void File::init()
78{
79  this->_handle = 0;
[7621]80  this->_status = NULL;
81}
[7616]82
[7621]83
84/**
85 * @brief sets a new File to apply to this File.
86 * @param fileName the Filename of the File to access.
87 */
88void File::setFileName(const std::string& fileName)
89{
90  this->close();
91  this->_name = fileName;
92  File::homeDirCheck(this->_name);
93  this->statFile();
94}
95
[7622]96/**
97 * @brief sets the file to the new File.
98 * @param fileName the FileName to set the File to.
99 * @returns this File.
100 */
101File& File::operator=(const std::string& fileName)
102{
103  this->setFileName(fileName);
104  return *this;
105}
[7621]106
[7622]107/**
108 * @brief sets the file to the new File.
109 * @param file the File to set the File to.
110 * @returns this File.
111 */
112File& File::operator=(const File& file)
113{
114  this->setFileName(file.name());
115  return *this;
116}
117
118/**
119 * @brief compares two files.
120 * @param fileName the File to compare against the stored one.
121 * @returns true if the filenames match.
122 */
123bool File::operator==(const std::string& fileName) const
124{
125  return (this->_name == fileName);
126}
127
128/**
129 * @brief compares two files.
130 * @param file the File to compare against the stored one.
131 * @returns true if the filenames match.
132 */
133bool File::operator==(const File& file) const
134{
135  return (this->_name == file.name());
136}
137
138
139/**
140 * @brief stats a File.
141 * Gathers information about the File, like permissions, and if it exists.
142 */
[7621]143void File::statFile()
144{
145  if (this->_status == NULL)
146    this->_status = new struct stat;
[7618]147  // Check the End of the FileName and chop away any \ and //
[7673]148  std::string name = this->_name;
149  while (name[name.size()-1] == '/' ||
150         name[name.size()-1] == '\\')
151    name.resize(name.size()-1);
152  if (stat(name.c_str(), this->_status))
[7616]153  {
154    delete this->_status;
155    this->_status = NULL;
156  }
157}
158
[7611]159bool File::open(OpenMode mode)
160{
161#warning implement
[8276]162  return false;
[7611]163}
[7615]164
[7611]165bool File::close()
166{
167#warning implement
[8276]168  return false;
[7611]169}
[7615]170
[7620]171bool File::exists() const
[7611]172{
[7616]173  return (this->_status != NULL);
[7611]174}
[7615]175
[7621]176/**
177 * @brief checks if the file is a Link (symlink/hardlink on UNIX)
178 * @returns true if the File is a Link, false otherwise (on windows always false)
179 */
[7620]180bool File::isLink() const
[7611]181{
[7616]182#ifndef __WIN32__
183  return (this->_status != NULL && this->_status->st_mode & (S_IFLNK));
184#else
185  return false;
186#endif
[7615]187}
[7616]188
[7621]189/**
190 * @brief checks if the File is a regular File
191 * @returns true if the File is a Regular file.
192 */
[7620]193bool File::isFile() const
[7611]194{
[7616]195  return (this->_status != NULL && this->_status->st_mode & (S_IFREG));
[7611]196}
[7615]197
[7616]198/**
[7621]199 * @brief Checks if the File is a Directory
[7616]200 * @returns true if it is a directory/symlink false otherwise
201 */
[7620]202bool File::isDirectory() const
[7611]203{
[7616]204  return (this->_status != NULL && this->_status->st_mode & (S_IFDIR));
[7611]205}
[7612]206
[7616]207
208/// FIXME NEXT THREE FUNCTIONS
[7620]209bool File::isReadeable() const
[7611]210{
[7616]211#ifndef __WIN32__
212  return (this->_status != NULL && this->_status->st_mode & (S_IRUSR));
213#else
214  return (this->_status != NULL);
215#endif
[7611]216}
[7620]217bool File::isWriteable() const
[7611]218{
[7616]219#ifndef __WIN32__
220  return (this->_status != NULL && this->_status->st_mode & (S_IWUSR));
221#else
222  return (this->_status != NULL);
223#endif
[7611]224}
[7620]225bool File::isExecutable() const
[7611]226{
[7616]227#ifndef __WIN32__
228  return (this->_status != NULL && this->_status->st_mode & (S_IXUSR));
229#else
230  return (this->_status != NULL);
231#endif
[7611]232}
233
[7621]234/**
235 * @brief copies the File to another File.
236 * @param destination the Destination File.
237 * @returns true on success, false otherwise.
238 */
[7611]239bool File::copy(const File& destination)
240{
[7623]241  if (*this == destination)
242  {
243    std::cout << "files are the Same '" << this->_name << "'\n";
244    return false;
245  }
[7616]246  char ch;
247  std::ifstream iFile(this->_name.c_str());
248  std::ofstream oFile(destination.name().c_str());
249  while (iFile.get(ch))
250  {
251    oFile.put(ch);
252  }
[8276]253  return true;
[7611]254}
[7616]255
[7621]256/**
257 * @brief renames the File (move)
258 * @param destination the Destination to move this file to.
259 * @returns true on success, false otherwise.
260 *
261 * if the File was opened, it will be closed throuh this function.
[7624]262 * The File will also be closed, if the File was not renamed.
[7621]263 */
[7611]264bool File::rename(const File& destination)
265{
[7624]266  this->close();
267
[7616]268  if (!std::rename(this->_name.c_str(), destination.name().c_str()))
269  {
270    this->_name = destination.name();
[7621]271    this->statFile();
[7616]272    return true;
273  }
274  return false;
[7611]275}
[7616]276
[7621]277/**
278 * @brief touches the File.
279 * @returns true if the file could have been touched. false otherwise.
280 *
281 * Touching a File means creating it.
282 */
[7611]283bool File::touch()
284{
[7616]285  FILE* stream;
286  if( (stream = fopen (this->_name.c_str(), "w")) == NULL)
287  {
288    std::cout << "could not touch '" << this->_name << "' for writing\n";
289    return false;
290  }
291  fclose(stream);
[7624]292
293  this->statFile();
[7616]294  return true;
[7611]295}
[7616]296
[7621]297/**
298 * @brief delete the File on the Disk
299 * @returns true on success, false otherwise.
300 */
[7611]301bool File::remove()
302{
[8276]303  if (!this->exists())
304    return false;
305
[7623]306  this->close();
[7616]307  unlink(this->_name.c_str());
308  delete this->_status;
309  this->_status = NULL;
[8276]310
311  return true;
[7611]312}
313
[7621]314/**
315 * @brief transforms a Relative path to an absolute one.
316 * @param fileName the Absolute Path.
317 */
318void File::relToAbs(std::string& relFileName)
[7611]319{
[7621]320  if (relFileName.empty())
[7616]321    return ;
[7621]322  if (relFileName[0] !=  '/')
[7616]323  {
[7621]324    if (relFileName[0] == '.' && relFileName[1] != '.')
325      relFileName.erase(0);
326    relFileName = File::cwd() + relFileName;
[7616]327  }
[7611]328}
[7616]329
[7621]330void File::absToRel(std::string& absFileName)
[7611]331{
[7621]332  if (absFileName.find(cwd()) == 0)
333    absFileName.replace(0, File::cwd().size(), ".");
[7611]334}
335
336
337std::string File::_cwd = "";
338
339/**
340 * @returns the Current Woring Directory
341 */
342const std::string& File::cwd()
343{
344  if (File::_cwd.empty())
345  {
346    char cwd[1024];
347    char* errorCode = getcwd(cwd, 1024);
348    if (errorCode == 0)
349      return File::_cwd;
350
351    File::_cwd = cwd;
352  }
353  return File::_cwd;
354}
355
[7621]356/**
357 * @brief check if fileName has the '~/` prepended.
358 * @returns the fileName in absolute coordinate.
359 */
[7616]360void File::homeDirCheck(std::string& fileName)
361{
362  if (fileName.size() < 2 || fileName[0] != '~' || fileName[1] != '/')
363    return;
364  std::string homeDir;
365#ifdef __WIN32__
[7619]366  homeDir = getenv("USERPROFILE");
[7616]367#else
[7619]368  homeDir = getenv("HOME");
[7616]369#endif
[7619]370  fileName = homeDir + fileName.substr(1);
[7616]371}
[7611]372
[7616]373
[7611]374#include "file.h"
375
376
Note: See TracBrowser for help on using the repository browser.