-rw-r--r-- | noncore/unsupported/oipkg/package.cpp | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/noncore/unsupported/oipkg/package.cpp b/noncore/unsupported/oipkg/package.cpp index 7aaa240..1054a1d 100644 --- a/noncore/unsupported/oipkg/package.cpp +++ b/noncore/unsupported/oipkg/package.cpp | |||
@@ -27,127 +27,127 @@ Package::Package( QObject *parent, const char *name ) | |||
27 | Package::~Package() | 27 | Package::~Package() |
28 | { | 28 | { |
29 | } | 29 | } |
30 | 30 | ||
31 | Package::Package( PackageManagerSettings *s, QObject *parent, const char *name ) | 31 | Package::Package( PackageManagerSettings *s, QObject *parent, const char *name ) |
32 | : QObject(parent,name) | 32 | : QObject(parent,name) |
33 | { | 33 | { |
34 | Package(parent,name); | 34 | Package(parent,name); |
35 | init(s); | 35 | init(s); |
36 | } | 36 | } |
37 | 37 | ||
38 | void Package::init( PackageManagerSettings *s ) | 38 | void Package::init( PackageManagerSettings *s ) |
39 | { | 39 | { |
40 | settings = s; | 40 | settings = s; |
41 | _size = ""; | 41 | _size = ""; |
42 | _section = ""; | 42 | _section = ""; |
43 | _subsection = ""; | 43 | _subsection = ""; |
44 | _shortDesc = ""; | 44 | _shortDesc = ""; |
45 | _desc = ""; | 45 | _desc = ""; |
46 | _name = ""; | 46 | _name = ""; |
47 | _toProcess = false; | 47 | _toProcess = false; |
48 | _useFileName = false; | 48 | _useFileName = false; |
49 | _old = false; | 49 | _old = false; |
50 | _status = ""; | 50 | _status = ""; |
51 | _dest = settings->getDestinationName(); | 51 | _dest = settings->getDestinationName(); |
52 | _link = settings->createLinks(); | 52 | _link = settings->createLinks(); |
53 | _versions=0; | 53 | _versions=0; |
54 | _version=""; | 54 | _version=""; |
55 | } | 55 | } |
56 | 56 | ||
57 | Package::Package( QStringList pack, PackageManagerSettings *s , QObject *parent, const char *name ) | 57 | Package::Package( QStringList pack, PackageManagerSettings *s , QObject *parent, const char *name ) |
58 | : QObject(parent,name) | 58 | : QObject(parent,name) |
59 | { | 59 | { |
60 | init(s); | 60 | init(s); |
61 | parsePackage( pack ); | 61 | parsePackage( pack ); |
62 | } | 62 | } |
63 | 63 | ||
64 | Package::Package( QString n, PackageManagerSettings *s, QObject *parent, const char *name ) | 64 | Package::Package( QString n, PackageManagerSettings *s, QObject *parent, const char *name ) |
65 | : QObject(parent,name) | 65 | : QObject(parent,name) |
66 | { | 66 | { |
67 | init(s); | 67 | init(s); |
68 | if ( !QFile::exists( n ) ) | 68 | if ( !QFile::exists( n ) ) |
69 | { | 69 | { |
70 | _name = QString( n ); | 70 | _name = QString( n ); |
71 | }else{ | 71 | }else{ |
72 | pvDebug(4,"remote file: "+n); | 72 | pvDebug(4,"remote file: "+n); |
73 | parseIpkgFile( n ); | 73 | parseIpkgFile( n ); |
74 | _useFileName = true; | 74 | _useFileName = true; |
75 | _fileName = QString( n ); | 75 | _fileName = QString( n ); |
76 | } | 76 | } |
77 | } | 77 | } |
78 | 78 | ||
79 | Package::Package( Package *pi, QObject *parent, const char *name ) | 79 | Package::Package( Package *pi, QObject *parent, const char *name ) |
80 | : QObject(parent,name) | 80 | : QObject(parent,name) |
81 | { | 81 | { |
82 | init(pi->settings); | 82 | init(pi->settings); |
83 | copyValues( pi ); | 83 | copyValues( pi ); |
84 | } | 84 | } |
85 | 85 | ||
86 | 86 | ||
87 | void Package::setValue( QString n, QString t ) | 87 | void Package::setValue( QString n, QString t ) |
88 | { | 88 | { |
89 | if ( n == "Package" ) | 89 | if ( n == "Package" ) |
90 | { | 90 | { |
91 | _name = QString( t ); | 91 | _name = QString( t ); |
92 | }else if ( n == "Installed-Size" ) | 92 | }else if ( n == "Installed-Size" ) |
93 | { | 93 | { |
94 | _size = t; | 94 | _size = t; |
95 | // }else if ( n == "Priority") | 95 | // }else if ( n == "Priority") |
96 | // { | 96 | // { |
97 | 97 | ||
98 | }else if ( n == "Section") | 98 | }else if ( n == "Section") |
99 | { | 99 | { |
100 | setSection( t ); | 100 | setSection( t ); |
101 | // }else if ( n == "Maintainer") | 101 | // }else if ( n == "Maintainer") |
102 | // { | 102 | // { |
103 | // | 103 | // |
104 | // }else if ( n == "Architecture") | 104 | // }else if ( n == "Architecture") |
105 | // { | 105 | // { |
106 | 106 | ||
107 | }else if ( n == "Version") | 107 | }else if ( n == "Version") |
108 | { | 108 | { |
109 | _version = t; | 109 | _version = t; |
110 | // }else if ( n == "Pre-Depends") | 110 | // }else if ( n == "Pre-Depends") |
111 | // { | 111 | // { |
112 | // | 112 | // |
113 | // }else if ( n == "Depends") | 113 | // }else if ( n == "Depends") |
114 | // { | 114 | // { |
115 | 115 | ||
116 | }else if ( n == "Filename") | 116 | }else if ( n == "Filename") |
117 | { | 117 | { |
118 | _fileName = t; | 118 | _fileName = t; |
119 | // }else if ( n == "Size") | 119 | // }else if ( n == "Size") |
120 | // { | 120 | // { |
121 | // | 121 | // |
122 | //}else if ( n == "MD5Sum") | 122 | //}else if ( n == "MD5Sum") |
123 | //{ | 123 | //{ |
124 | 124 | ||
125 | }else if ( n == "Description") | 125 | }else if ( n == "Description") |
126 | { | 126 | { |
127 | setDesc( t ); | 127 | setDesc( t ); |
128 | }else if ( n == "Status") | 128 | }else if ( n == "Status") |
129 | { | 129 | { |
130 | if ( installed() ) return; | 130 | if ( installed() ) return; |
131 | _status = t; | 131 | _status = t; |
132 | // }else if ( n == "Essential") | 132 | // }else if ( n == "Essential") |
133 | // { | 133 | // { |
134 | 134 | ||
135 | }else{ | 135 | }else{ |
136 | _values.insert(n,new QString(t)); | 136 | _values.insert(n,new QString(t)); |
137 | } | 137 | } |
138 | } | 138 | } |
139 | 139 | ||
140 | QString Package::name() | 140 | QString Package::name() |
141 | { | 141 | { |
142 | if (_displayName.isEmpty() ) return _name; | 142 | if (_displayName.isEmpty() ) return _name; |
143 | else return _displayName; | 143 | else return _displayName; |
144 | } | 144 | } |
145 | 145 | ||
146 | 146 | ||
147 | QString Package::installName() | 147 | QString Package::installName() |
148 | { | 148 | { |
149 | if (_useFileName) return _fileName; | 149 | if (_useFileName) return _fileName; |
150 | else return _name; | 150 | else return _name; |
151 | } | 151 | } |
152 | 152 | ||
153 | QString Package::packageName() | 153 | QString Package::packageName() |
@@ -356,116 +356,123 @@ QString Package::details() | |||
356 | description.append(" "); | 356 | description.append(" "); |
357 | description.append(Qtopia::escapeString(line)); | 357 | description.append(Qtopia::escapeString(line)); |
358 | } | 358 | } |
359 | } | 359 | } |
360 | } | 360 | } |
361 | } | 361 | } |
362 | return description; | 362 | return description; |
363 | } | 363 | } |
364 | 364 | ||
365 | void Package::processed() | 365 | void Package::processed() |
366 | { | 366 | { |
367 | _toProcess = false; | 367 | _toProcess = false; |
368 | //hack, but we're not writing status anyway... | 368 | //hack, but we're not writing status anyway... |
369 | if ( installed() ) _status = "install"; | 369 | if ( installed() ) _status = "install"; |
370 | else _status = "installed"; | 370 | else _status = "installed"; |
371 | } | 371 | } |
372 | 372 | ||
373 | QString Package::dest() | 373 | QString Package::dest() |
374 | { | 374 | { |
375 | if ( installed()||(!installed() && _toProcess) ) | 375 | if ( installed()||(!installed() && _toProcess) ) |
376 | return _dest!=""?_dest:settings->getDestinationName(); | 376 | return _dest!=""?_dest:settings->getDestinationName(); |
377 | else return ""; | 377 | else return ""; |
378 | } | 378 | } |
379 | 379 | ||
380 | void Package::setDest( QString d ) | 380 | void Package::setDest( QString d ) |
381 | { | 381 | { |
382 | if ( d == "remote") _useFileName = true; | 382 | if ( d == "remote") _useFileName = true; |
383 | else _dest = d; | 383 | else _dest = d; |
384 | } | 384 | } |
385 | 385 | ||
386 | void Package::setOn() | 386 | void Package::setOn() |
387 | { | 387 | { |
388 | _toProcess = true; | 388 | _toProcess = true; |
389 | } | 389 | } |
390 | 390 | ||
391 | bool Package::link() | 391 | bool Package::link() |
392 | { | 392 | { |
393 | if ( _dest == "root" || (!installed() && !_toProcess) ) return false; | 393 | if ( _dest == "root" || (!installed() && !_toProcess) ) return false; |
394 | return _link; | 394 | return _link; |
395 | } | 395 | } |
396 | 396 | ||
397 | void Package::setLink(bool b) | 397 | void Package::setLink(bool b) |
398 | { | 398 | { |
399 | _link = b; | 399 | _link = b; |
400 | } | 400 | } |
401 | 401 | ||
402 | void Package::parseIpkgFile( QString file) | 402 | void Package::parseIpkgFile( QString file) |
403 | { | 403 | { |
404 | system("tar xzf "+file+" -C /tmp"); | 404 | // 20020830 |
405 | system("tar xzf /tmp/control.tar.gz -C /tmp"); | 405 | // a quick hack to make oipkg understand the new ipk format |
406 | // neu: ar pf PACKAGE control.tar.gz | tar xfOz - ./control > /tmp/control | ||
407 | if (! system("ar pf "+file+" control.tar.gz | tar xfOz - ./control > /tmp/control") ) | ||
408 | { | ||
409 | //#old tar ipk format | ||
410 | system("tar xzf "+file+" -C /tmp"); | ||
411 | system("tar xzf /tmp/control.tar.gz -C /tmp"); | ||
412 | } | ||
406 | QFile f("/tmp/control"); | 413 | QFile f("/tmp/control"); |
407 | if ( f.open(IO_ReadOnly) ) | 414 | if ( f.open(IO_ReadOnly) ) |
408 | { | 415 | { |
409 | QTextStream t( &f ); | 416 | QTextStream t( &f ); |
410 | QStringList pack; | 417 | QStringList pack; |
411 | while ( !t.eof() ) | 418 | while ( !t.eof() ) |
412 | { | 419 | { |
413 | pack << t.readLine(); | 420 | pack << t.readLine(); |
414 | } | 421 | } |
415 | f.close(); | 422 | f.close(); |
416 | parsePackage( pack ); | 423 | parsePackage( pack ); |
417 | } | 424 | } |
418 | 425 | ||
419 | } | 426 | } |
420 | 427 | ||
421 | //QString Package::getPackageName() | 428 | //QString Package::getPackageName() |
422 | //{ | 429 | //{ |
423 | //if ( _packageName.isEmpty() ) return _name; | 430 | //if ( _packageName.isEmpty() ) return _name; |
424 | //else return _packageName; | 431 | //else return _packageName; |
425 | //} | 432 | //} |
426 | 433 | ||
427 | void Package::instalFromFile(bool iff) | 434 | void Package::instalFromFile(bool iff) |
428 | { | 435 | { |
429 | _useFileName = iff; | 436 | _useFileName = iff; |
430 | } | 437 | } |
431 | 438 | ||
432 | void Package::setName(QString n) | 439 | void Package::setName(QString n) |
433 | { | 440 | { |
434 | _displayName = n; | 441 | _displayName = n; |
435 | } | 442 | } |
436 | 443 | ||
437 | QDict<QString>* Package::getFields() | 444 | QDict<QString>* Package::getFields() |
438 | { | 445 | { |
439 | return &_values; | 446 | return &_values; |
440 | } | 447 | } |
441 | 448 | ||
442 | QString Package::status() | 449 | QString Package::status() |
443 | { | 450 | { |
444 | return _status; | 451 | return _status; |
445 | } | 452 | } |
446 | 453 | ||
447 | bool Package::isOld() | 454 | bool Package::isOld() |
448 | { | 455 | { |
449 | if (!_versions) return false; | 456 | if (!_versions) return false; |
450 | QDictIterator<Package> other( *_versions ); | 457 | QDictIterator<Package> other( *_versions ); |
451 | while ( other.current() ) { | 458 | while ( other.current() ) { |
452 | if (other.current()->version() > version() ) return true; | 459 | if (other.current()->version() > version() ) return true; |
453 | ++other; | 460 | ++other; |
454 | } | 461 | } |
455 | return false; | 462 | return false; |
456 | } | 463 | } |
457 | 464 | ||
458 | bool Package::hasVersions() | 465 | bool Package::hasVersions() |
459 | { | 466 | { |
460 | if (!_versions) return false; | 467 | if (!_versions) return false; |
461 | else return true; | 468 | else return true; |
462 | } | 469 | } |
463 | 470 | ||
464 | QDict<Package>* Package::getOtherVersions() | 471 | QDict<Package>* Package::getOtherVersions() |
465 | { | 472 | { |
466 | return _versions; | 473 | return _versions; |
467 | } | 474 | } |
468 | 475 | ||
469 | void Package::setOtherVersions(QDict<Package> *v) | 476 | void Package::setOtherVersions(QDict<Package> *v) |
470 | { | 477 | { |
471 | _versions=v; | 478 | _versions=v; |