mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 18:56:37 +00:00 
			
		
		
		
	Merge branch 'master' of git://github.com/zinnschlag/openmw
This commit is contained in:
		
						commit
						17fb0f5a69
					
				
					 12 changed files with 98 additions and 58 deletions
				
			
		|  | @ -15,7 +15,7 @@ include (OpenMWMacros) | ||||||
| # Version | # Version | ||||||
| 
 | 
 | ||||||
| set (OPENMW_VERSION_MAJOR 0) | set (OPENMW_VERSION_MAJOR 0) | ||||||
| set (OPENMW_VERSION_MINOR 21) | set (OPENMW_VERSION_MINOR 22) | ||||||
| set (OPENMW_VERSION_RELEASE 0) | set (OPENMW_VERSION_RELEASE 0) | ||||||
| 
 | 
 | ||||||
| set (OPENMW_VERSION "${OPENMW_VERSION_MAJOR}.${OPENMW_VERSION_MINOR}.${OPENMW_VERSION_RELEASE}") | set (OPENMW_VERSION "${OPENMW_VERSION_MAJOR}.${OPENMW_VERSION_MINOR}.${OPENMW_VERSION_RELEASE}") | ||||||
|  | @ -334,7 +334,7 @@ if(DPKG_PROGRAM) | ||||||
| 
 | 
 | ||||||
|     #Install icon and desktop file |     #Install icon and desktop file | ||||||
|     INSTALL(FILES "${OpenMW_BINARY_DIR}/openmw.desktop" DESTINATION "share/applications/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") |     INSTALL(FILES "${OpenMW_BINARY_DIR}/openmw.desktop" DESTINATION "share/applications/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") | ||||||
|     INSTALL(FILES "${OpenMW_SOURCE_DIR}/apps/launcher/resources/images/openmw.png" DESTINATION "share/pixmaps/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") |     INSTALL(FILES "${OpenMW_SOURCE_DIR}/files/launcher/images/openmw.png" DESTINATION "share/pixmaps/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") | ||||||
| 
 | 
 | ||||||
|     #Install global configuration files |     #Install global configuration files | ||||||
|     INSTALL(FILES "${OpenMW_BINARY_DIR}/settings-default.cfg" DESTINATION "../etc/openmw/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") |     INSTALL(FILES "${OpenMW_BINARY_DIR}/settings-default.cfg" DESTINATION "../etc/openmw/" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ COMPONENT "openmw") | ||||||
|  | @ -409,8 +409,8 @@ if(WIN32) | ||||||
|     SET(CPACK_NSIS_HELP_LINK "http:\\\\\\\\www.openmw.org") |     SET(CPACK_NSIS_HELP_LINK "http:\\\\\\\\www.openmw.org") | ||||||
|     SET(CPACK_NSIS_URL_INFO_ABOUT "http:\\\\\\\\www.openmw.org") |     SET(CPACK_NSIS_URL_INFO_ABOUT "http:\\\\\\\\www.openmw.org") | ||||||
|     SET(CPACK_NSIS_INSTALLED_ICON_NAME "omwlauncher.exe") |     SET(CPACK_NSIS_INSTALLED_ICON_NAME "omwlauncher.exe") | ||||||
|     SET(CPACK_NSIS_MUI_ICON "${OpenMW_SOURCE_DIR}/apps/launcher/resources/images/openmw.ico") |     SET(CPACK_NSIS_MUI_ICON "${OpenMW_SOURCE_DIR}/files/launcher/images/openmw.ico") | ||||||
|     SET(CPACK_NSIS_MUI_UNIICON "${OpenMW_SOURCE_DIR}/apps/launcher/resources/images/openmw.ico") |     SET(CPACK_NSIS_MUI_UNIICON "${OpenMW_SOURCE_DIR}/files/launcher/images/openmw.ico") | ||||||
|     SET(CPACK_PACKAGE_ICON "${OpenMW_SOURCE_DIR}\\\\files\\\\openmw.bmp") |     SET(CPACK_PACKAGE_ICON "${OpenMW_SOURCE_DIR}\\\\files\\\\openmw.bmp") | ||||||
| 
 | 
 | ||||||
|     SET(VCREDIST32 "${OpenMW_BINARY_DIR}/vcredist_x86.exe") |     SET(VCREDIST32 "${OpenMW_BINARY_DIR}/vcredist_x86.exe") | ||||||
|  | @ -680,7 +680,7 @@ if (NOT WIN32 AND NOT DPKG_PROGRAM AND NOT APPLE) | ||||||
|     ENDIF(BUILD_OPENCS) |     ENDIF(BUILD_OPENCS) | ||||||
| 
 | 
 | ||||||
|     # Install icon and .desktop |     # Install icon and .desktop | ||||||
|     INSTALL(FILES "${OpenMW_SOURCE_DIR}/apps/launcher/resources/images/openmw.png" DESTINATION "${ICONDIR}") |     INSTALL(FILES "${OpenMW_SOURCE_DIR}/files/launcher/images/openmw.png" DESTINATION "${ICONDIR}") | ||||||
|     INSTALL(FILES "${OpenMW_BINARY_DIR}/openmw.desktop" DESTINATION "${DATAROOTDIR}/applications") |     INSTALL(FILES "${OpenMW_BINARY_DIR}/openmw.desktop" DESTINATION "${DATAROOTDIR}/applications") | ||||||
| 
 | 
 | ||||||
|     # Install global configuration files |     # Install global configuration files | ||||||
|  |  | ||||||
|  | @ -12,7 +12,7 @@ set(LAUNCHER | ||||||
|     utils/checkablemessagebox.cpp |     utils/checkablemessagebox.cpp | ||||||
|     utils/textinputdialog.cpp |     utils/textinputdialog.cpp | ||||||
| 
 | 
 | ||||||
|     launcher.rc |     ${CMAKE_SOURCE_DIR}/files/launcher/launcher.rc | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| set(LAUNCHER_HEADER | set(LAUNCHER_HEADER | ||||||
|  | @ -43,10 +43,10 @@ set(LAUNCHER_HEADER_MOC | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| set(LAUNCHER_UI | set(LAUNCHER_UI | ||||||
|     ../../files/ui/datafilespage.ui |     ${CMAKE_SOURCE_DIR}/files/ui/datafilespage.ui | ||||||
|     ../../files/ui/graphicspage.ui |     ${CMAKE_SOURCE_DIR}/files/ui/graphicspage.ui | ||||||
|     ../../files/ui/mainwindow.ui |     ${CMAKE_SOURCE_DIR}/files/ui/mainwindow.ui | ||||||
|     ../../files/ui/playpage.ui |     ${CMAKE_SOURCE_DIR}/files/ui/playpage.ui | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| source_group(launcher FILES ${LAUNCHER} ${LAUNCHER_HEADER}) | source_group(launcher FILES ${LAUNCHER} ${LAUNCHER_HEADER}) | ||||||
|  |  | ||||||
|  | @ -1,6 +1,9 @@ | ||||||
| #include "datafilespage.hpp" | #include "datafilespage.hpp" | ||||||
| 
 | 
 | ||||||
| #include <QtGui> | #include <QPushButton> | ||||||
|  | #include <QMessageBox> | ||||||
|  | #include <QCheckBox> | ||||||
|  | #include <QMenu> | ||||||
| 
 | 
 | ||||||
| #include <components/files/configurationmanager.hpp> | #include <components/files/configurationmanager.hpp> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,6 +1,8 @@ | ||||||
| #include "graphicspage.hpp" | #include "graphicspage.hpp" | ||||||
| 
 | 
 | ||||||
| #include <QtGui> | #include <QDesktopWidget> | ||||||
|  | #include <QMessageBox> | ||||||
|  | #include <QDir> | ||||||
| 
 | 
 | ||||||
| #include <cstdlib> | #include <cstdlib> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1 +0,0 @@ | ||||||
| IDI_ICON1               ICON    DISCARDABLE     "resources/images/openmw.ico" |  | ||||||
|  | @ -1,6 +1,15 @@ | ||||||
| #include "maindialog.hpp" | #include "maindialog.hpp" | ||||||
| 
 | 
 | ||||||
| #include <QtGui> | #include <QFontDatabase> | ||||||
|  | #include <QInputDialog> | ||||||
|  | #include <QFileDialog> | ||||||
|  | #include <QCloseEvent> | ||||||
|  | #include <QTextCodec> | ||||||
|  | #include <QProcess> | ||||||
|  | #include <QFile> | ||||||
|  | #include <QDir> | ||||||
|  | 
 | ||||||
|  | #include <QDebug> | ||||||
| 
 | 
 | ||||||
| #include "utils/checkablemessagebox.hpp" | #include "utils/checkablemessagebox.hpp" | ||||||
| 
 | 
 | ||||||
|  | @ -203,10 +212,15 @@ bool MainDialog::showFirstRunDialog() | ||||||
|         // Construct the arguments to run the importer
 |         // Construct the arguments to run the importer
 | ||||||
|         QStringList arguments; |         QStringList arguments; | ||||||
| 
 | 
 | ||||||
|         if (msgBox.isChecked()) |  | ||||||
|             arguments.append(QString("-g")); |  | ||||||
| 
 | 
 | ||||||
|  |         if (msgBox.isChecked()) | ||||||
|  |             arguments.append(QString("--game-files")); | ||||||
|  | 
 | ||||||
|  |         arguments.append(QString("--encoding")); | ||||||
|  |         arguments.append(mGameSettings.value(QString("encoding"), QString("win1252"))); | ||||||
|  |         arguments.append(QString("--ini")); | ||||||
|         arguments.append(iniPaths.first()); |         arguments.append(iniPaths.first()); | ||||||
|  |         arguments.append(QString("--cfg")); | ||||||
|         arguments.append(path); |         arguments.append(path); | ||||||
| 
 | 
 | ||||||
|         if (!startProgram(QString("mwiniimport"), arguments, false)) |         if (!startProgram(QString("mwiniimport"), arguments, false)) | ||||||
|  | @ -659,7 +673,7 @@ bool MainDialog::startProgram(const QString &name, const QStringList &arguments, | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (process.exitCode() != 0) { |         if (process.exitCode() != 0 || process.exitStatus() == QProcess::CrashExit) { | ||||||
|             QString error(process.readAllStandardError()); |             QString error(process.readAllStandardError()); | ||||||
|             error.append(tr("\nArguments:\n")); |             error.append(tr("\nArguments:\n")); | ||||||
|             error.append(arguments.join(" ")); |             error.append(arguments.join(" ")); | ||||||
|  |  | ||||||
|  | @ -1,6 +1,10 @@ | ||||||
| #include "playpage.hpp" | #include "playpage.hpp" | ||||||
| 
 | 
 | ||||||
| #include <QtGui> | #include <QListView> | ||||||
|  | 
 | ||||||
|  | #ifdef Q_OS_MAC | ||||||
|  | #include <QPlastiqueStyle> | ||||||
|  | #endif | ||||||
| 
 | 
 | ||||||
| PlayPage::PlayPage(QWidget *parent) : QWidget(parent) | PlayPage::PlayPage(QWidget *parent) : QWidget(parent) | ||||||
| { | { | ||||||
|  |  | ||||||
|  | @ -1,4 +1,6 @@ | ||||||
| #include <QDebug> | #include <QDebug> | ||||||
|  | #include <QTextDecoder> | ||||||
|  | #include <QTextCodec> | ||||||
| #include <QFileInfo> | #include <QFileInfo> | ||||||
| #include <QDir> | #include <QDir> | ||||||
| 
 | 
 | ||||||
|  | @ -237,10 +239,6 @@ bool lessThanDate(const EsmFile *e1, const EsmFile *e2) | ||||||
|     } else { |     } else { | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| //    if (!e1->fileName().endsWith(".esm") && e2->fileName().endsWith(".esm"))
 |  | ||||||
| //        return false;
 |  | ||||||
| 
 |  | ||||||
| //    return e1->fileName().toLower() < e2->fileName().toLower();
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void DataFilesModel::sort(int column, Qt::SortOrder order) | void DataFilesModel::sort(int column, Qt::SortOrder order) | ||||||
|  | @ -270,17 +268,32 @@ void DataFilesModel::addFiles(const QString &path) | ||||||
|     filters << "*.esp" << "*.esm"; |     filters << "*.esp" << "*.esm"; | ||||||
|     dir.setNameFilters(filters); |     dir.setNameFilters(filters); | ||||||
| 
 | 
 | ||||||
|  |     // Create a decoder for non-latin characters in esx metadata
 | ||||||
|  |     QTextCodec *codec; | ||||||
|  | 
 | ||||||
|  |     if (mEncoding == QLatin1String("win1252")) { | ||||||
|  |         codec = QTextCodec::codecForName("windows-1252"); | ||||||
|  |     } else if (mEncoding == QLatin1String("win1251")) { | ||||||
|  |         codec = QTextCodec::codecForName("windows-1251"); | ||||||
|  |     } else if (mEncoding == QLatin1String("win1250")) { | ||||||
|  |         codec = QTextCodec::codecForName("windows-1250"); | ||||||
|  |     } else { | ||||||
|  |         return; // This should never happen;
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     QTextDecoder *decoder = codec->makeDecoder(); | ||||||
|  | 
 | ||||||
|     foreach (const QString &path, dir.entryList()) { |     foreach (const QString &path, dir.entryList()) { | ||||||
|         QFileInfo info(dir.absoluteFilePath(path)); |         QFileInfo info(dir.absoluteFilePath(path)); | ||||||
|         EsmFile *file = new EsmFile(path); |         EsmFile *file = new EsmFile(path); | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         try { |         try { | ||||||
|             ESM::ESMReader fileReader; |             ESM::ESMReader fileReader; | ||||||
|             ToUTF8::Utf8Encoder encoder(ToUTF8::calculateEncoding(mEncoding.toStdString())); |             ToUTF8::Utf8Encoder encoder(ToUTF8::calculateEncoding(mEncoding.toStdString())); | ||||||
|             fileReader.setEncoder(&encoder); |             fileReader.setEncoder(&encoder); | ||||||
|             fileReader.open(dir.absoluteFilePath(path).toStdString()); |             fileReader.open(dir.absoluteFilePath(path).toStdString()); | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|             ESM::ESMReader::MasterList mlist = fileReader.getMasters(); |             ESM::ESMReader::MasterList mlist = fileReader.getMasters(); | ||||||
|             QStringList masters; |             QStringList masters; | ||||||
| 
 | 
 | ||||||
|  | @ -289,13 +302,13 @@ void DataFilesModel::addFiles(const QString &path) | ||||||
|                 masters.append(master); |                 masters.append(master); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             file->setAuthor(QString::fromStdString(fileReader.getAuthor())); |             file->setAuthor(decoder->toUnicode(fileReader.getAuthor().c_str())); | ||||||
|             file->setSize(info.size()); |             file->setSize(info.size()); | ||||||
|             file->setDates(info.lastModified(), info.lastRead()); |             file->setDates(info.lastModified(), info.lastRead()); | ||||||
|             file->setVersion(fileReader.getFVer()); |             file->setVersion(fileReader.getFVer()); | ||||||
|             file->setPath(info.absoluteFilePath()); |             file->setPath(info.absoluteFilePath()); | ||||||
|             file->setMasters(masters); |             file->setMasters(masters); | ||||||
|             file->setDescription(QString::fromStdString(fileReader.getDesc())); |             file->setDescription(decoder->toUnicode(fileReader.getDesc().c_str())); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|             // Put the file in the table
 |             // Put the file in the table
 | ||||||
|  | @ -308,6 +321,8 @@ void DataFilesModel::addFiles(const QString &path) | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     delete decoder; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QModelIndex DataFilesModel::indexFromItem(EsmFile *item) const | QModelIndex DataFilesModel::indexFromItem(EsmFile *item) const | ||||||
|  |  | ||||||
							
								
								
									
										1
									
								
								files/launcher/launcher.rc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								files/launcher/launcher.rc
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | ||||||
|  | IDI_ICON1               ICON    DISCARDABLE     "images/openmw.ico" | ||||||
|  | @ -5,7 +5,7 @@ | ||||||
|   <property name="minimumSize"> |   <property name="minimumSize"> | ||||||
|    <size> |    <size> | ||||||
|     <width>575</width> |     <width>575</width> | ||||||
|     <height>525</height> |     <height>535</height> | ||||||
|    </size> |    </size> | ||||||
|   </property> |   </property> | ||||||
|   <property name="windowTitle"> |   <property name="windowTitle"> | ||||||
|  |  | ||||||
|  | @ -19,6 +19,9 @@ | ||||||
|      <property name="frameShadow"> |      <property name="frameShadow"> | ||||||
|       <enum>QFrame::Plain</enum> |       <enum>QFrame::Plain</enum> | ||||||
|      </property> |      </property> | ||||||
|  |      <property name="lineWidth"> | ||||||
|  |       <number>0</number> | ||||||
|  |      </property> | ||||||
|      <layout class="QGridLayout" name="gridLayout"> |      <layout class="QGridLayout" name="gridLayout"> | ||||||
|       <property name="leftMargin"> |       <property name="leftMargin"> | ||||||
|        <number>30</number> |        <number>30</number> | ||||||
|  | @ -40,10 +43,14 @@ | ||||||
|     border-color: rgba(0, 0, 0, 125); |     border-color: rgba(0, 0, 0, 125); | ||||||
|     border-style: solid; |     border-style: solid; | ||||||
|     border-radius: 2px; |     border-radius: 2px; | ||||||
|  | 
 | ||||||
|  |     font-size: 12pt; | ||||||
|  |     font-family: "EB Garamond", "EB Garamond 08"; | ||||||
|  | 	color: black; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /*QComboBox gets the "on" state when the popup is open */ | /*QComboBox gets the "on" state when the popup is open */ | ||||||
| #profilesComboBox:!editable:on, #ProfilesComboBox::drop-down:editable:on { | #profilesComboBox:!editable:on { | ||||||
|     background: qlineargradient(x1:0, y1:0, x2:0, y2:1, |     background: qlineargradient(x1:0, y1:0, x2:0, y2:1, | ||||||
|         stop:0 rgba(0, 0, 0, 75), |         stop:0 rgba(0, 0, 0, 75), | ||||||
|         stop:0.1 rgba(0, 0, 0, 15), |         stop:0.1 rgba(0, 0, 0, 15), | ||||||
|  | @ -52,13 +59,9 @@ | ||||||
|     border: 1px solid rgba(0, 0, 0, 55); |     border: 1px solid rgba(0, 0, 0, 55); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #profilesComboBox { /* shift the text when the popup opens */ | #profilesComboBox:on { /* shift the text when the popup opens */ | ||||||
|     padding-top: 3px; |     padding-top: 3px; | ||||||
|     padding-left: 4px; |     padding-left: 4px; | ||||||
| 
 |  | ||||||
|     font-size: 12pt; |  | ||||||
|     font-family: "EB Garamond", "EB Garamond 08"; |  | ||||||
| 	color: black; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #profilesComboBox::drop-down { | #profilesComboBox::drop-down { | ||||||
|  | @ -82,7 +85,6 @@ | ||||||
|     left: 1px; |     left: 1px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| #profilesComboBox QAbstractItemView { | #profilesComboBox QAbstractItemView { | ||||||
|     border: 0px; |     border: 0px; | ||||||
| }</string> | }</string> | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ OpenMW: A reimplementation of The Elder Scrolls III: Morrowind | ||||||
| OpenMW is an attempt at recreating the engine for the popular role-playing game | OpenMW is an attempt at recreating the engine for the popular role-playing game | ||||||
| Morrowind by Bethesda Softworks. You need to own and install the original game for OpenMW to work. | Morrowind by Bethesda Softworks. You need to own and install the original game for OpenMW to work. | ||||||
| 
 | 
 | ||||||
| Version: 0.21.0 | Version: 0.22.0 | ||||||
| License: GPL (see GPL3.txt for more information) | License: GPL (see GPL3.txt for more information) | ||||||
| Website: http://www.openmw.org | Website: http://www.openmw.org | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue