You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
159 lines
5.9 KiB
C++
159 lines
5.9 KiB
C++
20 years ago
|
// ***************************************************************** -*- C++ -*-
|
||
|
/*
|
||
|
* Copyright (C) 2005 Andreas Huggel <ahuggel@gmx.net>
|
||
|
*
|
||
|
* This program is part of the Exiv2 distribution.
|
||
|
*
|
||
|
* 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.
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License
|
||
|
* along with this program; if not, write to the Free Software
|
||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||
|
*/
|
||
|
/*!
|
||
|
@file sonymn.hpp
|
||
|
@brief Basic Sony MakerNote implementation
|
||
|
@version $Rev$
|
||
|
@author Andreas Huggel (ahu)
|
||
|
<a href="mailto:ahuggel@gmx.net">ahuggel@gmx.net</a>
|
||
|
@date 18-Apr-05, ahu: created
|
||
|
*/
|
||
|
#ifndef SONYMN_HPP_
|
||
|
#define SONYMN_HPP_
|
||
|
|
||
|
// *****************************************************************************
|
||
|
// included header files
|
||
|
#include "types.hpp"
|
||
|
#include "makernote.hpp"
|
||
|
#include "tags.hpp"
|
||
|
|
||
|
// + standard includes
|
||
|
#include <string>
|
||
|
#include <iosfwd>
|
||
|
#include <memory>
|
||
|
|
||
|
// *****************************************************************************
|
||
|
// namespace extensions
|
||
|
namespace Exiv2 {
|
||
|
|
||
|
// *****************************************************************************
|
||
|
// class declarations
|
||
|
class Value;
|
||
|
|
||
|
// *****************************************************************************
|
||
|
// free functions
|
||
|
|
||
|
/*!
|
||
|
@brief Return an auto-pointer to a newly created empty MakerNote
|
||
|
initialized to operate in the memory management model indicated.
|
||
|
The caller owns this copy and the auto-pointer ensures that it
|
||
|
will be deleted.
|
||
|
|
||
|
@param alloc Memory management model for the new MakerNote. Determines if
|
||
|
memory required to store data should be allocated and deallocated
|
||
|
(true) or not (false). If false, only pointers to the buffer
|
||
|
provided to read() will be kept. See Ifd for more background on
|
||
|
this concept.
|
||
|
@param buf Pointer to the makernote character buffer (not used).
|
||
|
@param len Length of the makernote character buffer (not used).
|
||
|
@param byteOrder Byte order in which the Exif data (and possibly the
|
||
|
makernote) is encoded (not used).
|
||
|
@param offset Offset from the start of the TIFF header of the makernote
|
||
|
buffer (not used).
|
||
|
|
||
|
@return An auto-pointer to a newly created empty MakerNote. The caller
|
||
|
owns this copy and the auto-pointer ensures that it will be
|
||
|
deleted.
|
||
|
*/
|
||
|
MakerNote::AutoPtr createSonyMakerNote(bool alloc,
|
||
|
const byte* buf,
|
||
|
long len,
|
||
|
ByteOrder byteOrder,
|
||
|
long offset);
|
||
|
|
||
|
// *****************************************************************************
|
||
|
// class definitions
|
||
|
|
||
|
//! MakerNote for Sony cameras
|
||
|
class SonyMakerNote : public IfdMakerNote {
|
||
|
public:
|
||
|
//! Shortcut for a %SonyMakerNote auto pointer.
|
||
|
typedef std::auto_ptr<SonyMakerNote> AutoPtr;
|
||
|
|
||
|
//! @name Creators
|
||
|
//@{
|
||
|
/*!
|
||
|
@brief Constructor. Allows to choose whether or not memory management
|
||
|
is required for the makernote entries.
|
||
|
*/
|
||
|
SonyMakerNote(bool alloc =true);
|
||
|
//! Copy constructor
|
||
|
SonyMakerNote(const SonyMakerNote& rhs);
|
||
|
//! Virtual destructor
|
||
|
virtual ~SonyMakerNote() {}
|
||
|
//@}
|
||
|
|
||
|
//! @name Manipulators
|
||
|
//@{
|
||
|
int readHeader(const byte* buf,
|
||
|
long len,
|
||
|
ByteOrder byteOrder);
|
||
|
//@}
|
||
|
|
||
|
//! @name Accessors
|
||
|
//@{
|
||
|
int checkHeader() const;
|
||
|
AutoPtr create(bool alloc =true) const;
|
||
|
AutoPtr clone() const;
|
||
|
//@}
|
||
|
|
||
|
private:
|
||
|
//! Internal virtual create function.
|
||
|
SonyMakerNote* create_(bool alloc =true) const;
|
||
|
//! Internal virtual copy constructor.
|
||
|
SonyMakerNote* clone_() const;
|
||
|
|
||
|
//! Tag information
|
||
|
static const TagInfo tagInfo_[];
|
||
|
|
||
|
//! Structure used to auto-register the MakerNote.
|
||
|
struct RegisterMakerNote {
|
||
|
//! Default constructor
|
||
|
RegisterMakerNote()
|
||
|
{
|
||
|
MakerNoteFactory& mnf = MakerNoteFactory::instance();
|
||
|
mnf.registerMakerNote("SONY", "*", createSonyMakerNote);
|
||
|
mnf.registerMakerNote(sonyIfdId,
|
||
|
MakerNote::AutoPtr(new SonyMakerNote));
|
||
|
ExifTags::registerMakerTagInfo(sonyIfdId, tagInfo_);
|
||
|
}
|
||
|
};
|
||
|
// DATA
|
||
|
/*!
|
||
|
The static member variable is initialized before main (see note) and
|
||
|
will in the process register the MakerNote class. (Remember the
|
||
|
definition of the variable in the implementation file!)
|
||
|
|
||
|
@note The standard says that, if no function is explicitly called ever
|
||
|
in a module, then that module's static data might be never
|
||
|
initialized. This clause was introduced to allow dynamic link
|
||
|
libraries. The idea is, with this clause the loader is not
|
||
|
forced to eagerly load all modules, but load them only on
|
||
|
demand.
|
||
|
*/
|
||
|
static const RegisterMakerNote register_;
|
||
|
|
||
|
}; // class SonyMakerNote
|
||
|
|
||
|
} // namespace Exiv2
|
||
|
|
||
|
#endif // #ifndef SONYMN_HPP_
|