172 lines
5.5 KiB
C++
172 lines
5.5 KiB
C++
// SPDX-License-Identifier: MIT
|
|
// Copyright 2010, SIL International, All rights reserved.
|
|
|
|
#pragma once
|
|
#include "inc/Main.h"
|
|
#include "inc/FeatureVal.h"
|
|
|
|
namespace graphite2 {
|
|
|
|
// Forward declarations for implmentation types
|
|
class FeatureMap;
|
|
class Face;
|
|
|
|
|
|
class FeatureSetting
|
|
{
|
|
public:
|
|
FeatureSetting(int16_t theValue, uint16_t labelId) : m_label(labelId), m_value(theValue) {};
|
|
uint16_t label() const { return m_label; }
|
|
int16_t value() const { return m_value; }
|
|
|
|
CLASS_NEW_DELETE;
|
|
private:
|
|
FeatureSetting(const FeatureSetting & fs) : m_label(fs.m_label), m_value(fs.m_value) {};
|
|
|
|
uint16_t m_label;
|
|
int16_t m_value;
|
|
};
|
|
|
|
class FeatureRef
|
|
{
|
|
typedef uint32_t chunk_t;
|
|
static const uint8_t SIZEOF_CHUNK = sizeof(chunk_t)*8;
|
|
|
|
public:
|
|
FeatureRef() throw();
|
|
FeatureRef(const Face & face, unsigned short & bits_offset, uint32_t max_val,
|
|
uint32_t name, uint16_t uiName, uint16_t flags,
|
|
FeatureSetting *settings, uint16_t num_set) throw();
|
|
~FeatureRef() throw();
|
|
|
|
bool applyValToFeature(uint32_t val, Features& pDest) const; //defined in GrFaceImp.h
|
|
void maskFeature(Features & pDest) const {
|
|
if (m_index < pDest.size()) //defensive
|
|
pDest[m_index] |= m_mask;
|
|
}
|
|
|
|
uint32_t getFeatureVal(const Features& feats) const; //defined in GrFaceImp.h
|
|
|
|
uint32_t getId() const { return m_id; }
|
|
uint16_t getNameId() const { return m_nameid; }
|
|
uint16_t getNumSettings() const { return m_numSet; }
|
|
uint16_t getSettingName(uint16_t index) const { return m_nameValues[index].label(); }
|
|
int16_t getSettingValue(uint16_t index) const { return m_nameValues[index].value(); }
|
|
uint32_t maxVal() const { return m_max; }
|
|
const Face & getFace() const { assert(m_face); return *m_face;}
|
|
const FeatureMap* getFeatureMap() const;// { return m_pFace;}
|
|
|
|
CLASS_NEW_DELETE;
|
|
private:
|
|
FeatureRef(const FeatureRef & rhs);
|
|
|
|
const Face * m_face;
|
|
FeatureSetting * m_nameValues; // array of name table ids for feature values
|
|
chunk_t m_mask, // bit mask to get the value from the vector
|
|
m_max; // max value the value can take
|
|
uint32_t m_id; // feature identifier/name
|
|
uint16_t m_nameid, // Name table id for feature name
|
|
m_flags, // feature flags (unused at the moment but read from the font)
|
|
m_numSet; // number of values (number of entries in m_nameValues)
|
|
byte m_bits, // how many bits to shift the value into place
|
|
m_index; // index into the array to find the ulong to mask
|
|
|
|
private: //unimplemented
|
|
FeatureRef& operator=(const FeatureRef&);
|
|
};
|
|
|
|
inline
|
|
FeatureRef::FeatureRef() throw()
|
|
: m_face(0),
|
|
m_nameValues(0),
|
|
m_mask(0), m_max(0),
|
|
m_id(0),
|
|
m_nameid(0), m_flags(0), m_numSet(0),
|
|
m_bits(0), m_index(0)
|
|
{
|
|
}
|
|
|
|
|
|
class NameAndFeatureRef
|
|
{
|
|
public:
|
|
NameAndFeatureRef(uint32_t name = 0) : m_name(name) , m_pFRef(NULL){}
|
|
NameAndFeatureRef(FeatureRef const & p) : m_name(p.getId()), m_pFRef(&p) {}
|
|
|
|
bool operator<(const NameAndFeatureRef& rhs) const //orders by m_name
|
|
{ return m_name<rhs.m_name; }
|
|
|
|
CLASS_NEW_DELETE
|
|
|
|
uint32_t m_name;
|
|
const FeatureRef* m_pFRef;
|
|
};
|
|
|
|
class FeatureMap
|
|
{
|
|
public:
|
|
FeatureMap() : m_numFeats(0), m_feats(NULL), m_pNamedFeats(NULL) {}
|
|
~FeatureMap() { delete[] m_feats; delete[] m_pNamedFeats; }
|
|
|
|
bool readFeats(const Face & face);
|
|
const FeatureRef *findFeatureRef(uint32_t name) const;
|
|
FeatureRef *feature(uint16_t index) const { return m_feats + index; }
|
|
//GrFeatureRef *featureRef(byte index) { return index < m_numFeats ? m_feats + index : NULL; }
|
|
const FeatureRef *featureRef(byte index) const { return index < m_numFeats ? m_feats + index : NULL; }
|
|
FeatureVal* cloneFeatures(uint32_t langname/*0 means default*/) const; //call destroy_Features when done.
|
|
uint16_t numFeats() const { return m_numFeats; };
|
|
CLASS_NEW_DELETE
|
|
private:
|
|
friend class SillMap;
|
|
uint16_t m_numFeats;
|
|
|
|
FeatureRef *m_feats;
|
|
NameAndFeatureRef* m_pNamedFeats; //owned
|
|
FeatureVal m_defaultFeatures; //owned
|
|
|
|
private: //defensive on m_feats, m_pNamedFeats, and m_defaultFeatures
|
|
FeatureMap(const FeatureMap&);
|
|
FeatureMap& operator=(const FeatureMap&);
|
|
};
|
|
|
|
|
|
class SillMap
|
|
{
|
|
private:
|
|
class LangFeaturePair
|
|
{
|
|
LangFeaturePair(const LangFeaturePair &);
|
|
LangFeaturePair & operator = (const LangFeaturePair &);
|
|
|
|
public:
|
|
LangFeaturePair() : m_lang(0), m_pFeatures(0) {}
|
|
~LangFeaturePair() { delete m_pFeatures; }
|
|
|
|
uint32_t m_lang;
|
|
Features* m_pFeatures; //owns
|
|
CLASS_NEW_DELETE
|
|
};
|
|
public:
|
|
SillMap() : m_langFeats(NULL), m_numLanguages(0) {}
|
|
~SillMap() { delete[] m_langFeats; }
|
|
bool readFace(const Face & face);
|
|
bool readSill(const Face & face);
|
|
FeatureVal* cloneFeatures(uint32_t langname/*0 means default*/) const; //call destroy_Features when done.
|
|
uint16_t numLanguages() const { return m_numLanguages; };
|
|
uint32_t getLangName(uint16_t index) const { return (index < m_numLanguages)? m_langFeats[index].m_lang : 0; };
|
|
|
|
const FeatureMap & theFeatureMap() const { return m_FeatureMap; };
|
|
private:
|
|
FeatureMap m_FeatureMap; //of face
|
|
LangFeaturePair * m_langFeats;
|
|
uint16_t m_numLanguages;
|
|
|
|
private: //defensive on m_langFeats
|
|
SillMap(const SillMap&);
|
|
SillMap& operator=(const SillMap&);
|
|
};
|
|
|
|
} // namespace graphite2
|
|
|
|
struct gr_feature_ref : public graphite2::FeatureRef {};
|