summaryrefslogtreecommitdiff
authorsandman <sandman>2002-10-21 12:39:51 (UTC)
committer sandman <sandman>2002-10-21 12:39:51 (UTC)
commit32817a02b4fae7010e7ef1212916168845a58831 (patch) (unidiff)
tree9859d99a7e507859d06d6e9f2a03a3b8efb046a8
parentcdaf60fdf5dc19e88db4faa319daacfe4e879518 (diff)
downloadopie-32817a02b4fae7010e7ef1212916168845a58831.zip
opie-32817a02b4fae7010e7ef1212916168845a58831.tar.gz
opie-32817a02b4fae7010e7ef1212916168845a58831.tar.bz2
Get rid of the QDir::readDirEntries: Cannot read the directory:
/opt/QtPalmtop/plugins/fontfactories message if no fontfactories are installed -- this seems to confuse users
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--library/fontdatabase.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/library/fontdatabase.cpp b/library/fontdatabase.cpp
index 147134c..899d5cf 100644
--- a/library/fontdatabase.cpp
+++ b/library/fontdatabase.cpp
@@ -100,128 +100,132 @@ QStringList FontDatabase::families() const
100 QString familyname = qdf->name; 100 QString familyname = qdf->name;
101 if ( !familyDict.find( familyname ) ) { 101 if ( !familyDict.find( familyname ) ) {
102 familyDict.insert( familyname, (void *)1 ); 102 familyDict.insert( familyname, (void *)1 );
103 list.append( familyname ); 103 list.append( familyname );
104 } 104 }
105 } 105 }
106 106
107 QDir dir(fontDir(),"*.qpf"); 107 QDir dir(fontDir(),"*.qpf");
108 for (int i=0; i<(int)dir.count(); i++) { 108 for (int i=0; i<(int)dir.count(); i++) {
109 QString familyname = fontFamily(dir[i]); 109 QString familyname = fontFamily(dir[i]);
110 if ( !familyDict.find( familyname ) ) { 110 if ( !familyDict.find( familyname ) ) {
111 familyDict.insert( familyname, (void *)1 ); 111 familyDict.insert( familyname, (void *)1 );
112 list.append( familyname ); 112 list.append( familyname );
113 } 113 }
114 } 114 }
115 115
116 return list; 116 return list;
117#endif 117#endif
118} 118}
119 119
120#ifdef QT_NO_FONTDATABASE 120#ifdef QT_NO_FONTDATABASE
121/*! 121/*!
122 Returns a list of standard fontsizes. 122 Returns a list of standard fontsizes.
123*/ 123*/
124QValueList<int> FontDatabase::standardSizes() 124QValueList<int> FontDatabase::standardSizes()
125{ 125{
126 static int s[]={ 8, 9, 10, 11, 12, 14, 16, 18, 20, 22, 24, 26, 28, 126 static int s[]={ 8, 9, 10, 11, 12, 14, 16, 18, 20, 22, 24, 26, 28,
127 36, 48, 72, 0 }; 127 36, 48, 72, 0 };
128 static bool first = TRUE; 128 static bool first = TRUE;
129 static QValueList<int> sList; 129 static QValueList<int> sList;
130 if ( first ) { 130 if ( first ) {
131 first = FALSE; 131 first = FALSE;
132 int i = 0; 132 int i = 0;
133 while( s[i] ) 133 while( s[i] )
134 sList.append( s[i++] ); 134 sList.append( s[i++] );
135 } 135 }
136 return sList; 136 return sList;
137} 137}
138 138
139#endif 139#endif
140 140
141/*! 141/*!
142 Load any font renderer plugins that are available and make the fonts 142 Load any font renderer plugins that are available and make the fonts
143 that the plugins can read available. 143 that the plugins can read available.
144*/ 144*/
145void FontDatabase::loadRenderers() 145void FontDatabase::loadRenderers()
146{ 146{
147#ifndef QT_NO_COMPONENT 147#ifndef QT_NO_COMPONENT
148 if ( !factoryList ) 148 if ( !factoryList )
149 factoryList = new QValueList<FontFactory>; 149 factoryList = new QValueList<FontFactory>;
150 150
151 QValueList<FontFactory>::Iterator mit; 151 QValueList<FontFactory>::Iterator mit;
152 for ( mit = factoryList->begin(); mit != factoryList->end(); ++mit ) { 152 for ( mit = factoryList->begin(); mit != factoryList->end(); ++mit ) {
153 qt_fontmanager->factories.setAutoDelete( false ); 153 qt_fontmanager->factories.setAutoDelete( false );
154 qt_fontmanager->factories.removeRef( (*mit).factory ); 154 qt_fontmanager->factories.removeRef( (*mit).factory );
155 qt_fontmanager->factories.setAutoDelete( true ); 155 qt_fontmanager->factories.setAutoDelete( true );
156 (*mit).interface->release(); 156 (*mit).interface->release();
157 (*mit).library->unload(); 157 (*mit).library->unload();
158 delete (*mit).library; 158 delete (*mit).library;
159 } 159 }
160 factoryList->clear(); 160 factoryList->clear();
161 161
162 QString path = QPEApplication::qpeDir() + "/plugins/fontfactories"; 162 QString path = QPEApplication::qpeDir() + "/plugins/fontfactories";
163 QDir dir( path, "lib*.so" ); 163 QDir dir( path, "lib*.so" );
164
165 if ( !dir.exists())
166 return;
167
164 QStringList list = dir.entryList(); 168 QStringList list = dir.entryList();
165 QStringList::Iterator it; 169 QStringList::Iterator it;
166 for ( it = list.begin(); it != list.end(); ++it ) { 170 for ( it = list.begin(); it != list.end(); ++it ) {
167 FontFactoryInterface *iface = 0; 171 FontFactoryInterface *iface = 0;
168 QLibrary *lib = new QLibrary( path + "/" + *it ); 172 QLibrary *lib = new QLibrary( path + "/" + *it );
169 if ( lib->queryInterface( IID_FontFactory, (QUnknownInterface**)&iface ) == QS_OK ) { 173 if ( lib->queryInterface( IID_FontFactory, (QUnknownInterface**)&iface ) == QS_OK ) {
170 FontFactory factory; 174 FontFactory factory;
171 factory.library = lib; 175 factory.library = lib;
172 factory.interface = iface; 176 factory.interface = iface;
173 factory.factory = factory.interface->fontFactory(); 177 factory.factory = factory.interface->fontFactory();
174 factoryList->append( factory ); 178 factoryList->append( factory );
175 qt_fontmanager->factories.append( factory.factory ); 179 qt_fontmanager->factories.append( factory.factory );
176 readFonts( factory.factory ); 180 readFonts( factory.factory );
177 } else { 181 } else {
178 delete lib; 182 delete lib;
179 } 183 }
180 } 184 }
181#endif 185#endif
182} 186}
183 187
184/*! 188/*!
185 \internal 189 \internal
186*/ 190*/
187void FontDatabase::readFonts( QFontFactory *factory ) 191void FontDatabase::readFonts( QFontFactory *factory )
188{ 192{
189 // Load in font definition file 193 // Load in font definition file
190 QString fn = fontDir() + "fontdir"; 194 QString fn = fontDir() + "fontdir";
191 FILE* fontdef=fopen(fn.local8Bit(),"r"); 195 FILE* fontdef=fopen(fn.local8Bit(),"r");
192 if(!fontdef) { 196 if(!fontdef) {
193 QCString temp=fn.local8Bit(); 197 QCString temp=fn.local8Bit();
194 qWarning("Cannot find font definition file %s - is $QTDIR set correctly?", 198 qWarning("Cannot find font definition file %s - is $QTDIR set correctly?",
195 temp.data()); 199 temp.data());
196 return; 200 return;
197 } 201 }
198 char buf[200]=""; 202 char buf[200]="";
199 char name[200]=""; 203 char name[200]="";
200 char render[200]=""; 204 char render[200]="";
201 char file[200]=""; 205 char file[200]="";
202 char flags[200]=""; 206 char flags[200]="";
203 char isitalic[10]=""; 207 char isitalic[10]="";
204 fgets(buf,200,fontdef); 208 fgets(buf,200,fontdef);
205 while(!feof(fontdef)) { 209 while(!feof(fontdef)) {
206 if ( buf[0] != '#' ) { 210 if ( buf[0] != '#' ) {
207 int weight=50; 211 int weight=50;
208 int size=0; 212 int size=0;
209 flags[0]=0; 213 flags[0]=0;
210 sscanf(buf,"%s %s %s %s %d %d %s",name,file,render,isitalic,&weight,&size,flags); 214 sscanf(buf,"%s %s %s %s %d %d %s",name,file,render,isitalic,&weight,&size,flags);
211 QString filename; 215 QString filename;
212 if ( file[0] != '/' ) 216 if ( file[0] != '/' )
213 filename = fontDir(); 217 filename = fontDir();
214 filename += file; 218 filename += file;
215 if ( QFile::exists(filename) ) { 219 if ( QFile::exists(filename) ) {
216 if( factory->name() == render ) { 220 if( factory->name() == render ) {
217 QDiskFont * qdf=new QDiskFont(factory,name,isitalic[0]=='y', 221 QDiskFont * qdf=new QDiskFont(factory,name,isitalic[0]=='y',
218 weight,size,flags,filename); 222 weight,size,flags,filename);
219 qt_fontmanager->diskfonts.append(qdf); 223 qt_fontmanager->diskfonts.append(qdf);
220#if QT_VERSION >= 232 224#if QT_VERSION >= 232
221 QFontDatabase::qwsAddDiskFont( qdf ); 225 QFontDatabase::qwsAddDiskFont( qdf );
222#endif 226#endif
223 } 227 }
224 } 228 }
225 } 229 }
226 fgets(buf,200,fontdef); 230 fgets(buf,200,fontdef);
227 } 231 }