summaryrefslogtreecommitdiff
authorkorovkin <korovkin>2006-04-04 12:16:09 (UTC)
committer korovkin <korovkin>2006-04-04 12:16:09 (UTC)
commit76276b77e99897ae264aa5b171191521edada420 (patch) (unidiff)
treeb182f312ecac405b3eff0938272692cb414d51fe
parent57f97a65fc7ce932231585895f358f1089900879 (diff)
downloadopie-76276b77e99897ae264aa5b171191521edada420.zip
opie-76276b77e99897ae264aa5b171191521edada420.tar.gz
opie-76276b77e99897ae264aa5b171191521edada420.tar.bz2
Modified parser so it ignores lines like something_key_something.
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/opietooth/manager/hciconfwrapper.cpp45
-rw-r--r--noncore/net/opietooth/manager/hciconfwrapper.h10
2 files changed, 43 insertions, 12 deletions
diff --git a/noncore/net/opietooth/manager/hciconfwrapper.cpp b/noncore/net/opietooth/manager/hciconfwrapper.cpp
index 47e170e..2413f2b 100644
--- a/noncore/net/opietooth/manager/hciconfwrapper.cpp
+++ b/noncore/net/opietooth/manager/hciconfwrapper.cpp
@@ -1,142 +1,163 @@
1/* $Id$ */
2/* hcid.conf parser */
3/***************************************************************************
4 * *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) any later version. *
9 * *
10 ***************************************************************************/
1#include "hciconfwrapper.h" 11#include "hciconfwrapper.h"
2 12
3#include <qfile.h> 13#include <qfile.h>
4#include <qtextstream.h> 14#include <qtextstream.h>
5#include <qregexp.h> 15#include <qregexp.h>
6 16
7#include <opie2/odebug.h> 17#include <opie2/odebug.h>
8using namespace Opie::Core; 18using namespace Opie::Core;
9 19
10namespace OpieTooth { 20namespace OpieTooth {
11 21
12 22
13 HciConfWrapper::HciConfWrapper( const QString &fileName) { 23 HciConfWrapper::HciConfWrapper( const QString &fileName) {
14 m_fileName = fileName; 24 m_fileName = fileName;
15 } 25 }
16 26
17 HciConfWrapper::~HciConfWrapper() { 27 HciConfWrapper::~HciConfWrapper() {
18 } 28 }
19 29
20 30
21 void HciConfWrapper::setPinHelper( const QString& app ) { 31 void HciConfWrapper::setPinHelper( const QString& app ) {
22 setValue( "pin_helper" , app ); 32 setValue( "pin_helper" , app );
23 } 33 }
24 34
25 void HciConfWrapper::setName( const QString &name ) { 35 void HciConfWrapper::setName( const QString &name ) {
26 odebug << "NAME : " << name << oendl; 36 odebug << "NAME : " << name << oendl;
27 setValue( "name" , "\"" + name + "\"" ); 37 setValue( "name" , "\"" + name + "\"" );
28 } 38 }
29 39
30 void HciConfWrapper::setIscan( bool enable) { 40 void HciConfWrapper::setIscan( bool enable) {
31 41
32 if ( enable ) { 42 if ( enable ) {
33 setValue( "iscan" , "enable" ); 43 setValue( "iscan" , "enable" );
34 } else { 44 } else {
35 setValue( "iscan" , "disable" ); 45 setValue( "iscan" , "disable" );
36 } 46 }
37 } 47 }
38 48
39 void HciConfWrapper::setPscan( bool enable) { 49 void HciConfWrapper::setPscan( bool enable) {
40 50
41 if ( enable ) { 51 if ( enable ) {
42 setValue( "pscan" , "enable" ); 52 setValue( "pscan" , "enable" );
43 } else { 53 } else {
44 setValue( "pscan" , "disable" ); 54 setValue( "pscan" , "disable" );
45 } 55 }
46 } 56 }
47 57
48 58
49 void HciConfWrapper::setAuth( bool enable) { 59 void HciConfWrapper::setAuth( bool enable) {
50 60
51 if ( enable ) { 61 if ( enable ) {
52 setValue( "auth" , "enable" ); 62 setValue( "auth" , "enable" );
63 setValue( "security" , "auto" );
53 } else { 64 } else {
54 setValue( "auth" , "disable" ); 65 setValue( "auth" , "disable" );
66 setValue( "security" , "none" );
55 } 67 }
56 } 68 }
57 69
58 70
59 void HciConfWrapper::setEncrypt( bool enable) { 71 void HciConfWrapper::setEncrypt( bool enable) {
60 72
61 if ( enable ) { 73 if ( enable ) {
62 setValue( "encrypt" , "enable" ); 74 setValue( "encrypt" , "enable" );
63 } else { 75 } else {
64 setValue( "encrypt" , "disable" ); 76 setValue( "encrypt" , "disable" );
65 } 77 }
66 } 78 }
67 79
68 80
69 void HciConfWrapper::setValue(const QString &key, const QString &value ) { 81 void HciConfWrapper::setValue(const QString &key, const QString &value ) {
70 82
71 if (m_file.isEmpty() ) // load first 83 if (m_file.isEmpty() ) // load first
72 return; 84 return;
73 85
74 QStringList::Iterator it; 86 QStringList::Iterator it;
75 87
76 QString str; 88 QString str;
89 QString tmpLine;
90 bool wasCommented = false; //If the optin string was commented out
91 QRegExp rx1("^" + key + "[ ]+"); //Regexp fo key searching
92 QRegExp rx2(";[ ]*" + key + "[ ]+"); //Regexp fo key searching
77 for (it = m_file.begin(); it != m_file.end(); ++it ) { 93 for (it = m_file.begin(); it != m_file.end(); ++it ) {
94 wasCommented = false;
78 str = (*it); 95 str = (*it);
79 if( (str.contains(key)) > 0 ) { 96 tmpLine = str.simplifyWhiteSpace();
80 odebug << "Found" << oendl; 97 //If it's commented out, remove the comment and check again
81 // still need to look if its commented out!!! 98 //Now, let's check if this is a real keyword (not word_keyword)
82 str.simplifyWhiteSpace(); 99 if (tmpLine.startsWith("#")) {
83 odebug << key << oendl; 100 tmpLine.remove(0, 1);
84 if (str.startsWith("#")) { 101 tmpLine = tmpLine.simplifyWhiteSpace();
85 str = (key + " " + value + ";"); 102 wasCommented = true;
86 } else { 103 }
87 str = str.replace( QRegExp( "\\s*"+key+"\\s+[^\\s][^;]*;" ), key + " " + value + ";"); 104 if( (tmpLine.contains(rx1)) > 0 || (tmpLine.contains(rx2)) > 0) {
88 } 105 odebug << "Found " + key << oendl;
106
107 if (wasCommented)
108 str = ("\t" + key + " " + value + ";");
109 else
110 str = str.replace(QRegExp("\\s*" + key + "\\s+[^\\s][^;]*;"),
111 "\t" + key + " " + value + ";");
89 odebug << str << oendl; 112 odebug << str << oendl;
90 it = m_file.remove( it ); 113 it = m_file.remove( it );
91 it = m_file.insert( it, str ); 114 it = m_file.insert( it, str );
92 //return; the regexp is too wide -zecke // all set 115 //return; the regexp is too wide -zecke // all set
93 } 116 }
94 } 117 }
95
96
97 } 118 }
98 119
99 /** 120 /**
100 * This loads the config file and stores it inside 121 * This loads the config file and stores it inside
101 * the m_file 122 * the m_file
102 */ 123 */
103 void HciConfWrapper::load() { 124 void HciConfWrapper::load() {
104 owarn << "loaded" << oendl; 125 owarn << "loaded" << oendl;
105 m_file.clear(); 126 m_file.clear();
106 QFile file( m_fileName ); 127 QFile file( m_fileName );
107 if (!file.open( IO_ReadOnly ) ) { 128 if (!file.open( IO_ReadOnly ) ) {
108 odebug << "Could not open" << oendl; 129 odebug << "Could not open" << oendl;
109 return; 130 return;
110 } 131 }
111 132
112 /** 133 /**
113 * readAll() into a QByteArray 134 * readAll() into a QByteArray
114 * QStringList::split('\n', array ) 135 * QStringList::split('\n', array )
115 * would this be faster? -zecke 136 * would this be faster? -zecke
116 */ 137 */
117 QTextStream stream(&file ); 138 QTextStream stream(&file );
118 QString tmp; 139 QString tmp;
119 while ( !stream.atEnd() ) { 140 while ( !stream.atEnd() ) {
120 tmp = stream.readLine(); 141 tmp = stream.readLine();
121 m_file.append( tmp ); 142 m_file.append( tmp );
122 } 143 }
123 } 144 }
124 void HciConfWrapper::save() { 145 void HciConfWrapper::save() {
125 owarn << "save" << oendl; 146 owarn << "save" << oendl;
126 if (m_file.isEmpty() ) // load first 147 if (m_file.isEmpty() ) // load first
127 return; 148 return;
128 149
129 QFile file( m_fileName ); 150 QFile file( m_fileName );
130 if ( !file.open(IO_WriteOnly ) ) { 151 if ( !file.open(IO_WriteOnly ) ) {
131 owarn << "could not open " << m_fileName.latin1() << "" << oendl; 152 owarn << "could not open " << m_fileName.latin1() << "" << oendl;
132 return; 153 return;
133 } 154 }
134 155
135 QTextStream stream(&file ); 156 QTextStream stream(&file );
136 QStringList::Iterator it; 157 QStringList::Iterator it;
137 for ( it = m_file.begin(); it != m_file.end(); ++it ) { 158 for ( it = m_file.begin(); it != m_file.end(); ++it ) {
138 stream << (*it) << endl; 159 stream << (*it) << endl;
139 } 160 }
140 owarn << "saved" << oendl; 161 owarn << "saved" << oendl;
141 }; 162 };
142} 163}
diff --git a/noncore/net/opietooth/manager/hciconfwrapper.h b/noncore/net/opietooth/manager/hciconfwrapper.h
index 0c4b290..5bf483c 100644
--- a/noncore/net/opietooth/manager/hciconfwrapper.h
+++ b/noncore/net/opietooth/manager/hciconfwrapper.h
@@ -1,34 +1,44 @@
1/* $Id$ */
2/* hcid.conf parser */
3/***************************************************************************
4 * *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) any later version. *
9 * *
10 ***************************************************************************/
1#ifndef HCICONFWRAPPER_H 11#ifndef HCICONFWRAPPER_H
2#define HCICONFWRAPPER_H 12#define HCICONFWRAPPER_H
3 13
4#include <qstring.h> 14#include <qstring.h>
5#include <qstringlist.h> 15#include <qstringlist.h>
6 16
7namespace OpieTooth { 17namespace OpieTooth {
8 18
9 class HciConfWrapper { 19 class HciConfWrapper {
10 20
11 public: 21 public:
12 HciConfWrapper( const QString &fileName ); 22 HciConfWrapper( const QString &fileName );
13 ~HciConfWrapper(); 23 ~HciConfWrapper();
14 void load(); 24 void load();
15 void save(); 25 void save();
16 26
17 void setPinHelper( const QString& app ); 27 void setPinHelper( const QString& app );
18 void setName( const QString& name ); 28 void setName( const QString& name );
19 void setIscan( bool enable ); 29 void setIscan( bool enable );
20 void setPscan( bool enable ); 30 void setPscan( bool enable );
21 void setAuth( bool enable); 31 void setAuth( bool enable);
22 void setEncrypt( bool enable); 32 void setEncrypt( bool enable);
23 33
24 private: 34 private:
25 35
26 void setValue(const QString &entry, const QString &value ); 36 void setValue(const QString &entry, const QString &value );
27 37
28 QString m_fileName; 38 QString m_fileName;
29 QStringList m_file; 39 QStringList m_file;
30 }; 40 };
31 41
32} 42}
33 43
34#endif 44#endif