4 #include "zypp/cache/CacheTypes.h"
5 #include "zypp/cache/ResolvableQuery.h"
6 #include "zypp/Package.h"
7 #include "zypp/cache/sqlite3x/sqlite3x.hpp"
9 using namespace sqlite3x;
12 namespace zypp { namespace cache {
15 struct ResolvableQuery::Impl
19 CacheTypes _type_cache;
21 Impl( const Pathname &dbdir)
25 _fields = "id, name, version, release, epoch, arch, kind, installed_size, archive_size, install_only, build_time, install_time, repository_id";
32 data::ResObject_Ptr fromRow( sqlite3_reader &reader )
34 data::ResObject_Ptr ptr (new data::ResObject);
36 ptr->name = reader.getstring(1);
37 ptr->edition = Edition( reader.getstring(2), reader.getstring(3), reader.getint(4));
38 ptr->arch = _type_cache.archFor(reader.getint(5));
40 // TODO get the rest of the data
46 void query( const data::RecordId &id,
47 ProcessResolvable fnc )
49 sqlite3_connection con((_dbdir + "zypp.db").asString().c_str());
50 //con.executenonquery("PRAGMA cache_size=8000;");
51 con.executenonquery("BEGIN;");
52 sqlite3_command cmd( con, "select " + _fields + " from resolvables where id=:id;");
54 sqlite3_reader reader = cmd.executereader();
57 fnc( id, fromRow(reader) );
59 con.executenonquery("COMMIT;");
63 void query( const std::string &s,
64 ProcessResolvable fnc )
67 sqlite3_connection con((_dbdir + "zypp.db").asString().c_str());
68 //con.executenonquery("PRAGMA cache_size=8000;");
69 con.executenonquery("BEGIN;");
70 sqlite3_command cmd( con, "select " + _fields + " from resolvables where name like '%:name%';");
72 sqlite3_reader reader = cmd.executereader();
75 fnc( reader.getint64(0), fromRow(reader) );
77 con.executenonquery("COMMIT;");
81 std::string queryStringAttribute( const data::RecordId &record_id,
82 const std::string &klass,
83 const std::string &name )
85 sqlite3_connection con((_dbdir + "zypp.db").asString().c_str());
86 return queryStringAttributeTranslationInternal( con, record_id, Locale(), klass, name);
90 std::string queryStringAttributeTranslation( const data::RecordId &record_id,
92 const std::string &klass,
93 const std::string &name )
95 sqlite3_connection con((_dbdir + "zypp.db").asString().c_str());
96 return queryStringAttributeTranslationInternal( con, record_id, locale, klass, name );
100 TranslatedText queryTranslatedStringAttribute( const data::RecordId &record_id,
101 const std::string &klass,
102 const std::string &name )
104 sqlite3_connection con((_dbdir + "zypp.db").asString().c_str());
105 return queryTranslatedStringAttributeInternal( con, record_id, klass, name );
109 bool queryBooleanAttribute( const data::RecordId &record_id,
110 const std::string &klass,
111 const std::string &name )
113 sqlite3_connection con((_dbdir + "zypp.db").asString().c_str());
114 return ( queryNumericAttributeInternal( con, record_id, klass, name) != 0 );
117 int queryNumericAttribute( const data::RecordId &record_id,
118 const std::string &klass,
119 const std::string &name )
121 sqlite3_connection con((_dbdir + "zypp.db").asString().c_str());
122 return queryNumericAttributeInternal( con, record_id, klass, name);
127 int queryNumericAttributeInternal( sqlite3_connection &con,
128 const data::RecordId &record_id,
129 const std::string &klass,
130 const std::string &name )
132 con.executenonquery("BEGIN;");
133 sqlite3_command cmd( con, "select a.value from numeric_attributes a,types t where a.weak_resolvable_id=:rid and a.attr_id=t.id and t.class=:tclass and t.name=:tname;");
135 cmd.bind(":rid", record_id);
137 cmd.bind(":tclass", klass);
138 cmd.bind(":tname", name);
140 return cmd.executeint();
143 TranslatedText queryTranslatedStringAttributeInternal( sqlite3_connection &con,
144 const data::RecordId &record_id,
145 const std::string &klass,
146 const std::string &name )
148 //con.executenonquery("PRAGMA cache_size=8000;");
149 con.executenonquery("BEGIN;");
150 sqlite3_command cmd( con, "select a.text, l.name from text_attributes a,types l,types t where a.weak_resolvable_id=:rid and a.lang_id=l.id and a.attr_id=t.id and l.class=:lclass and t.class=:tclass and t.name=:tname;");
152 cmd.bind(":rid", record_id);
153 cmd.bind(":lclass", "lang");
155 cmd.bind(":tclass", klass);
156 cmd.bind(":tname", name);
158 TranslatedText result;
159 sqlite3_reader reader = cmd.executereader();
162 result.setText( reader.getstring(0), Locale( reader.getstring(1) ) );
167 std::string queryStringAttributeInternal( sqlite3_connection &con,
168 const data::RecordId &record_id,
169 const std::string &klass,
170 const std::string &name )
172 return queryStringAttributeTranslationInternal( con, record_id, Locale(), klass, name);
175 std::string queryStringAttributeTranslationInternal( sqlite3_connection &con,
176 const data::RecordId &record_id,
177 const Locale &locale,
178 const std::string &klass,
179 const std::string &name )
181 //con.executenonquery("PRAGMA cache_size=8000;");
182 con.executenonquery("BEGIN;");
183 sqlite3_command cmd( con, "select a.text from text_attributes a,types l,types t where a.weak_resolvable_id=:rid and a.lang_id=l.id and a.attr_id=t.id and l.class=:lclass and l.name=:lname and t.class=:tclass and t.name=:tname;");
185 cmd.bind(":rid", record_id);
186 cmd.bind(":lclass", "lang");
187 if (locale == Locale() )
188 cmd.bind(":lname", "none");
190 cmd.bind(":lname", locale.code());
192 cmd.bind(":tclass", klass);
193 cmd.bind(":tname", name);
195 return cmd.executestring();
199 //////////////////////////////////////////////////////////////////////////////
200 // FORWARD TO IMPLEMENTATION
201 //////////////////////////////////////////////////////////////////////////////
203 ResolvableQuery::ResolvableQuery( const Pathname &dbdir)
204 : _pimpl(new Impl(dbdir))
208 //////////////////////////////////////////////////////////////////////////////
210 void ResolvableQuery::query( const data::RecordId &id, ProcessResolvable fnc )
212 _pimpl->query(id, fnc);
215 //////////////////////////////////////////////////////////////////////////////
217 void ResolvableQuery::query( const std::string &s, ProcessResolvable fnc )
219 _pimpl->query(s, fnc);
222 //////////////////////////////////////////////////////////////////////////////
224 int ResolvableQuery::queryNumericAttribute( const data::RecordId &record_id,
225 const std::string &klass,
226 const std::string &name )
228 return _pimpl->queryNumericAttribute(record_id, klass, name);
231 bool ResolvableQuery::queryBooleanAttribute( const data::RecordId &record_id,
232 const std::string &klass,
233 const std::string &name )
235 return _pimpl->queryNumericAttribute(record_id, klass, name);
239 std::string ResolvableQuery::queryStringAttribute( const data::RecordId &record_id,
240 const std::string &klass,
241 const std::string &name )
243 return _pimpl->queryStringAttribute(record_id, klass, name);
246 //////////////////////////////////////////////////////////////////////////////
248 std::string ResolvableQuery::queryStringAttributeTranslation( const data::RecordId &record_id,
249 const Locale &locale,
250 const std::string &klass,
251 const std::string &name )
253 return _pimpl->queryStringAttributeTranslation(record_id, locale, klass, name);
256 //////////////////////////////////////////////////////////////////////////////
258 TranslatedText ResolvableQuery::queryTranslatedStringAttribute( const data::RecordId &record_id,
259 const std::string &klass,
260 const std::string &name )
262 return _pimpl->queryTranslatedStringAttribute(record_id, klass, name);
265 //////////////////////////////////////////////////////////////////////////////
267 } } // namespace zypp::cache