author | llornkcor <llornkcor> | 2005-03-01 07:56:26 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2005-03-01 07:56:26 (UTC) |
commit | 2f2b707684582cfa97c96c5fabab2197a7c7f307 (patch) (side-by-side diff) | |
tree | 72df20aae2b443f649f73e7f983eefe53a54109d | |
parent | e12f0049687c84c24f0b7b737b65df2ed6a500a5 (diff) | |
download | opie-2f2b707684582cfa97c96c5fabab2197a7c7f307.zip opie-2f2b707684582cfa97c96c5fabab2197a7c7f307.tar.gz opie-2f2b707684582cfa97c96c5fabab2197a7c7f307.tar.bz2 |
update to new gutenberg directory structures
-rw-r--r-- | noncore/apps/opie-gutenbrowser/LibraryDialog.cpp | 644 | ||||
-rw-r--r-- | noncore/apps/opie-gutenbrowser/LibraryDialog.h | 7 | ||||
-rw-r--r-- | noncore/apps/opie-gutenbrowser/NetworkDialog.cpp | 25 | ||||
-rw-r--r-- | noncore/apps/opie-gutenbrowser/gutenbrowser.cpp | 38 |
4 files changed, 352 insertions, 362 deletions
diff --git a/noncore/apps/opie-gutenbrowser/LibraryDialog.cpp b/noncore/apps/opie-gutenbrowser/LibraryDialog.cpp index 549c1d2..3b540c5 100644 --- a/noncore/apps/opie-gutenbrowser/LibraryDialog.cpp +++ b/noncore/apps/opie-gutenbrowser/LibraryDialog.cpp @@ -20,7 +20,7 @@ #include <qpe/applnk.h> #include <qpe/qpeapplication.h> #include <qpe/qpedialog.h> -#include <opie2/odebug.h> +//#include <opie2///odebug.h> /* QT */ #include <qpushbutton.h> @@ -34,7 +34,7 @@ /* * The dialog will by default be modeless, unless you set 'modal' to - * TRUE to construct a modal dialog. */ + * true to construct a modal dialog. */ LibraryDialog::LibraryDialog( QWidget* parent, const char* name , bool /*modal*/, WFlags fl ) : QDialog( parent, name, true/* modal*/, fl ) { @@ -50,13 +50,9 @@ LibraryDialog::LibraryDialog( QWidget* parent, const char* name , bool /*modal* local_index = local_library + index; QString iniFile ; - iniFile = QPEApplication::qpeDir()+"etc/gutenbrowser/gutenbrowserrc"; - - new_index =QPEApplication::qpeDir()+"etc/gutenbrowser/PGWHOLE.TXT"; - - old_index = QPEApplication::qpeDir()+"etc/gutenbrowser/GUTINDEX.ALL"; - // old_index = QPEApplication::qpeDir()+"etc/gutenbrowser/GUTINDEX.ALL"; - + iniFile = local_library + "/gutenbrowserrc"; + new_index = local_library + "/PGWHOLE.TXT"; + old_index = local_index; // iniFile = local_library+"gutenbrowserrc"; // new_index = local_library + "PGWHOLE.TXT"; // old_index = local_library + "GUTINDEX.ALL"; @@ -68,20 +64,20 @@ LibraryDialog::LibraryDialog( QWidget* parent, const char* name , bool /*modal* config.setGroup( "FTPsite" ); ftp_host=config.readEntry("SiteName", "sailor.gutenberg.org"); - odebug << "Library Dialog: ftp_host is "+ftp_host << oendl; - // ftp_host=ftp_host.right(ftp_host.length()-(ftp_host.find(") ",0,TRUE)+1) ); + //odebug << "Library Dialog: ftp_host is "+ftp_host << oendl; + // ftp_host=ftp_host.right(ftp_host.length()-(ftp_host.find(") ",0,true)+1) ); // ftp_host=ftp_host.stripWhiteSpace(); ftp_base_dir= config.readEntry("base", "/pub/gutenberg"); i_binary = 0; config.setGroup("SortAuth"); - if( config.readEntry("authSort", "FALSE") == "TRUE") - authBox->setChecked(TRUE); + if( config.readEntry("authSort", "false") == "true") + authBox->setChecked(true); config.setGroup("General"); downDir =config.readEntry( "DownloadDirectory",local_library); - odebug << "downDir is "+downDir << oendl; + //odebug << "downDir is "+downDir << oendl; newindexLib.setName( old_index); indexLib.setName( old_index); @@ -92,20 +88,22 @@ LibraryDialog::LibraryDialog( QWidget* parent, const char* name , bool /*modal* LibraryDialog::~LibraryDialog() { -// delete QList_Item2; -// delete QList_Item1; -// delete QList_Item3; -// delete QList_Item4; -// delete QList_Item5; +} - // saveConfig(); +void LibraryDialog::clearItems() { + ListView1->clear(); + ListView2->clear(); + ListView3->clear(); + ListView4->clear(); + ListView5->clear(); } /*This groks using PGWHOLE.TXT */ void LibraryDialog::Newlibrary() { + clearItems(); #ifndef Q_WS_QWS //sorry embedded gutenbrowser cant use zip files - //odebug << "Opening new library index " << newindexLib << "" << oendl; + ////odebug << "Opening new library index " << newindexLib << "" << oendl; if ( newindexLib.open( IO_ReadOnly) ) { setCaption( tr( "Library Index - using master pg index." ) );// file opened successfully QTextStream indexStream( &newindexLib ); @@ -114,61 +112,14 @@ void LibraryDialog::Newlibrary() indexLine = indexStream.readLine(); if ( ( indexLine.mid(4,4)).toInt() && !( indexLine.left(3)).toInt()) { year = indexLine.mid(4,4); - year = year.stripWhiteSpace(); - file = indexLine.mid( indexLine.find( "[", 0, TRUE )+1, 12 ); - file = file.stripWhiteSpace(); - number = indexLine.mid( indexLine.find( "]", 0, TRUE ) +1, indexLine.find( " ", 0, TRUE )+1 ); + file = indexLine.mid( indexLine.find( "[", 0, true )+1, 12 ); + number = indexLine.mid( indexLine.find( "]", 0, true ) +1, indexLine.find( " ", 0, true )+1 ); if( year.toInt() < 1984) number = number.left( number.length() -1 ); - number = number.stripWhiteSpace(); - title = indexLine.mid( indexLine.find(" ", 26, TRUE), indexLine.length() ); - title = title.stripWhiteSpace(); - - getAuthor(); // groks author - author = author.stripWhiteSpace(); - if (authBox->isChecked()) { // this reverses the first name and last name of the author - // odebug << "Sorting last name first" << oendl; - QString lastName, firstName=""; - int finder=author.findRev( ' ', -1, TRUE); - lastName=author.right( author.length()-finder); - firstName=author.left(finder); - lastName=lastName.stripWhiteSpace(); - firstName=firstName.stripWhiteSpace(); - - if( lastName.find( firstName, 0, true) == -1) // this avoids dup names - author=lastName+", "+firstName; - } - - if( !number.isEmpty() - && (title.find( "reserved",0, FALSE) == -1) - && (file.find( "]",0, TRUE) == -1) - && (title.find( "Audio",0, FALSE) == -1)) { - - // fill string list or something to be able to resort the whole library - if( author.isEmpty() ) - QList_Item5 = new QListViewItem( ListView5, /* number,*/ title, author, year, file ); - else { - - if( (author.left(1) >= QString("A") && author.left(1) <= QString("F")) || - (author.left(1) >= QString("a") && author.left(1) <= QString("f")) ) - QList_Item1 = new QListViewItem( ListView1,/* number,*/ title, author, year, file ); - - else if( (author.left(1) >= QString("G") && author.left(1) <= QString("M")) || - (author.left(1) >= QString("g") && author.left(1) <= QString("m")) ) - QList_Item2 = new QListViewItem( ListView2, /*number, */title, author, year, file ); - - else if( (author.left(1) >= QString("N") && author.left(1) <= QString("R")) || - (author.left(1) >= QString("n") && author.left(1) <= QString("r")) ) - QList_Item3 = new QListViewItem( ListView3, /*number,*/ title, author, year, file ); + title = indexLine.mid( indexLine.find(" ", 26, true), indexLine.length() ); - else if( (author.left(1) >= QString("S") && author.left(1) <= QString("Z")) || - (author.left(1) >= QString("s") && author.left(1) <= QString("z")) ) - QList_Item4 = new QListViewItem( ListView4, /* number,*/ title, author, year, file ); + addItems(); - else - QList_Item5 = new QListViewItem( ListView5, /* number,*/ title, author, year, file ); - } - } }// end if }// end while newindexLib.close(); @@ -180,99 +131,67 @@ void LibraryDialog::Newlibrary() } // end Newlibrary() -void LibraryDialog::Library() -{// old library groking method - - ListView1->clear(); - ListView2->clear(); - ListView3->clear(); - ListView4->clear(); - ListView5->clear(); +void LibraryDialog::Library() { + clearItems(); - odebug << "opening GUTINDEX.ALL file" << oendl; +// qDebug( "opening GUTINDEX.ALL file"); IDontKnowWhy = ""; if ( indexLib.open( IO_ReadOnly) ) { // file opened successfully QTextStream indexStream( &indexLib ); QString indexLine; qApp->processEvents(); - // int jig; + while ( !indexStream.eof() ) { indexLine = indexStream.readLine(); if ( indexLine != "") { - if( (indexLine.mid(4,4)).toInt() /* && !( indexLine.left(3)).toInt()*/ ) { - // month = indexLine.left( 3); + + if( (indexLine.mid(4,4)).toInt() ) { + year = indexLine.mid(4,4); - // title = indexLine.mid( 9, 50); file = indexLine.mid(60,12); if(file.left(1).find("[",0,TRUE) != -1) file.remove(1,1); if( file.find("]",0,TRUE) != -1) file = file.left( file.find("]",0,TRUE)); - if(file.find("?", 0, false) != -1 ) { QString tmpfile = file.replace(QRegExp("[?]"), "8"); -// qDebug( "file is now " + tmpfile ); file = tmpfile; } -// number = indexLine.mid( indexLine.find( "]", 0, TRUE ) +1, indexLine.find( " ", 0, TRUE )+1 ); number = indexLine.mid(55,5); - number = number.stripWhiteSpace(); - // title = indexLine.mid( indexLine.find(" ", 26, TRUE), indexLine.length() ); title = indexLine.mid( 9, 50 ); - title = title.stripWhiteSpace(); - //odebug << "title is "+title << oendl; - getAuthor(); // grok author - author = author.stripWhiteSpace(); - //odebug << "author is "+author << oendl; - if (authBox->isChecked() == TRUE) { // this reverses the first name and last name of the author - QString lastName, firstName=""; - int finder=author.findRev( ' ', -1, TRUE); - lastName=author.right( author.length()-finder); - firstName=author.left(finder); - lastName=lastName.stripWhiteSpace(); - firstName=firstName.stripWhiteSpace(); - - if( lastName.find( firstName, 0, true) == -1) // this avoids dup names - author=lastName+", "+firstName; - } - if( !number.isEmpty() - && (title.find( "reserved",0, FALSE) == -1) - &&(title.find( "Audio",0, FALSE) == -1)) { - // fill string list or something to be able to sort by Author - if( author.isEmpty() ) - QList_Item5 = new QListViewItem( ListView5, /*number, */title, author, year, file ); - else { - if( (author.left(1) >= QString("A") && author.left(1) <= QString("F")) || - (author.left(1) >= QString("a") && author.left(1) <= QString("f")) ) - QList_Item1 = new QListViewItem( ListView1, /* number,*/ title, author, year, file ); + addItems(); - else if( (author.left(1) >= QString("G") && author.left(1) <= QString("M")) || - (author.left(1) >= QString("g") && author.left(1) <= QString("m")) ) - QList_Item2 = new QListViewItem( ListView2, /* number,*/ title, author, year, file ); + } + else if ( indexLine.mid(73,5).toInt() && indexLine.mid(73,5).toInt() > 10000 ) { +// newer files with numbers > 100000 have new dir structure and need to be parsed differently.. + number = indexLine.mid(73,5); + int num = number.toInt(); + if(num < 10626) + year = "2003"; + else if(num >= 10626 && num < 14600) + year = "2004"; + else if(num >= 14600) + year = "2005"; - else if( (author.left(1) >= QString("N") && author.left(1) <= QString("R")) || - (author.left(1) >= QString("n") && author.left(1) <= QString("r")) ) - QList_Item3 = new QListViewItem( ListView3, /* number,*/ title, author, year, file ); + file = number;// + ".txt"; + title = indexLine.mid(0,72); - else if( (author.left(1) >= QString("S") && author.left(1) <= QString("Z")) || - (author.left(1) >= QString("s") && author.left(1) <= QString("z")) ) - QList_Item4 = new QListViewItem( ListView4, /* number,*/ title, author, year, file ); - } - } + addItems(); + // qDebug("file number is " + number + " title is " + title ); } } } indexLib.close(); } else { QString sMsg; - sMsg = ( tr("<p>Error opening local library index:</P> "))+local_index; + + sMsg = ( tr("<p>Error opening library index file. Please download a new one.</P> ")); QMessageBox::message( "Error",sMsg); } - } //end Library() @@ -280,64 +199,64 @@ void LibraryDialog::Library() Groks the author out of the title */ bool LibraryDialog::getAuthor() { - if( title.contains( ", by", TRUE)) { + if( title.contains( ", by", true)) { int auth; - auth = title.find(", by", 0, TRUE); + auth = title.find(", by", 0, true); author = title.right(title.length() - (auth + 4) ); - if( int finder = author.find("[", 0, TRUE)) { + if( int finder = author.find("[", 0, true)) { author = author.left(finder); } } - else if ( title.contains( "by, ", TRUE) ) { + else if ( title.contains( "by, ", true) ) { int auth; - auth = title.find("by, ", 0, TRUE); + auth = title.find("by, ", 0, true); author = title.right(title.length() - (auth + 4) ); - if( int finder = author.find("[", 0, TRUE)) { + if( int finder = author.find("[", 0, true)) { author = author.left( finder); } } - else if ( title.contains( " by", TRUE) ) { + else if ( title.contains( " by", true) ) { int auth; - auth = title.find(" by", 0, TRUE); + auth = title.find(" by", 0, true); author = title.right(title.length() - (auth + 3) ); - if( int finder = author.find("[", 0, TRUE)) { + if( int finder = author.find("[", 0, true)) { author = author.left( finder); } } - else if ( title.contains( "by ", TRUE) ) { + else if ( title.contains( "by ", true) ) { int auth; - auth = title.find("by ", 0, TRUE); + auth = title.find("by ", 0, true); author = title.right(title.length() - (auth + 3) ); - if( int finder = author.find("[", 0, TRUE)) { + if( int finder = author.find("[", 0, true)) { author = author.left( finder); } } - else if ( title.contains( ",", TRUE) ) { + else if ( title.contains( ",", true) ) { int auth; - auth = title.find(",", 0, TRUE); + auth = title.find(",", 0, true); author = title.right( title.length() - (auth + 1) ); - if ( author.contains( ",", TRUE) ) { + if ( author.contains( ",", true) ) { int auth; - auth = author.find(",", 0, TRUE); + auth = author.find(",", 0, true); author = author.right( author.length() - (auth + 1) ); } - if( int finder = author.find("[", 0, TRUE)) { + if( int finder = author.find("[", 0, true)) { author = author.left( finder); } } - else if ( title.contains( "/", TRUE) ) { + else if ( title.contains( "/", true) ) { int auth; - auth = title.find("/", 0, TRUE); + auth = title.find("/", 0, true); author = title.right(title.length() - (auth + 1) ); - if( int finder = author.find("[", 0, TRUE)) { + if( int finder = author.find("[", 0, true)) { author = author.left( finder); } } - else if ( title.contains( "of", TRUE) ) { + else if ( title.contains( "of", true) ) { int auth; - auth = title.find("of", 0, TRUE); + auth = title.find("of", 0, true); author = title.right(title.length() - (auth + 2) ); - if( int finder = author.find("[", 0, TRUE)) + if( int finder = author.find("[", 0, true)) { author = author.left( finder); } @@ -346,38 +265,75 @@ bool LibraryDialog::getAuthor() } if ( author.contains("et. al")) { int auth; - auth = author.find("et. al", 0, TRUE); + auth = author.find("et. al", 0, true); author = author.left( auth ); } if ( author.contains("#")) { int auth; - auth = author.find("#", 0, TRUE); + auth = author.find("#", 0, true); author = author.left( auth); } if ( author.contains("(")) { int auth; - auth = author.find("(", 0, TRUE); + auth = author.find("(", 0, true); author = author.left( auth); } if ( author.contains("et al")) { int auth; - auth = author.find("et al", 0, TRUE); + auth = author.find("et al", 0, true); author = author.left( auth ); } - QRegExp r = QRegExp("[0-9]", TRUE, FALSE); + QRegExp r = QRegExp("[0-9]", true, false); if ( author.left(2).find( r) != -1 ) { author = ""; } - // if( author.contains(" ", TRUE)) { - // int suth = author.findRev(" ", -1, TRUE); - // author = author.right( author.length() - suth); - // } - // title - // author + author = author.stripWhiteSpace(); + if (authBox->isChecked() == TRUE) { // this reverses the first name and last name of the author + QString lastName, firstName=""; + int finder = author.findRev( ' ', -1, TRUE); + lastName = author.right( author.length()-finder); + firstName = author.left(finder); + lastName = lastName.stripWhiteSpace(); + firstName = firstName.stripWhiteSpace(); + + if( lastName.find( firstName, 0, true) == -1) // this avoids dup names + author = lastName+", "+firstName; + } return true; }////// end getAuthor() +void LibraryDialog::addItems() { + cleanStrings(); + getAuthor(); // grok author + if( !number.isEmpty() + && (title.find( "reserved",0, FALSE) == -1) + && (file.find( "]",0, true) == -1) + &&(title.find( "Audio",0, FALSE) == -1)) { +// qDebug("new item "+title); + // fill string list or something to be able to sort by Author + if( author.isEmpty() ) + QList_Item5 = new QListViewItem( ListView5, /*number, */title, author, year, file ); + else { + if( (author.left(1) >= QString("A") && author.left(1) <= QString("F")) || + (author.left(1) >= QString("a") && author.left(1) <= QString("f")) ) + QList_Item1 = new QListViewItem( ListView1, /* number,*/ title, author, year, file ); + + else if( (author.left(1) >= QString("G") && author.left(1) <= QString("M")) || + (author.left(1) >= QString("g") && author.left(1) <= QString("m")) ) + QList_Item2 = new QListViewItem( ListView2, /* number,*/ title, author, year, file ); + + else if( (author.left(1) >= QString("N") && author.left(1) <= QString("R")) || + (author.left(1) >= QString("n") && author.left(1) <= QString("r")) ) + QList_Item3 = new QListViewItem( ListView3, /* number,*/ title, author, year, file ); + + else if( (author.left(1) >= QString("S") && author.left(1) <= QString("Z")) || + (author.left(1) >= QString("s") && author.left(1) <= QString("z")) ) + QList_Item4 = new QListViewItem( ListView4, /* number,*/ title, author, year, file ); + } + } +} + /* selected one etext*/ void LibraryDialog::select_title( QListViewItem * item) @@ -388,6 +344,7 @@ void LibraryDialog::select_title( QListViewItem * item) DlglistItemTitle = item->text(0); DlglistItemYear = item->text(2); DlglistItemFile = item->text(3); + switch (index) { case 0: { ListView1->clearSelection(); @@ -413,85 +370,77 @@ void LibraryDialog::select_title( QListViewItem * item) } if(DlglistItemTitle.length()>2) { - // DlglistItemNumber = item->text(0); item = 0; - odebug << "string from librarydialog is:" << DlglistItemYear << " " << DlglistItemFile << " " << DlglistItemNumber << "" << oendl; - odebug << "Title is "+DlglistItemTitle << oendl; + // todo check for connection here - // check for connection here - // if( get_extext()) - - if(download_Etext()) { - // odebug << "get here 2" << oendl; - if(i_binary == 1) { + bool ok = false; + qDebug(DlglistItemFile); + if( DlglistItemFile.toInt() > 10000 ) { + // new directory sturcture + if( download_newEtext()) + ok = true; + } else { + if(download_Etext()) + ok = true; } - if(checkBox->isChecked () ) { + if(ok) { + if(checkBox->isChecked () ) accept(); } } } -} -bool LibraryDialog::download_Etext() +bool LibraryDialog::download_newEtext() { // ftp method - // might have to use old gpl'd ftp for embedded!! + QString fileName = DlglistItemFile; + + QString directory; + int stringlength = DlglistItemFile.length(); + for(i = 0; i < stringlength - 1; i++ ) { + directory += "/"+ DlglistItemFile[i]; + } + + directory += "/" + DlglistItemFile; + +// qWarning(directory); + Config cfg("Gutenbrowser"); cfg.setGroup("FTPsite"); ftp_host=cfg.readEntry("SiteName", "sailor.gutenberg.org"); ftp_base_dir= cfg.readEntry("base", "/pub/gutenberg"); - odebug << "about to network dialog" << oendl; - QString NewlistItemNumber, NewlistItemYear, ls_result, result_line, s, dir, networkUrl, outputFile; - - //////////////////// FIXME- if 'x' is part of real name.... - NewlistItemFile = DlglistItemFile.left(DlglistItemFile.find(".xxx", 1, FALSE)).left(DlglistItemFile.left(DlglistItemFile.find(".xxx", 1, FALSE)).find("x", 1, FALSE)); - - if( NewlistItemFile.find( DlglistItemFile.left(4) ,0,TRUE) ==-1 ) { - NewlistItemFile.replace( 0,4, DlglistItemFile.left(4)); - odebug << "NewlistItemFile is now "+NewlistItemFile << oendl; - } - NewlistItemYear = DlglistItemYear.right(2); - int NewlistItemYear_Int = NewlistItemYear.toInt(0, 10); - odebug << NewlistItemYear << oendl; - if (NewlistItemYear_Int < 91 && NewlistItemYear_Int > 70) { - NewlistItemYear = "90"; - } - Edir ="etext" +NewlistItemYear; - dir= ftp_base_dir + "/etext" +NewlistItemYear+"/"; if( ftp_base_dir.find("=",0,true) ) ftp_base_dir.remove( ftp_base_dir.find("=",0,true),1); - networkUrl= "ftp://"+ftp_host+dir; + QString dir = ftp_base_dir + directory; + QString outputFile = local_library + ".guten_temp"; + QString file = fileName + ".txt"; - outputFile=local_library+".guten_temp"; - //odebug << "Download file:" << NewlistItemFile << "" << oendl; - odebug << "Checking: "+ftp_host+" "+dir+" "+outputFile+" "+NewlistItemFile << oendl; QStringList networkList; - networkList.append((const char *)ftp_host); - networkList.append((const char *)dir); - networkList.append((const char *)outputFile); - networkList.append((const char *)NewlistItemFile); -//<< (char *)ftp_host << (char *)dir << (char *)outputFile << (char *)NewlistItemFile; + networkList.append((const char *)ftp_host); //host + networkList.append((const char *)dir); //ftp base directory + networkList.append((const char *)outputFile); //output filepath + networkList.append((const char *)file); //filename - NetworkDialog *NetworkDlg; - NetworkDlg = new NetworkDialog( this,"Network Protocol Dialog", TRUE, 0, networkList); + getEtext( networkList); + + return true; +} +bool LibraryDialog::getEtext(const QStringList &networkList) +{ + NetworkDialog *NetworkDlg; + NetworkDlg = new NetworkDialog( this,"Network Protocol Dialog", true, 0, networkList); - if( NetworkDlg->exec() != 0 ) { // use new, improved, *INSTANT* network-dialog-file-getterer +// use new, improved, *INSTANT* network-dialog-file-getterer + if( NetworkDlg->exec() != 0 ) { File_Name= NetworkDlg->localFileName; - odebug << "back to Library from Network Dialog" << oendl; - odebug << "Just downloaded "+NetworkDlg->localFileName << oendl; - // if (File_Name.find( local_library, 0, TRUE) != -1 ) { //could not be found - // QString oldName=File_Name; - // File_Name.replace(0,local_library.length(),downDir); - // odebug << "File_Name now is "+File_Name << oendl; + qDebug("Just downloaded " + NetworkDlg->localFileName); - // } - // rename .txt to .etx if(NetworkDlg->successDownload) { - odebug << "Filename is "+File_Name << oendl; + //odebug << "Filename is "+File_Name << oendl; if(File_Name.right(4)==".txt") { QString s_fileName=File_Name; s_fileName.replace( s_fileName.length()-3,3,"gtn"); @@ -499,7 +448,7 @@ bool LibraryDialog::download_Etext() rename(File_Name.latin1(),s_fileName.latin1()); File_Name=s_fileName; - odebug << "Filename is now "+File_Name << oendl; + //odebug << "Filename is now "+File_Name << oendl; } if(File_Name.length() > 5 ) { @@ -508,26 +457,81 @@ bool LibraryDialog::download_Etext() QString name_file=fi.fileName(); name_file=name_file.left(name_file.length()-4); - odebug << "Setting doclink" << oendl; + //odebug << "Setting doclink" << oendl; DocLnk lnk; - odebug << "name is "+name_file << oendl; + //odebug << "name is "+name_file << oendl; lnk.setName(name_file); //sets file name - odebug << "Title is "+DlglistItemTitle << oendl; + //odebug << "Title is "+DlglistItemTitle << oendl; lnk.setComment(DlglistItemTitle); - odebug << "Filename is "+File_Name << oendl; + //odebug << "Filename is "+File_Name << oendl; lnk.setFile(File_Name); //sets File property lnk.setType("guten/plain");// hey is this a REGISTERED mime type?!?!? ;D lnk.setExec(File_Name); lnk.setIcon("gutenbrowser/Gutenbrowser"); if(!lnk.writeLink()) { - odebug << "Writing doclink did not work" << oendl; + //odebug << "Writing doclink did not work" << oendl; } else { } } else QMessageBox::message("Note","<p>There was an error with the file</p>"); } } + + return true; +} + +bool LibraryDialog::download_Etext() +{ // ftp method + // might have to use old gpl'd ftp for embedded!! + + Config cfg("Gutenbrowser"); + cfg.setGroup("FTPsite"); + ftp_host = cfg.readEntry("SiteName", "sailor.gutenberg.org"); + ftp_base_dir = cfg.readEntry("base", "/pub/gutenberg"); + + qDebug( "about to network dialog"); + + QString NewlistItemNumber, NewlistItemYear, ls_result, result_line, s, dir, /*networkUrl, */outputFile; + + //////////////////// FIXME- if 'x' is part of real name.... + NewlistItemFile = DlglistItemFile.left(DlglistItemFile.find(".xxx", 1, false)).left(DlglistItemFile.left(DlglistItemFile.find(".xxx", 1, false)).find("x", 1, false)); + + if( NewlistItemFile.find( DlglistItemFile.left(4) ,0,true) ==-1 ) { + NewlistItemFile.replace( 0,4, DlglistItemFile.left(4)); + qDebug("NewlistItemFile is now " + NewlistItemFile); + } + + NewlistItemYear = DlglistItemYear.right(2); + int NewlistItemYear_Int = NewlistItemYear.toInt(0, 10); + //odebug << NewlistItemYear << oendl; + if (NewlistItemYear_Int < 91 && NewlistItemYear_Int > 70) { + NewlistItemYear = "90"; + } + + Edir ="etext" +NewlistItemYear; + + dir = ftp_base_dir + "/etext" + NewlistItemYear + "/"; + + if( ftp_base_dir.find("=",0,true) ) + ftp_base_dir.remove( ftp_base_dir.find("=",0,true),1); + +// networkUrl = "ftp://"+ftp_host+dir; + + outputFile = local_library+".guten_temp"; + + qDebug( "Download file: " +NewlistItemFile); + qDebug("Checking: " + ftp_host + " " + dir + " " + outputFile+" " + NewlistItemFile); + + + QStringList networkList; + networkList.append((const char *)ftp_host); //host + networkList.append((const char *)dir); //ftp base directory + networkList.append((const char *)outputFile); //output filepath + networkList.append((const char *)NewlistItemFile); //filename +//<< (char *)ftp_host << (char *)dir << (char *)outputFile << (char *)NewlistItemFile; + getEtext( networkList); + return true; } @@ -556,8 +560,8 @@ bool LibraryDialog::httpDownload() QTextStream t( &tmp ); // use a text stream while ( !t.eof()) { QString s = t.readLine(); - if (s.contains( NewlistItemFile, FALSE) && (s.contains(".txt")) ) { - str = s.mid( s.find( ".txt\">"+NewlistItemFile, 0, TRUE)+6, (s.find( ".txt</A>", 0, TRUE) + 4) - ( s.find( ".txt\">"+NewlistItemFile, 0, TRUE)+6 ) ); + if (s.contains( NewlistItemFile, false) && (s.contains(".txt")) ) { + str = s.mid( s.find( ".txt\">"+NewlistItemFile, 0, true)+6, (s.find( ".txt</A>", 0, true) + 4) - ( s.find( ".txt\">"+NewlistItemFile, 0, true)+6 ) ); httpName += "/" + str; } } //end of while loop @@ -588,14 +592,14 @@ void LibraryDialog::cancelIt() bool LibraryDialog::setTitle() { Config config("Gutenbrowser"); - odebug << "setting title" << oendl; - odebug << DlglistItemTitle << oendl; - - if( DlglistItemTitle.find("[",0,TRUE) != -1) - DlglistItemTitle.replace(DlglistItemTitle.find("[",0,TRUE),1, "(" ); - if( DlglistItemTitle.find("]",0,TRUE) !=-1) - DlglistItemTitle.replace(DlglistItemTitle.find("]",0,TRUE),1, ")" ); - odebug << "Title being set is "+DlglistItemTitle << oendl; + //odebug << "setting title" << oendl; + //odebug << DlglistItemTitle << oendl; + + if( DlglistItemTitle.find("[",0,true) != -1) + DlglistItemTitle.replace(DlglistItemTitle.find("[",0,true),1, "(" ); + if( DlglistItemTitle.find("]",0,true) !=-1) + DlglistItemTitle.replace(DlglistItemTitle.find("]",0,true),1, ")" ); + //odebug << "Title being set is "+DlglistItemTitle << oendl; int test = 0; QString ramble, temp; config.setGroup("Files"); @@ -608,6 +612,9 @@ bool LibraryDialog::setTitle() test = 1; } } + + if(test == 0 ) { + config.setGroup("Files"); config.writeEntry( "NumberOfFiles", i_numofFiles +1 ); QString interger; @@ -615,7 +622,7 @@ bool LibraryDialog::setTitle() config.writeEntry( interger, File_Name); config.setGroup( "Titles" ); config.writeEntry( File_Name, DlglistItemTitle); - + } test = 0; return true; } @@ -624,21 +631,21 @@ bool LibraryDialog::setTitle() void LibraryDialog::saveConfig() { Config config("Gutenbrowser"); - if( httpBox->isChecked() == TRUE) { + if( httpBox->isChecked() == true) { checked = 1; config.setGroup( "Proxy" ); - config.writeEntry("IsChecked", "TRUE"); + config.writeEntry("IsChecked", "true"); } else { checked = 0; config.setGroup( "Proxy" ); - config.writeEntry("IsChecked", "FALSE"); + config.writeEntry("IsChecked", "false"); } - if (authBox->isChecked() == TRUE) { + if (authBox->isChecked() == true) { config.setGroup("SortAuth"); - config.writeEntry("authSort", "TRUE"); + config.writeEntry("authSort", "true"); } else { config.setGroup("SortAuth"); - config.writeEntry("authSort", "FALSE"); + config.writeEntry("authSort", "false"); } // config.write(); } @@ -657,10 +664,12 @@ void LibraryDialog::onButtonSearch() SearchDialog* searchDlg; // if( resultsList) - searchDlg = new SearchDialog( this, "Library Search", TRUE); + searchDlg = new SearchDialog( this, "Library Search", true); searchDlg->setCaption( tr( "Library Search" ) ); searchDlg->setLabel( "- author or title"); + QString resultString; + int i_berger = 0; if( searchDlg->exec() != 0 ) { QString searcherStr = searchDlg->get_text(); @@ -756,9 +765,11 @@ void LibraryDialog::onButtonSearch() SearchResultsDialog->showMaximized(); if( SearchResultsDialog->exec() != 0) { texter = SearchResultsDialog->selText; - // odebug << texter << oendl; + // //odebug << texter << oendl; resultLs= SearchResultsDialog->resultsList; i_berger = 1; + } else { + resultLs.clear(); } Searchlist.clear(); @@ -767,7 +778,7 @@ void LibraryDialog::onButtonSearch() QString tester; for ( QStringList::Iterator it = resultLs.begin(); it != resultLs.end(); ++it ) { texter.sprintf("%s \n",(*it).latin1()); - // odebug << texter << oendl; + // //odebug << texter << oendl; if( tester!=texter) parseSearchResults( texter); tester = texter; @@ -786,68 +797,37 @@ void LibraryDialog::onButtonSearch() splits the result string and calls download for the current search result*/ void LibraryDialog::parseSearchResults( QString resultStr) { - int stringLeng=resultStr.length(); + QString my; my.setNum( stringLeng, 10); if( resultStr.length() > 2 && resultStr.length() < 130) { - int titleInt = resultStr.find( " : ", 0, TRUE); + + int titleInt = resultStr.find( " : ", 0, true); DlglistItemTitle = resultStr.left( titleInt); - int yearInt = resultStr.find( " : ", titleInt+3, TRUE); + + int yearInt = resultStr.find( " : ", titleInt+3, true); + DlglistItemYear = resultStr.mid( titleInt+3, (yearInt - titleInt)-3); + DlglistItemFile = resultStr.right( resultStr.length() - (yearInt + 3)); - download_Etext(); + DlglistItemFile = DlglistItemFile.left( DlglistItemFile.length() - 2); + + cleanStrings(); + + if(DlglistItemFile.left(1) == "/") + DlglistItemFile = DlglistItemFile.right( DlglistItemFile.length() - 1); + + + if( DlglistItemFile.toInt() > 10000 ) { + // new directory sturcture + download_newEtext(); //) + } else { + download_Etext(); //) + } + } } - /* - printf( DlglistItemTitle+"\n"); printf( DlglistItemYear+"\n"); printf( DlglistItemFile+"\n");*/ -} - - // bool LibraryDialog::UnzipIt( QString zipFile) { - // //////////TODO findsome other way of dealingwithzip files. - // ///usr/bin/unzip"; - // if( QFile::exists( zipFile)) { - // // QString thatFile = local_library +"PGWHOLE.TXT"; - // QString cmd; - // #if defined(_WS_X11_) - // cmd = "gunzip -d " + zipFile /*newestLibraryFile */+" -d " + local_library; - // #endif - // #if defined(_WS_WIN_) - // QString temp= QDir::convertSeparators(local_library); - // zipFile=QDir::convertSeparators( zipFile); - // cmd = temp+"unzip.exe -o " +zipFile/*newestLibraryFile */+" -d " + temp; - // #endif - // #ifndef Q_WS_QWS - // // QString cmd = "gunzip -d " + zipFile /*newestLibraryFile */+" -d " + local_library; - // cmd = "unzip " + zipFile; - // #endif - - // int exit=QMessageBox::information(this, "Unzip?", "Ok to unzip "+ zipFile+" ?", QMessageBox::Yes, QMessageBox::No); - // if (exit==QMessageBox::Yes) { - // odebug << "Issuing the command "+cmd << oendl; - // #if defined(_WS_WIN_) - // WinExec( cmd, SW_HIDE ); - // #endif - // #if defined(_WS_X11_) - // system( cmd); - // #endif - // #ifndef Q_WS_QWS - // system( cmd); - // #endif - // // printf("unzip\n"); - // // remove( zipFile /*newestLibraryFile*/); - // return true; - // } - // else if(exit==QMessageBox::No) { - // // printf("unzip\n"); - // return false; - // } - // } else { - // // QMessageBox::message( "Note",( tr("Please install unzip in your PATH")) ); - // return false; - // } - // return true; - // } void LibraryDialog::sort() { @@ -858,7 +838,7 @@ void LibraryDialog::sort() Downloads the current selected listitem*/ bool LibraryDialog::getItem(QListViewItem *it) { - // odebug << "selected getItem" << oendl; + // //odebug << "selected getItem" << oendl; // DlglistItemNumber = it->text(0); DlglistItemTitle = it->text(0); @@ -876,7 +856,7 @@ bool LibraryDialog::getItem(QListViewItem *it) download button is pushed so we get the current items to download*/ bool LibraryDialog::onButtonDownload() { - // odebug << "selected onButtonDownloadz" << oendl; + // //odebug << "selected onButtonDownloadz" << oendl; QListViewItemIterator it1( ListView1 ); QListViewItemIterator it2( ListView2 ); @@ -888,27 +868,27 @@ bool LibraryDialog::onButtonDownload() for ( ; it1.current(); ++it1 ) { if ( it1.current()->isSelected() ) getItem(it1.current()); - it1.current()->setSelected(FALSE); + it1.current()->setSelected(false); } for ( ; it2.current(); ++it2 ) { if ( it2.current()->isSelected() ) getItem(it2.current()); - it2.current()->setSelected(FALSE); + it2.current()->setSelected(false); } for ( ; it3.current(); ++it3 ) { if ( it3.current()->isSelected() ) getItem(it3.current()); - it3.current()->setSelected(FALSE); + it3.current()->setSelected(false); } for ( ; it4.current(); ++it4 ) { if ( it4.current()->isSelected() ) getItem(it4.current()); - it4.current()->setSelected(FALSE); + it4.current()->setSelected(false); } for ( ; it5.current(); ++it5 ) { if ( it5.current()->isSelected() ) getItem(it5.current()); - it5.current()->setSelected(FALSE); + it5.current()->setSelected(false); } return true; } @@ -918,12 +898,12 @@ bool LibraryDialog::onButtonDownload() handles the sorting combo box */ void LibraryDialog::comboSelect(int index) { - // odebug << "we are sorting" << oendl; - ListView1->setSorting( index, TRUE); - ListView2->setSorting( index, TRUE); - ListView3->setSorting( index, TRUE); - ListView4->setSorting( index, TRUE); - ListView5->setSorting( index, TRUE); + // //odebug << "we are sorting" << oendl; + ListView1->setSorting( index, true); + ListView2->setSorting( index, true); + ListView3->setSorting( index, true); + ListView4->setSorting( index, true); + ListView5->setSorting( index, true); ListView1->sort(); ListView2->sort(); @@ -944,12 +924,10 @@ void LibraryDialog::newList() onButtonDownload(); } else { Output *outDlg; - buttonNewList->setDown(TRUE); - QDir gutDir(QPEApplication::qpeDir()+"etc/gutenbrowser"); - if(!gutDir.exists()) gutDir.mkdir(QPEApplication::qpeDir()+"etc/gutenbrowser",true); - if( chdir(QPEApplication::qpeDir()+"etc/gutenbrowser") == 0) { - odebug << "changing dir "+QPEApplication::qpeDir()+"etc/gutenbrowser" << oendl; - QString gutenindex1 = QPEApplication::qpeDir()+"etc/gutenbrowser/GUTINDEX.ALL"; + buttonNewList->setDown(true); + //odebug << "changing dir "+QPEApplication::qpeDir()+"etc/gutenbrowser" << oendl; + QString gutenindex1 = local_library + "/GUTINDEX.ALL"; + QString cmd="wget -O " + gutenindex1 + " http://sailor.gutenberg.org/GUTINDEX.ALL 2>&1"; int result = QMessageBox::warning( this,"Download" @@ -957,33 +935,33 @@ void LibraryDialog::newList() ,"Yes","No",0,0,1); qApp->processEvents(); if(result == 0) { - outDlg = new Output( 0, tr("Downloading Gutenberg Index...."),TRUE); + outDlg = new Output( 0, tr("Downloading Gutenberg Index...."),true); outDlg->showMaximized(); outDlg->show(); qApp->processEvents(); FILE *fp; char line[130]; outDlg->OutputEdit->append( tr("Running wget") ); - outDlg->OutputEdit->setCursorPosition(outDlg->OutputEdit->numLines() + 1,0,FALSE); + outDlg->OutputEdit->setCursorPosition(outDlg->OutputEdit->numLines() + 1,0,false); sleep(1); fp = popen( (const char *) cmd, "r"); if ( !fp ) { } else { - odebug << "Issuing the command\n"+cmd << oendl; + //odebug << "Issuing the command\n"+cmd << oendl; // system(cmd); while ( fgets( line, sizeof line, fp)) { outDlg->OutputEdit->append(line); - outDlg->OutputEdit->setCursorPosition(outDlg->OutputEdit->numLines() + 1,0,FALSE); + outDlg->OutputEdit->setCursorPosition(outDlg->OutputEdit->numLines() + 1,0,false); } pclose(fp); outDlg->OutputEdit->append("Finished downloading\n"); - outDlg->OutputEdit->setCursorPosition(outDlg->OutputEdit->numLines() + 1,0,FALSE); + outDlg->OutputEdit->setCursorPosition(outDlg->OutputEdit->numLines() + 1,0,false); qApp->processEvents(); // if( QFile(gutenindex1).exists() ) { // QString gutenindex=QPEApplication::qpeDir()+"etc/gutenbrowser/GUTINDEX.ALL"; // if( rename(gutenindex1.latin1(),gutenindex.latin1()) !=0) - // odebug << "renaming error" << oendl; + // //odebug << "renaming error" << oendl; // } } @@ -991,10 +969,8 @@ void LibraryDialog::newList() FindLibrary(); if(outDlg) delete outDlg; } - buttonNewList->setDown(FALSE); - } else { - QMessageBox::message("Note","Could not change directories"); - } + buttonNewList->setDown(false); + // if(outDlg) // delete outDlg; } @@ -1042,7 +1018,7 @@ bool LibraryDialog::moreInfo() } item=0; if(titleString.length()>2) { - odebug << "Title is "+titleString << oendl; + //odebug << "Title is "+titleString << oendl; titleString.replace( QRegExp("\\s"), "%20"); titleString.replace( QRegExp("'"), "%20"); titleString.replace( QRegExp("\""), "%20"); @@ -1060,26 +1036,34 @@ bool LibraryDialog::moreInfo() This loads the library Index*/ void LibraryDialog::FindLibrary() { - buttonLibrary->setDown(TRUE); + buttonLibrary->setDown(true); qApp->processEvents(); if( QFile( new_index).exists() /* && this->isHidden() */) { newindexLib.setName( new_index); indexLib.setName( new_index); - odebug << "index file is "+ new_index << oendl; + //odebug << "index file is "+ new_index << oendl; Newlibrary(); } else { newindexLib.setName( old_index); indexLib.setName( old_index); - odebug << "new index nameis "+ old_index << oendl; + //odebug << "new index nameis "+ old_index << oendl; Library(); } indexLoaded=true; - buttonSearch->setEnabled(TRUE); - moreInfoButton->setEnabled(TRUE); + buttonSearch->setEnabled(true); + moreInfoButton->setEnabled(true); - buttonLibrary->setDown(FALSE); + buttonLibrary->setDown(false); buttonNewList->setText("Download"); qApp->processEvents(); } + +void LibraryDialog::cleanStrings() { + year = year.stripWhiteSpace(); + file = file.stripWhiteSpace(); + title = title.stripWhiteSpace(); + number = number.stripWhiteSpace(); + +} diff --git a/noncore/apps/opie-gutenbrowser/LibraryDialog.h b/noncore/apps/opie-gutenbrowser/LibraryDialog.h index f5bfe08..8d6352f 100644 --- a/noncore/apps/opie-gutenbrowser/LibraryDialog.h +++ b/noncore/apps/opie-gutenbrowser/LibraryDialog.h @@ -106,6 +106,8 @@ public slots: bool setTitle(); void saveConfig(); bool download_Etext(); + bool download_newEtext(); + void onButtonSearch(); bool onButtonDownload(); @@ -120,6 +122,11 @@ protected: QHBoxLayout *hbox,*hbox1,*hbox2; QVBoxLayout *vbox; // void search_slot(); +private: + void addItems(); + void clearItems(); + void cleanStrings(); + bool getEtext(const QStringList &); }; diff --git a/noncore/apps/opie-gutenbrowser/NetworkDialog.cpp b/noncore/apps/opie-gutenbrowser/NetworkDialog.cpp index a321952..ba583ad 100644 --- a/noncore/apps/opie-gutenbrowser/NetworkDialog.cpp +++ b/noncore/apps/opie-gutenbrowser/NetworkDialog.cpp @@ -167,7 +167,9 @@ bool NetworkDialog::downloadFile( QString networkUrl ) // FtpQuit(conn); // return false; // } - odebug << "Requesting directory list." << oendl; + QString File_Name; + + if( s_partialFileName.right(4) != ".txt") { TextLabel3->setText("Getting directory list."); qApp->processEvents(); if (!FtpDir( "./.guten_temp", dir.latin1(), conn) ) { @@ -178,11 +180,11 @@ bool NetworkDialog::downloadFile( QString networkUrl ) return false; } QFile tmp("./.guten_temp"); - QString s, File_Name; - if (tmp.open(IO_ReadOnly)) { QTextStream t( &tmp ); // use a text stream - odebug << "Finding partial filename "+s_partialFileName << oendl; + //odebug << "Finding partial filename "+s_partialFileName << oendl; + QString s; + while ( !t.eof()) { s = t.readLine(); @@ -191,22 +193,19 @@ bool NetworkDialog::downloadFile( QString networkUrl ) if (str.contains(".txt")) { File_Name = str; - odebug << "Found file_name "+ File_Name << oendl; + //odebug << "Found file_name "+ File_Name << oendl; break; } -// if (str.contains(".zip")) { -// File_Name = str; -// odebug << "Found file_name "+ File_Name << oendl; -// break; -// } - } } //end of while loop tmp.close(); // tmp.remove(); ///TODO this is for release version Zaurus } - else - odebug << "Error opening temp file." << oendl; + } else { + File_Name = s_partialFileName; + qDebug("new dir " + File_Name); + } + Config cfg("Gutenbrowser"); cfg.setGroup("General"); diff --git a/noncore/apps/opie-gutenbrowser/gutenbrowser.cpp b/noncore/apps/opie-gutenbrowser/gutenbrowser.cpp index c7cdd83..413ab51 100644 --- a/noncore/apps/opie-gutenbrowser/gutenbrowser.cpp +++ b/noncore/apps/opie-gutenbrowser/gutenbrowser.cpp @@ -141,13 +141,13 @@ Gutenbrowser::Gutenbrowser(QWidget *,const char*, WFlags ) } } - // QString gutenIndex= local_library + "GUTINDEX.ALL"; - QString gutenIndex = QPEApplication::qpeDir()+ "etc/gutenbrowser/GUTINDEX.ALL"; + QString gutenIndex = local_library + "/GUTINDEX.ALL"; qDebug("gutenindex "+gutenIndex ); + if( QFile( gutenIndex).exists() ) { indexLib.setName( gutenIndex); } else { - QString localLibIndexFile = QPEApplication::qpeDir()+ "etc/gutenbrowser/PGWHOLE.TXT"; + QString localLibIndexFile = local_library + "/PGWHOLE.TXT"; // QString localLibIndexFile= local_library + "PGWHOLE.TXT"; newindexLib.setName( localLibIndexFile); } @@ -197,28 +197,28 @@ void Gutenbrowser::InfoBarClick() { /* download http with wget or preferred browser */ void Gutenbrowser::goGetit( const QString &url, bool showMsg) { - // int eexit=0; QString cmd; - // config.read(); qApp->processEvents(); - QString filename = QPEApplication::qpeDir(); - if(filename.right(1)!="/") - filename+="/etc/gutenbrowser/"; - else - filename+="etc/gutenbrowser/"; - odebug << "filename "+filename << oendl; - // QString filename = QDir::homeDirPath()+"/Applications/gutenbrowser/"; - filename += url.right( url.length() - url.findRev("/",-1,TRUE) -1); + QString filename = local_library + "/GUTINDEX.ALL"; +// QString filename = old_index; - Config config("Gutenbrowser"); - config.setGroup( "Browser" ); - QString brow = config.readEntry("Preferred", "Opera"); - odebug << "Preferred browser is "+brow << oendl; +// filename += url.right( url.length() - url.findRev("/",-1,TRUE) -1); + + Config cfg("Gutenbrowser"); + cfg.setGroup("FTPsite"); + ftp_host=cfg.readEntry("SiteName", "sailor.gutenberg.org"); + ftp_base_dir= cfg.readEntry("base", "/pub/gutenberg"); + +// Config config("Gutenbrowser"); +// config.setGroup( "Browser" ); +// QString brow = config.readEntry("Preferred", "Opera"); +// //odebug << "Preferred browser is "+brow << oendl; if(!showMsg) { //if we just get the gutenindex.all +// QString cmd="wget -O " + gutenindex1 + " http://sailor.gutenberg.org/GUTINDEX.ALL 2>&1"; cmd="wget -O " + filename +" " + url+" 2>&1" ; chdir(local_library); - odebug << "Issuing the system command: " << cmd << "" << oendl; +// //odebug << "Issuing the system command: " << cmd << "" << oendl; Output *outDlg; @@ -274,7 +274,7 @@ void Gutenbrowser::goGetit( const QString &url, bool showMsg) { } chdir(local_library); - odebug << "Issuing the sys command: " << cmd << "" << oendl; +// //odebug << "Issuing the sys command: " << cmd << "" << oendl; system(cmd); } } |