Compare commits

...

4 Commits

  1. 2
      .gitignore
  2. 4
      CommandDetector.pro
  3. 80
      CommandDetector.pro.user
  4. 28
      logic/include/BaseDecoder.h
  5. 17
      logic/include/CommandDecoder.h
  6. 27
      logic/include/CommandsType.h
  7. 2
      logic/logic.pro
  8. 6
      logic/src/BaseDecoder.cpp
  9. 82
      logic/src/CommandDecoder.cpp
  10. 7
      test/include/CommandDecoderTest.h
  11. 129
      test/src/CommandDecoderTest.cpp
  12. 8
      test/src/main.cpp
  13. 37
      ui/main.cpp
  14. 31
      ui/ui.pro

2
.gitignore

@ -0,0 +1,2 @@
*.pro.user

4
CommandDetector.pro

@ -2,6 +2,8 @@ TEMPLATE = subdirs
SUBDIRS += \
logic \
test
test \
ui
test.depends += logic
ui.depends += logic

80
CommandDetector.pro.user

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE QtCreatorProject>
<!-- Written by QtCreator 4.10.0, 2022-10-11T09:57:58. -->
<!-- Written by QtCreator 4.10.0, 2022-11-20T18:21:25. -->
<qtcreator>
<data>
<variable>EnvironmentId</variable>
@ -65,7 +65,7 @@
<value type="QString" key="ProjectExplorer.ProjectConfiguration.DefaultDisplayName">Desktop Qt 5.13.1 GCC 64bit</value>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.DisplayName">Desktop Qt 5.13.1 GCC 64bit</value>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.Id">qt.qt5.5131.gcc_64_kit</value>
<value type="int" key="ProjectExplorer.Target.ActiveBuildConfiguration">1</value>
<value type="int" key="ProjectExplorer.Target.ActiveBuildConfiguration">0</value>
<value type="int" key="ProjectExplorer.Target.ActiveDeployConfiguration">0</value>
<value type="int" key="ProjectExplorer.Target.ActiveRunConfiguration">0</value>
<valuemap type="QVariantMap" key="ProjectExplorer.Target.BuildConfiguration.0">
@ -304,9 +304,75 @@
<value type="int" key="PE.EnvironmentAspect.Base">2</value>
<valuelist type="QVariantList" key="PE.EnvironmentAspect.Changes"/>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.DefaultDisplayName">test</value>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.DisplayName"></value>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.Id">Qt4ProjectManager.Qt4RunConfiguration:/home/hasis/Desktop/Nastaran/TRAIN/TaskLearning2/CommandDetector/test/test.pro</value>
<value type="QString" key="RunConfiguration.Arguments">-node 3 -d 5 -g -f 2</value>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.DisplayName">test2</value>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.Id">Qt4ProjectManager.Qt4RunConfiguration:/home/hasis/Desktop/Nastaran/TRAIN/TaskLearning3/CommandDetector/test/test.pro</value>
<value type="QString" key="RunConfiguration.Arguments"></value>
<value type="uint" key="RunConfiguration.QmlDebugServerPort">3768</value>
<value type="bool" key="RunConfiguration.UseCppDebugger">false</value>
<value type="bool" key="RunConfiguration.UseCppDebuggerAuto">true</value>
<value type="bool" key="RunConfiguration.UseLibrarySearchPath">true</value>
<value type="bool" key="RunConfiguration.UseMultiProcess">false</value>
<value type="bool" key="RunConfiguration.UseQmlDebugger">false</value>
<value type="bool" key="RunConfiguration.UseQmlDebuggerAuto">true</value>
<value type="QString" key="RunConfiguration.WorkingDirectory"></value>
<value type="QString" key="RunConfiguration.WorkingDirectory.default">/home/hasis/Desktop/Nastaran/TRAIN/TaskLearning2/build-CommandDetector-Desktop_Qt_5_13_1_GCC_64bit-Debug/test</value>
</valuemap>
<valuemap type="QVariantMap" key="ProjectExplorer.Target.RunConfiguration.1">
<value type="QString" key="Analyzer.Perf.CallgraphMode">dwarf</value>
<valuelist type="QVariantList" key="Analyzer.Perf.Events">
<value type="QString">cpu-cycles</value>
</valuelist>
<valuelist type="QVariantList" key="Analyzer.Perf.ExtraArguments"/>
<value type="int" key="Analyzer.Perf.Frequency">250</value>
<value type="QString" key="Analyzer.Perf.SampleMode">-F</value>
<value type="bool" key="Analyzer.Perf.Settings.UseGlobalSettings">true</value>
<value type="int" key="Analyzer.Perf.StackSize">4096</value>
<value type="bool" key="Analyzer.QmlProfiler.AggregateTraces">false</value>
<value type="bool" key="Analyzer.QmlProfiler.FlushEnabled">false</value>
<value type="uint" key="Analyzer.QmlProfiler.FlushInterval">1000</value>
<value type="QString" key="Analyzer.QmlProfiler.LastTraceFile"></value>
<value type="bool" key="Analyzer.QmlProfiler.Settings.UseGlobalSettings">true</value>
<valuelist type="QVariantList" key="Analyzer.Valgrind.AddedSuppressionFiles"/>
<value type="bool" key="Analyzer.Valgrind.Callgrind.CollectBusEvents">false</value>
<value type="bool" key="Analyzer.Valgrind.Callgrind.CollectSystime">false</value>
<value type="bool" key="Analyzer.Valgrind.Callgrind.EnableBranchSim">false</value>
<value type="bool" key="Analyzer.Valgrind.Callgrind.EnableCacheSim">false</value>
<value type="bool" key="Analyzer.Valgrind.Callgrind.EnableEventToolTips">true</value>
<value type="double" key="Analyzer.Valgrind.Callgrind.MinimumCostRatio">0.01</value>
<value type="double" key="Analyzer.Valgrind.Callgrind.VisualisationMinimumCostRatio">10</value>
<value type="bool" key="Analyzer.Valgrind.FilterExternalIssues">true</value>
<value type="QString" key="Analyzer.Valgrind.KCachegrindExecutable">kcachegrind</value>
<value type="int" key="Analyzer.Valgrind.LeakCheckOnFinish">1</value>
<value type="int" key="Analyzer.Valgrind.NumCallers">25</value>
<valuelist type="QVariantList" key="Analyzer.Valgrind.RemovedSuppressionFiles"/>
<value type="int" key="Analyzer.Valgrind.SelfModifyingCodeDetection">1</value>
<value type="bool" key="Analyzer.Valgrind.Settings.UseGlobalSettings">true</value>
<value type="bool" key="Analyzer.Valgrind.ShowReachable">false</value>
<value type="bool" key="Analyzer.Valgrind.TrackOrigins">true</value>
<value type="QString" key="Analyzer.Valgrind.ValgrindExecutable">valgrind</value>
<valuelist type="QVariantList" key="Analyzer.Valgrind.VisibleErrorKinds">
<value type="int">0</value>
<value type="int">1</value>
<value type="int">2</value>
<value type="int">3</value>
<value type="int">4</value>
<value type="int">5</value>
<value type="int">6</value>
<value type="int">7</value>
<value type="int">8</value>
<value type="int">9</value>
<value type="int">10</value>
<value type="int">11</value>
<value type="int">12</value>
<value type="int">13</value>
<value type="int">14</value>
</valuelist>
<value type="int" key="PE.EnvironmentAspect.Base">2</value>
<valuelist type="QVariantList" key="PE.EnvironmentAspect.Changes"/>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.DefaultDisplayName">ui</value>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.DisplayName">ui2</value>
<value type="QString" key="ProjectExplorer.ProjectConfiguration.Id">Qt4ProjectManager.Qt4RunConfiguration:/home/hasis/Desktop/Nastaran/TRAIN/TaskLearning3/CommandDetector/ui/ui.pro</value>
<value type="QString" key="RunConfiguration.Arguments"></value>
<value type="uint" key="RunConfiguration.QmlDebugServerPort">3768</value>
<value type="bool" key="RunConfiguration.UseCppDebugger">false</value>
<value type="bool" key="RunConfiguration.UseCppDebuggerAuto">true</value>
@ -315,9 +381,9 @@
<value type="bool" key="RunConfiguration.UseQmlDebugger">false</value>
<value type="bool" key="RunConfiguration.UseQmlDebuggerAuto">true</value>
<value type="QString" key="RunConfiguration.WorkingDirectory"></value>
<value type="QString" key="RunConfiguration.WorkingDirectory.default">/home/hasis/Desktop/Nastaran/TRAIN/TaskLearning2/build-CommandDetector-Desktop_Qt_5_13_1_GCC_64bit-Release/test</value>
<value type="QString" key="RunConfiguration.WorkingDirectory.default">/home/hasis/Desktop/Nastaran/TRAIN/TaskLearning2/build-CommandDetector-Desktop_Qt_5_13_1_GCC_64bit-Debug/ui</value>
</valuemap>
<value type="int" key="ProjectExplorer.Target.RunConfigurationCount">1</value>
<value type="int" key="ProjectExplorer.Target.RunConfigurationCount">2</value>
</valuemap>
</data>
<data>

28
logic/include/BaseDecoder.h

@ -0,0 +1,28 @@
#ifndef BASEDECODER_H
#define BASEDECODER_H
#include <QList>
#include "CommandsType.h"
template<class T>
class A
{
T x;
public:
A()
{
//std::cout << "Constructor Called" << endl;
}
};
class BaseDecoder
{
public:
BaseDecoder();
template<typename T, typename ... Types>
virtual QList<CommandsType> decoderString();
virtual ~BaseDecoder();
};
#endif //BASEDECODER_H

17
logic/include/CommandDecoder.h

@ -3,16 +3,25 @@
#include <QList>
#include "CommandsType.h"
#include "BaseDecoder.h"
class CommandDecoder
class CommandDecoder : public BaseDecoder
{
private:
bool isStartWithDash(char* argv);
QList<CommandsType> _decodedList;
bool _isNextItemValue = true;
int _argc;
bool isCommand(char* argv);
void checkIfEnoughArgsAreProvided(int argc);
QList<CommandsType> CommandValueDecoder(char* argv[]);
void initCommandStrcut(char* argv, CommandsType& sample);
void checkIfNextItemShallBeValue(char* argv);
public:
CommandDecoder();
QList<CommandsType2> decodeStrintg(int argc, char* argv[]);
QList<CommandsType> decoderString() override;
QList<CommandsType> decoderString(int argc, char* argv[]) override;
};
#endif //COMMANDDECODER_H

27
logic/include/CommandsType.h

@ -6,32 +6,43 @@
#include <QMetaType>
struct CommandsType2
struct CommandsType
{
char* command;
char* value;
bool operator==(const CommandsType2& com) const
bool operator==(const CommandsType& rhs) const
{
for(size_t i = 0; i < strlen(com.command); i++)
for(size_t i = 0; i < strlen(rhs.command); i++)
{
if(com.command[i] != command[i])
if(rhs.command[i] != command[i])
{
return false;
}
}
for(size_t i = 0; i < strlen(com.value); i++)
if(value != Q_NULLPTR && rhs.value != Q_NULLPTR)
{
if(com.value[i] != value[i])
for(size_t i = 0; i < strlen(rhs.value); i++)
{
return false;
if(rhs.value[i] != value[i])
{
return false;
}
}
}
else if(value == Q_NULLPTR && rhs.value == Q_NULLPTR)
{
return true;
}
else
{
return false;
}
return true;
}
};
Q_DECLARE_METATYPE(CommandsType2);
Q_DECLARE_METATYPE(CommandsType);
#endif //COMMANDSTYPE_H

2
logic/logic.pro

@ -18,9 +18,11 @@ DEFINES += QT_DEPRECATED_WARNINGS
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
SOURCES += \
src/BaseDecoder.cpp \
src/CommandDecoder.cpp
HEADERS += \
include/BaseDecoder.h \
include/CommandDecoder.h \
include/CommandsType.h

6
logic/src/BaseDecoder.cpp

@ -0,0 +1,6 @@
#include "../include/BaseDecoder.h"
BaseDecoder::BaseDecoder()
{
}

82
logic/src/CommandDecoder.cpp

@ -1,55 +1,71 @@
#include "../include/CommandDecoder.h"
QList<CommandsType2> CommandDecoder::decodeStrintg(int argc, char* argv[])
QList<CommandsType> CommandDecoder::decoderString(int argc, char* argv[])
{
_argc = argc;
checkIfEnoughArgsAreProvided(_argc);
return CommandValueDecoder(argv);
}
//****************************************************************
bool CommandDecoder::isCommand(char* argv)
{
return ('-' == argv[0]);
}
//****************************************************************
void CommandDecoder::checkIfEnoughArgsAreProvided(int argc)
{
if(argc < 2)
{
throw" the usage should lookLike this Sin <parameter>";
throw"the usage should lookLike this Cin <parameter>";
}
else
{
QList<CommandsType2> test;
bool checkIsValue;
auto count = argc - 1;
uint8_t j = 1;
checkIsValue = false;
}
while(j <= count)
//****************************************************************
QList<CommandsType> CommandDecoder::CommandValueDecoder(char* argv[])
{
int j = 0;
while(j < _argc)
{
CommandsType sample;
if(isCommand(argv[j]))
{
initCommandStrcut(argv[j], sample);
}
else
{
auto sample1 = new CommandsType2();
if(isStartWithDash(argv[j]))
{
sample1->command = argv[j];
checkIsValue = true;
test.append(*sample1);
}
else
{
if(!checkIsValue)
{
throw" error hasValue ";
}
test.last().value = argv[j];
checkIsValue = false;
}
j++;
checkIfNextItemShallBeValue(argv[j]);
}
return test;
j++;
}
return _decodedList;
}
bool CommandDecoder::isStartWithDash(char* argv)
//****************************************************************
void CommandDecoder::checkIfNextItemShallBeValue(char* argv)
{
if('-' == argv[0])
if(!_isNextItemValue)
{
return true;
throw"duplicated Value and its wrong";
}
_decodedList.last().value = argv;
_isNextItemValue = false;
}
return false;
//****************************************************************
void CommandDecoder::initCommandStrcut(char* argv, CommandsType& sample)
{
sample.command = argv;
sample.value = Q_NULLPTR;
_isNextItemValue = true;
_decodedList.append(sample);
}
//****************************************************************
CommandDecoder::CommandDecoder()
{
}

7
test/include/CommandDecoderTest.h

@ -10,7 +10,8 @@ class CommandDecoderTest : public QObject
Q_OBJECT
private:
QList<CommandsType2> handiResult();
QList<CommandsType> create2CommandSample();
QList<CommandsType> createCorrectOrderOfCommand();
public:
CommandDecoderTest();
@ -19,7 +20,9 @@ public:
//uncrustify off
private slots:
//uncrustify on
void testDecoder();
void normalOrderTestCase();
void twoCommandOrderTestCase();
void morethanOneValueTestCase();
};
#endif //COMMANDDECODERTEST_H

129
test/src/CommandDecoderTest.cpp

@ -1,18 +1,44 @@
#include "include/CommandDecoderTest.h"
#include "include/CommandDecoderTest.h"
#include "CommandDecoder.h"
QList<CommandsType2> CommandDecoderTest::handiResult()
QList<CommandsType> CommandDecoderTest::create2CommandSample()
{
QList<CommandsType2> blist;
auto b1 = new CommandsType2();
auto b2 = new CommandsType2();
b1->command = "-node";
b1->value = "3";
blist.append(*b1);
b2->command = "-f";
b2->value = "7";
blist.append(*b2);
//-node 3 -g -f 11 -o filetext.txt
QList<CommandsType> blist;
CommandsType b1;
CommandsType b2;
CommandsType b3;
CommandsType b4;
b1.command = "-node";
b1.value = "3";
blist.append(b1);
b2.command = "-g";
b2.value = Q_NULLPTR;
blist.append(b2);
b3.command = "-f";
b3.value = "11";
blist.append(b3);
b4.command = "-o";
b4.value = "filetext.txt";
blist.append(b4);
return blist;
}
//****************************************************************
QList<CommandsType> CommandDecoderTest::createCorrectOrderOfCommand()
{
//-node 3 -f 7
QList<CommandsType> blist;
CommandsType b1;
CommandsType b2;
b1.command = "-node";
b1.value = "3";
blist.append(b1);
b2.command = "-f";
b2.value = "7";
blist.append(b2);
return blist;
}
@ -28,27 +54,80 @@ CommandDecoderTest::~CommandDecoderTest()
}
//****************************************************************
void CommandDecoderTest::testDecoder()
void CommandDecoderTest::normalOrderTestCase()
{
CommandDecoder comTest;
CommandDecoder temp;
char* ptr_array[5];
char array[5][20] = {{0}};
strcpy(array[0], "order");
strcpy(array[1], "-node");
strcpy(array[2], "3");
strcpy(array[3], "-f");
strcpy(array[4], "7");
for(int i = 0; i < 5; i++)
char* ptr_array[4];
char array[4][20] = {{0}};
strcpy(array[0], "-node");
strcpy(array[1], "3");
strcpy(array[2], "-f");
strcpy(array[3], "7");
for(int i = 0; i < 4; i++)
{
ptr_array[i] = array[i];
}
QList<CommandsType2> c1 = comTest.decodeStrintg(5, ptr_array);
auto c2 = handiResult();
QList<CommandsType> c1 = temp.decoderString(4, ptr_array);
auto c2 = createCorrectOrderOfCommand();
//QVERIFY(c1 == c2);
QCOMPARE(c1, c2);
}
//****************************************************************
void CommandDecoderTest::twoCommandOrderTestCase()
{
//-node 3 -g -f 11 -o filetext.txt
CommandDecoder temp;
char* ptr_array[7];
char array[7][20] = {{0}};
strcpy(array[0], "-node");
strcpy(array[1], "3");
strcpy(array[2], "-g");
strcpy(array[3], "-f");
strcpy(array[4], "11");
strcpy(array[5], "-o");
strcpy(array[6], "filetext.txt");
for(int i = 0; i < 7; i++)
{
ptr_array[i] = array[i];
}
QList<CommandsType> c1 = temp.decoderString(7, ptr_array);
auto c2 = create2CommandSample();
QCOMPARE(c1, c2);
//QCOMPARE(c, c1);
}
//****************************************************************
void CommandDecoderTest::morethanOneValueTestCase()
{
//-node 3 -g 15 16 -h 22
CommandDecoder temp;
char* ptr_array[7];
char array[7][20] = {{0}};
strcpy(array[0], "-node");
strcpy(array[1], "3");
strcpy(array[2], "-g");
strcpy(array[3], "15");
strcpy(array[4], "11");
strcpy(array[5], "-h");
strcpy(array[6], "22");
for(int i = 0; i < 7; i++)
{
ptr_array[i] = array[i];
}
try
{
QList<CommandsType> c1 = temp.decoderString(7, ptr_array);
QVERIFY(false);
}
catch(...)
{
QVERIFY(true);
}
}

8
test/src/main.cpp

@ -4,7 +4,13 @@
int main()
{
QTest::qExec(new CommandDecoderTest);
try {
QTest::qExec(new CommandDecoderTest);
}
catch(...)
{
qDebug() << "some error in test \n";
}
return 0;
}

37
ui/main.cpp

@ -0,0 +1,37 @@
#include <QCoreApplication>
#include <CommandDecoder.h>
#include <QDebug>
int main(int argc, char* argv[])
{
QCoreApplication a(argc, argv);
try {
CommandDecoder dr;
char* arrayCopy[argc - 1];
//delete 1 (index 0)
for(int i = 0; i < argc; ++i)
{
arrayCopy[i] = argv[i + 1]; //copy next element left
}
auto result = dr.decoderString(argc - 1, arrayCopy);
for(int i = 0; i < result.length(); i++)
{
qDebug() << "command: " << result[i].command << " --- Value: " << result[i].value <<
endl;
}
}
catch(char* excp)
{
qDebug() << "Caught some error in ui " << excp;
}
catch(...)
{
qDebug() << "some error in ui \n";
}
return a.exec();
}

31
ui/ui.pro

@ -0,0 +1,31 @@
QT -= gui
CONFIG += c++11 console
CONFIG -= app_bundle
# The following define makes your compiler emit warnings if you use
# any Qt feature that has been marked deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS
# You can also make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
SOURCES += \
main.cpp
# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target
unix:!macx: LIBS += -L$$OUT_PWD/../logic/ -llogic
INCLUDEPATH += $$PWD/../logic/include
DEPENDPATH += $$PWD/../logic/include
unix:!macx: PRE_TARGETDEPS += $$OUT_PWD/../logic/liblogic.a
Loading…
Cancel
Save