-// Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
+// Copyright (C) 2007-2015 CEA/DEN, EDF R&D, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
-// version 2.1 of the License.
+// version 2.1 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
//
#include "SUIT_ResourceMgr.h"
+#include "SUIT_Session.h"
#include <QDir>
#include <QFileInfo>
{
QString pathName;
- QStringList arguments = QApplication::arguments();
+ QStringList arguments;
+ if ( SUIT_Session::session() ) arguments = SUIT_Session::session()->arguments();
// Try config file, given in arguments
for (int i = 1; i < arguments.count(); i++) {
QRegExp rx ("--resources=(.+)");
- if ( rx.indexIn( arguments[i] ) >= 0 && rx.numCaptures() > 1 ) {
+ if ( rx.indexIn( arguments[i] ) >= 0 && rx.captureCount() > 0 ) {
QString file = rx.cap(1);
QFileInfo fi (file);
pathName = fi.absoluteFilePath();
long id, appr = -1;
+ QStringList all_files;
+
// get all files from the same dir where use file is (should be) situated
QDir d( QFileInfo( fname ).dir() );
if ( d.exists() ) {
d.setFilter( QDir::Files | QDir::Hidden | QDir::NoSymLinks );
QStringList l = d.entryList();
- for( QStringList::const_iterator anIt = l.begin(), aLast = l.end(); anIt!=aLast; anIt++ )
- {
- id = userFileId( *anIt );
- if ( id < 0 )
- continue;
- if( appr < 0 || qAbs( id-id0 ) < qAbs( appr-id0 ) )
- {
- appr = id;
- appr_file = d.absoluteFilePath( *anIt );
- }
- }
+ foreach( QString ll, l )
+ all_files << d.absoluteFilePath( ll );
}
-
// backward compatibility: check also user's home directory (if it differs from above one)
QDir home = QDir::home();
if ( home.exists() && d.canonicalPath() != home.canonicalPath() ) {
home.setFilter( QDir::Files | QDir::Hidden | QDir::NoSymLinks );
QStringList l = home.entryList();
+ foreach( QString ll, l )
+ all_files << home.absoluteFilePath( ll );
+ }
+
+ for( QStringList::const_iterator anIt = all_files.begin(), aLast = all_files.end(); anIt!=aLast; anIt++ )
+ {
+ id = userFileId( *anIt );
+ if ( id < 0 )
+ continue;
- for( QStringList::const_iterator anIt = l.begin(), aLast = l.end(); anIt!=aLast; anIt++ )
+ if( appr < 0 || qAbs( id-id0 ) < qAbs( appr-id0 ) )
{
- id = userFileId( *anIt );
- if ( id < 0 )
- continue;
- if( appr < 0 || qAbs( id-id0 ) < qAbs( appr-id0 ) )
- {
- appr = id;
+ appr = id;
+ appr_file = d.absoluteFilePath( *anIt );
+ }
+ else if ( qAbs( id-id0 ) == qAbs( appr-id0 ) ) {
+ // appr == id that means that another file with equal version id is detected
+ // this can happen, e.g. if one file begins with "." and other one - not
+ // ...
+ // VSR 24/09/2012: issue 0021781: since version 6.6.0 user filename is not prepended with "."
+ // when it is stored in the ~/.config/<appname> directory;
+ // for backward compatibility we also check files prepended with "." with lower priority
+ if ( !QFileInfo( *anIt ).fileName().startsWith(".") )
appr_file = home.absoluteFilePath( *anIt );
- }
}
}