summaryrefslogtreecommitdiff
path: root/protocols/Xfire/src/variablevalue.cpp
diff options
context:
space:
mode:
authorGeorge Hazan <george.hazan@gmail.com>2015-08-11 13:33:42 +0000
committerGeorge Hazan <george.hazan@gmail.com>2015-08-11 13:33:42 +0000
commit85bd008c039eb1d93894e94fba9d158a42a71a12 (patch)
tree2d72d10759f6928e9e4b960175d2de01b5cf7e12 /protocols/Xfire/src/variablevalue.cpp
parent222802c2986dcaf029fdfb828b7679bdabfa7bb2 (diff)
massive code cleaning
git-svn-id: http://svn.miranda-ng.org/main/trunk@14910 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/Xfire/src/variablevalue.cpp')
-rw-r--r--protocols/Xfire/src/variablevalue.cpp333
1 files changed, 160 insertions, 173 deletions
diff --git a/protocols/Xfire/src/variablevalue.cpp b/protocols/Xfire/src/variablevalue.cpp
index 0de417cffd..6d3050da34 100644
--- a/protocols/Xfire/src/variablevalue.cpp
+++ b/protocols/Xfire/src/variablevalue.cpp
@@ -22,184 +22,171 @@
#include "stdafx.h"
-#include <string>
#include "variablevalue.h"
#include "xdebug.h"
#include "math.h" // for pow(..)
-namespace xfirelib {
-
using namespace std;
- VariableValue::VariableValue() {
- value = 0;
- }
- VariableValue::~VariableValue() {
- if (value)
- delete[] value;
- }
-
- void VariableValue::setName(std::string name){
- this->name = name;
- }
-
- void VariableValue::setValueLength(int valueLength){
- this->valueLength = valueLength;
- }
-
- void VariableValue::setValue( char * value) {
- if (this->value) delete[] this->value;
- this->value = value;
- }
- void VariableValue::setValue( std::string value ) {
- const char *val = value.c_str();
- setValue( val, value.length() );
- }
- void VariableValue::setValue( const char *value, int valueLength ) {
- this->value = new char[valueLength];
- memcpy( this->value, value, valueLength );
- this->valueLength = valueLength;
- }
- void VariableValue::setValueFromLong( long value, int bytes ) {
- this->valueLength = bytes;
- this->value = new char[bytes];
- for(int i = 0 ; i < bytes ; i++) {
- this->value[i] = value % 256;
- value = value / 256;
- }
- }
-
- std::string VariableValue::getName(){
- return name;
- }
-
- int VariableValue::getValueLength(){
- return valueLength;
- }
-
- char* VariableValue::getValue(){
- return value;
- }
-
- long VariableValue::getValueAsLong() {
- long intVal = 0;
- for(int i = 0 ; i < valueLength ; i++) {
- intVal += ((unsigned char)value[i]) * myPow(256,i);
- }
- return intVal;
- }
-
- long VariableValue::myPow(int x, int y) {
- long r = 1;
- for(int i = 0 ; i < y ; i++) r *= x;
- return r;
- }
-
- int VariableValue::readName(char *packet, int index) {
- int read = 0;
- int nameLength = packet[index];
- read++;
- char* namestr=new char[nameLength+1];
- namestr[nameLength]=0;
- memcpy(namestr,packet+index+read,nameLength);
- name = string(namestr);
- read+=nameLength;
- delete[] namestr;
- return read;
- }
-
- int VariableValue::readValue(char *packet, int index, int length,int ignoreZeroAfterLength) {
- int read = 0;
- valueLength = length;
- if (valueLength < 0) {
- valueLength = (unsigned char)packet[index+read];read++;
- if (ignoreZeroAfterLength) read++;
- }
-
- if (value) delete[] value;
- value = new char[valueLength];
- memcpy(value,packet+index+read,valueLength);
- read+=valueLength;
-
- return read;
- }
-
-/*TODO: this cant work, attLength is always 0, needs to be fixed*/
-/* int VariableValue::readFixValue(char *packet, int index, int packetLength, int valueLength) {
- VariableValue *value = this;
- int nameLength = packet[index];
-
- int i = 1;
- int attLengthLength = 0;
- int attLength = 0;
- string name;
-
- for(; i <= nameLength;i++){
- name += packet[index+i];
- }
- value->setName(name);
- index += i;
- index++; //ignore next value
-
- value->setValueLength(valueLength);
-
- char *att = new char[attLength];
- index += i+1;
- for(i = 0; i < attLength;i++){
- att[i] = packet[index+i];
- }
- index += i;
- value->setValue(att);
- return index;
- }*/
-
-
- int VariableValue::readVariableValue(char *packet, int index, int packetLength){
- VariableValue *value = this;
- int nameLength = packet[index];
-
- int i = 1;
- int attLengthLength = 0;
- int attLength = 0;
- string name;
-
- for(; i <= nameLength;i++){
- name += packet[index+i];
- }
- value->setName(name);
-
- index += i;
- attLengthLength = packet[index];
- index++;
-
- for(i = 0; i < attLengthLength;i++){
- attLength += (unsigned char)packet[index+i];/*todo: make it work if length is longer than 1 byte*/
- }
- value->setValueLength(attLength);
-
- char *att = new char[attLength];
- index += i+1;
- for(i = 0; i < attLength;i++){
- att[i] = packet[index+i];
- }
- value->setValue(att);
- index += i;
- return index;
- }
-
-
-
-
- int VariableValue::writeName(char *buf, int index) {
- int len = name.length();
- buf[index] = len;
- memcpy(buf+index+1,name.c_str(),len);
- return len+1;
- }
- int VariableValue::writeValue(char *buf, int index) {
- memcpy(buf+index,value,valueLength);
- return valueLength;
- }
-
+namespace xfirelib
+{
+ VariableValue::VariableValue()
+ {
+ value = 0;
+ }
+
+ VariableValue::~VariableValue()
+ {
+ if (value)
+ delete[] value;
+ }
+
+ void VariableValue::setName(std::string name)
+ {
+ this->name = name;
+ }
+
+ void VariableValue::setValueLength(int valueLength)
+ {
+ this->valueLength = valueLength;
+ }
+
+ void VariableValue::setValue(char * value)
+ {
+ if (this->value) delete[] this->value;
+ this->value = value;
+ }
+
+ void VariableValue::setValue(std::string value)
+ {
+ const char *val = value.c_str();
+ setValue(val, value.length());
+ }
+
+ void VariableValue::setValue(const char *value, int valueLength)
+ {
+ this->value = new char[valueLength];
+ memcpy(this->value, value, valueLength);
+ this->valueLength = valueLength;
+ }
+
+ void VariableValue::setValueFromLong(long value, int bytes)
+ {
+ this->valueLength = bytes;
+ this->value = new char[bytes];
+ for (int i = 0; i < bytes; i++) {
+ this->value[i] = value % 256;
+ value = value / 256;
+ }
+ }
+
+ std::string VariableValue::getName()
+ {
+ return name;
+ }
+
+ int VariableValue::getValueLength()
+ {
+ return valueLength;
+ }
+
+ char* VariableValue::getValue()
+ {
+ return value;
+ }
+
+ long VariableValue::getValueAsLong()
+ {
+ long intVal = 0;
+ for (int i = 0; i < valueLength; i++) {
+ intVal += ((unsigned char)value[i]) * myPow(256, i);
+ }
+ return intVal;
+ }
+
+ long VariableValue::myPow(int x, int y)
+ {
+ long r = 1;
+ for (int i = 0; i < y; i++) r *= x;
+ return r;
+ }
+
+ int VariableValue::readName(char *packet, int index)
+ {
+ int read = 0;
+ int nameLength = packet[index];
+ read++;
+ char* namestr = new char[nameLength + 1];
+ namestr[nameLength] = 0;
+ memcpy(namestr, packet + index + read, nameLength);
+ name = string(namestr);
+ read += nameLength;
+ delete[] namestr;
+ return read;
+ }
+
+ int VariableValue::readValue(char *packet, int index, int length, int ignoreZeroAfterLength)
+ {
+ int read = 0;
+ valueLength = length;
+ if (valueLength < 0) {
+ valueLength = (unsigned char)packet[index + read]; read++;
+ if (ignoreZeroAfterLength) read++;
+ }
+
+ if (value) delete[] value;
+ value = new char[valueLength];
+ memcpy(value, packet + index + read, valueLength);
+ read += valueLength;
+
+ return read;
+ }
+
+ int VariableValue::readVariableValue(char *packet, int index, int)
+ {
+ VariableValue *value = this;
+ int nameLength = packet[index];
+
+ int i = 1;
+ int attLengthLength = 0;
+ int attLength = 0;
+ string name;
+
+ for (; i <= nameLength; i++) {
+ name += packet[index + i];
+ }
+ value->setName(name);
+
+ index += i;
+ attLengthLength = packet[index];
+ index++;
+
+ for (i = 0; i < attLengthLength; i++)
+ attLength += (unsigned char)packet[index + i];/*todo: make it work if length is longer than 1 byte*/
+
+ value->setValueLength(attLength);
+
+ char *att = new char[attLength];
+ index += i + 1;
+ for (i = 0; i < attLength; i++)
+ att[i] = packet[index + i];
+
+ value->setValue(att);
+ index += i;
+ return index;
+ }
+
+ int VariableValue::writeName(char *buf, int index)
+ {
+ int len = name.length();
+ buf[index] = len;
+ memcpy(buf + index + 1, name.c_str(), len);
+ return len + 1;
+ }
+ int VariableValue::writeValue(char *buf, int index)
+ {
+ memcpy(buf + index, value, valueLength);
+ return valueLength;
+ }
};