aboutsummaryrefslogtreecommitdiff
path: root/Src/nde/android/IndexField.cpp
diff options
context:
space:
mode:
authorJef <jef@targetspot.com>2024-09-24 08:54:57 -0400
committerJef <jef@targetspot.com>2024-09-24 08:54:57 -0400
commit20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/nde/android/IndexField.cpp
parent537bcbc86291b32fc04ae4133ce4d7cac8ebe9a7 (diff)
downloadwinamp-20d28e80a5c861a9d5f449ea911ab75b4f37ad0d.tar.gz
Initial community commit
Diffstat (limited to 'Src/nde/android/IndexField.cpp')
-rw-r--r--Src/nde/android/IndexField.cpp142
1 files changed, 142 insertions, 0 deletions
diff --git a/Src/nde/android/IndexField.cpp b/Src/nde/android/IndexField.cpp
new file mode 100644
index 00000000..faf3cb49
--- /dev/null
+++ b/Src/nde/android/IndexField.cpp
@@ -0,0 +1,142 @@
+/* ---------------------------------------------------------------------------
+Nullsoft Database Engine
+--------------------
+codename: Near Death Experience
+--------------------------------------------------------------------------- */
+
+/* ---------------------------------------------------------------------------
+
+IndexField Class
+Android (linux) implementation
+
+Field data layout
+[4 bytes] Position
+[4 bytes] Data Type
+[1 byte] Name Length
+[Name Length bytes] Name (UTF-8)
+--------------------------------------------------------------------------- */
+
+#include "../nde.h"
+#include "../ndestring.h"
+//---------------------------------------------------------------------------
+IndexField::IndexField(unsigned char id, int Pos, int type, const char *FieldName)
+{
+ InitField();
+ Type = FIELD_INDEX;
+ Name = ndestring_wcsdup(FieldName);
+ ID = id;
+ Position = Pos;
+ DataType = type;
+}
+
+//---------------------------------------------------------------------------
+void IndexField::InitField(void)
+{
+ index = 0;
+ Type = FIELD_INDEX;
+ Name = NULL;
+ ID = 0;
+ Position = -1;
+ DataType = FIELD_UNKNOWN;
+}
+
+//---------------------------------------------------------------------------
+IndexField::IndexField()
+{
+ InitField();
+}
+
+//---------------------------------------------------------------------------
+IndexField::~IndexField()
+{
+ ndestring_release(Name);
+ delete index;
+}
+
+//---------------------------------------------------------------------------
+void IndexField::ReadTypedData(const uint8_t *data, size_t len)
+{
+ unsigned char c;
+ int pos=0;
+ CHECK_INT(len);
+ Position = GET_INT(); pos += 4;
+ CHECK_INT(len);
+ DataType = GET_INT(); pos += 4;
+ CHECK_CHAR(len);
+ c = GET_CHAR(); pos++;
+ if (c)
+ {
+ CHECK_BIN(len, c);
+ Name = ndestring_wcsndup((const char *)(data+pos), c);
+ }
+}
+
+//---------------------------------------------------------------------------
+void IndexField::WriteTypedData(uint8_t *data, size_t len)
+{
+ int pos=0;
+ CHECK_INT(len);
+ PUT_INT(Position); pos += 4;
+
+ CHECK_INT(len);
+ PUT_INT(DataType); pos += 4;
+ CHECK_CHAR(len);
+
+ CHECK_CHAR(len);
+
+ if (Name)
+ {
+ int string_length = strlen(Name);
+ if (string_length)
+ {
+ PUT_CHAR(string_length);
+ pos++;
+
+ CHECK_BIN(len, string_length);
+ PUT_BINARY(data, (const uint8_t *)Name, string_length, pos);
+ }
+ else
+ {
+ PUT_CHAR(0);
+ }
+ }
+ else
+ {
+ PUT_CHAR(0);
+ }
+}
+
+//---------------------------------------------------------------------------
+
+char *IndexField::GetIndexName(void)
+{
+ return Name;
+}
+
+//---------------------------------------------------------------------------
+size_t IndexField::GetDataSize(void)
+{
+ size_t s=9;
+ if (Name)
+ {
+ s+=strlen(Name);
+ }
+ s++;
+ return s;
+}
+
+//---------------------------------------------------------------------------
+int IndexField::Compare(Field * /*Entry*/)
+{
+ return 0;
+}
+
+//---------------------------------------------------------------------------
+int IndexField::TranslateToIndex(int Id, IndexField *toindex)
+{
+ if (index && toindex && toindex->index)
+ return index->TranslateIndex(Id, toindex->index);
+ return -1;
+}
+
+