Tidying a few things up.
[libdcp.git] / src / key.cc
index 4fd087d31fcba8eba0d341f25f86c05eb750e8ea..a5e92aac67d75474d454b8976db5085233281b02 100644 (file)
@@ -1,5 +1,5 @@
 /*
-    Copyright (C) 2013-2014 Carl Hetherington <cth@carlh.net>
+    Copyright (C) 2013-2021 Carl Hetherington <cth@carlh.net>
 
     This file is part of libdcp.
 
     files in the program, then also delete it here.
 */
 
+
 /** @file  src/key.cc
- *  @brief Key class.
+ *  @brief Key class
  */
 
+
 #include "key.h"
-#include "AS_DCP.h"
-#include "KM_prng.h"
-#include "KM_util.h"
-#include <sstream>
+#include "dcp_assert.h"
+#include <asdcp/AS_DCP.h>
+#include <asdcp/KM_prng.h>
+#include <asdcp/KM_util.h>
 #include <string>
 #include <iomanip>
 
+
 using std::string;
-using std::stringstream;
 using std::setw;
 using std::setfill;
 using namespace dcp;
 
-Key::Key ()
-       : _value (new uint8_t[ASDCP::KeyLen])
+
+Key::Key (int length)
+       : _value (new uint8_t[length])
+       , _length (length)
 {
        Kumu::FortunaRNG rng;
-       rng.FillRandom (_value, ASDCP::KeyLen);
+       rng.FillRandom (_value, _length);
 }
 
-Key::Key (uint8_t const * value)
-       : _value (new uint8_t[ASDCP::KeyLen])
+
+Key::Key (uint8_t const * value, int length)
+       : _value (new uint8_t[length])
+       , _length (length)
 {
-       memcpy (_value, value, ASDCP::KeyLen);
+       memcpy (_value, value, _length);
 }
 
+
 Key::Key (string value)
-       : _value (new uint8_t[ASDCP::KeyLen])
+       : _value (new uint8_t[value.length() / 2])
+       , _length (value.length() / 2)
 {
-       unsigned int length;
-       Kumu::hex2bin (value.c_str(), _value, ASDCP::KeyLen, &length);
+       unsigned int length_done;
+       Kumu::hex2bin (value.c_str(), _value, _length, &length_done);
 }
 
+
 Key::Key (Key const & other)
-       : _value (new uint8_t[ASDCP::KeyLen])
+       : _value (new uint8_t[other._length])
+       , _length (other._length)
 {
-       memcpy (_value, other._value, ASDCP::KeyLen);
+       memcpy (_value, other._value, _length);
 }
 
+
 Key::~Key ()
 {
        delete[] _value;
 }
 
+
 Key &
 Key::operator= (Key const & other)
 {
@@ -87,28 +99,38 @@ Key::operator= (Key const & other)
                return *this;
        }
 
-       memcpy (_value, other._value, ASDCP::KeyLen);
+       _length = other._length;
+       memcpy (_value, other._value, _length);
        return *this;
 }
 
+
 string
 Key::hex () const
 {
-       stringstream g;
-
-       for (unsigned int i = 0; i < ASDCP::KeyLen; ++i) {
-               g << setw(2) << setfill('0') << std::hex << static_cast<int> (_value[i]);
+       char buffer[_length * 2 + 1];
+
+       char* p = buffer;
+       for (int i = 0; i < _length; ++i) {
+#ifdef LIBDCP_WINDOWS
+               __mingw_snprintf (p, 3, "%02hhx", _value[i]);
+#else
+               snprintf (p, 3, "%02hhx", _value[i]);
+#endif
+               p += 2;
        }
 
-       return g.str ();
+       return buffer;
 }
 
+
 bool
 dcp::operator== (Key const & a, Key const & b)
 {
-       return memcmp (a.value(), b.value(), ASDCP::KeyLen) == 0;
+       return a.length() == b.length() && memcmp(a.value(), b.value(), a.length()) == 0;
 }
 
+
 bool
 dcp::operator!= (Key const & a, Key const & b)
 {