This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/blenlib/intern/winstuff.c

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

252 lines
7.2 KiB
C
Raw Normal View History

/*
2002-10-12 11:37:38 +00:00
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
2002-10-12 11:37:38 +00:00
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
2010-02-12 13:34:04 +00:00
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
2002-10-12 11:37:38 +00:00
*
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
* All rights reserved.
* Windows-posix compatibility layer, windows-specific functions.
*/
/** \file
* \ingroup bli
2011-02-27 20:37:56 +00:00
*/
2002-10-12 11:37:38 +00:00
#ifdef WIN32
# include <conio.h>
# include <stdio.h>
# include <stdlib.h>
2002-10-12 11:37:38 +00:00
# include "MEM_guardedalloc.h"
2012-05-12 15:13:06 +00:00
# define WIN32_SKIP_HKEY_PROTECTION // need to use HKEY
# include "BLI_path_util.h"
# include "BLI_string.h"
# include "BLI_utildefines.h"
# include "BLI_winstuff.h"
2002-10-12 11:37:38 +00:00
# include "utf_winfunc.h"
# include "utfconv.h"
2012-05-12 15:13:06 +00:00
/* FILE_MAXDIR + FILE_MAXFILE */
int BLI_windows_get_executable_dir(char *str)
{
char dir[FILE_MAXDIR];
int a;
/*change to utf support*/
2012-04-29 15:47:02 +00:00
GetModuleFileName(NULL, str, FILE_MAX);
BLI_split_dir_part(str, dir, sizeof(dir)); /* shouldn't be relative */
a = strlen(dir);
2019-03-27 13:16:10 +11:00
if (dir[a - 1] == '\\') {
dir[a - 1] = 0;
}
2018-06-17 16:32:54 +02:00
2012-04-29 15:47:02 +00:00
strcpy(str, dir);
2018-06-17 16:32:54 +02:00
return 1;
}
static void register_blend_extension_failed(HKEY root, const bool background)
{
printf("failed\n");
2019-03-27 13:16:10 +11:00
if (root) {
RegCloseKey(root);
2019-03-27 13:16:10 +11:00
}
if (!background) {
2012-05-12 15:13:06 +00:00
MessageBox(0, "Could not register file extension.", "Blender error", MB_OK | MB_ICONERROR);
2019-03-27 13:16:10 +11:00
}
2012-04-29 15:47:02 +00:00
TerminateProcess(GetCurrentProcess(), 1);
}
2002-10-12 11:37:38 +00:00
void BLI_windows_register_blend_extension(const bool background)
{
2002-10-12 11:37:38 +00:00
LONG lresult;
HKEY hkey = 0;
HKEY root = 0;
BOOL usr_mode = false;
2002-10-12 11:37:38 +00:00
DWORD dwd = 0;
char buffer[256];
char BlPath[MAX_PATH];
char InstallDir[FILE_MAXDIR];
char SysDir[FILE_MAXDIR];
const char *ThumbHandlerDLL;
2012-05-12 15:13:06 +00:00
char RegCmd[MAX_PATH * 2];
char MBox[256];
char *blender_app;
# ifndef _WIN64
BOOL IsWOW64;
# endif
printf("Registering file extension...");
2012-04-29 15:47:02 +00:00
GetModuleFileName(0, BlPath, MAX_PATH);
/* Replace the actual app name with the wrapper. */
blender_app = strstr(BlPath, "blender-app.exe");
if (blender_app != NULL) {
strcpy(blender_app, "blender.exe");
}
2012-07-07 22:51:57 +00:00
/* root is HKLM by default */
lresult = RegOpenKeyEx(HKEY_LOCAL_MACHINE, "Software\\Classes", 0, KEY_ALL_ACCESS, &root);
2012-03-07 04:53:43 +00:00
if (lresult != ERROR_SUCCESS) {
2012-07-07 22:51:57 +00:00
/* try HKCU on failure */
usr_mode = true;
lresult = RegOpenKeyEx(HKEY_CURRENT_USER, "Software\\Classes", 0, KEY_ALL_ACCESS, &root);
2019-03-27 13:16:10 +11:00
if (lresult != ERROR_SUCCESS) {
register_blend_extension_failed(0, background);
2019-03-27 13:16:10 +11:00
}
}
2002-10-12 11:37:38 +00:00
lresult = RegCreateKeyEx(
2012-05-12 15:13:06 +00:00
root, "blendfile", 0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL, &hkey, &dwd);
2002-10-12 11:37:38 +00:00
if (lresult == ERROR_SUCCESS) {
2012-04-29 15:47:02 +00:00
strcpy(buffer, "Blender File");
2012-05-12 15:13:06 +00:00
lresult = RegSetValueEx(hkey, NULL, 0, REG_SZ, (BYTE *)buffer, strlen(buffer) + 1);
2002-10-12 11:37:38 +00:00
RegCloseKey(hkey);
}
2019-03-27 13:16:10 +11:00
if (lresult != ERROR_SUCCESS) {
register_blend_extension_failed(root, background);
2019-03-27 13:16:10 +11:00
}
2002-10-12 11:37:38 +00:00
lresult = RegCreateKeyEx(root,
"blendfile\\shell\\open\\command",
0,
2012-05-12 15:13:06 +00:00
NULL,
REG_OPTION_NON_VOLATILE,
KEY_ALL_ACCESS,
NULL,
&hkey,
&dwd);
2002-10-12 11:37:38 +00:00
if (lresult == ERROR_SUCCESS) {
sprintf(buffer, "\"%s\" \"%%1\"", BlPath);
2012-05-12 15:13:06 +00:00
lresult = RegSetValueEx(hkey, NULL, 0, REG_SZ, (BYTE *)buffer, strlen(buffer) + 1);
2002-10-12 11:37:38 +00:00
RegCloseKey(hkey);
}
2019-03-27 13:16:10 +11:00
if (lresult != ERROR_SUCCESS) {
register_blend_extension_failed(root, background);
2019-03-27 13:16:10 +11:00
}
2002-10-12 11:37:38 +00:00
lresult = RegCreateKeyEx(root,
"blendfile\\DefaultIcon",
0,
2012-05-12 15:13:06 +00:00
NULL,
REG_OPTION_NON_VOLATILE,
KEY_ALL_ACCESS,
NULL,
&hkey,
&dwd);
if (lresult == ERROR_SUCCESS) {
2012-04-29 15:47:02 +00:00
sprintf(buffer, "\"%s\", 1", BlPath);
2012-05-12 15:13:06 +00:00
lresult = RegSetValueEx(hkey, NULL, 0, REG_SZ, (BYTE *)buffer, strlen(buffer) + 1);
RegCloseKey(hkey);
}
2019-03-27 13:16:10 +11:00
if (lresult != ERROR_SUCCESS) {
register_blend_extension_failed(root, background);
2019-03-27 13:16:10 +11:00
}
2002-10-12 11:37:38 +00:00
lresult = RegCreateKeyEx(
2012-05-12 15:13:06 +00:00
root, ".blend", 0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL, &hkey, &dwd);
2002-10-12 11:37:38 +00:00
if (lresult == ERROR_SUCCESS) {
strcpy(buffer, "blendfile");
2012-05-12 15:13:06 +00:00
lresult = RegSetValueEx(hkey, NULL, 0, REG_SZ, (BYTE *)buffer, strlen(buffer) + 1);
2002-10-12 11:37:38 +00:00
RegCloseKey(hkey);
}
2019-03-27 13:16:10 +11:00
if (lresult != ERROR_SUCCESS) {
register_blend_extension_failed(root, background);
2019-03-27 13:16:10 +11:00
}
2018-06-17 16:32:54 +02:00
BLI_windows_get_executable_dir(InstallDir);
2012-04-29 15:47:02 +00:00
GetSystemDirectory(SysDir, FILE_MAXDIR);
ThumbHandlerDLL = "BlendThumb.dll";
2012-05-12 15:13:06 +00:00
snprintf(
RegCmd, MAX_PATH * 2, "%s\\regsvr32 /s \"%s\\%s\"", SysDir, InstallDir, ThumbHandlerDLL);
system(RegCmd);
RegCloseKey(root);
2012-04-29 15:47:02 +00:00
printf("success (%s)\n", usr_mode ? "user" : "system");
if (!background) {
2012-04-29 15:47:02 +00:00
sprintf(MBox,
"File extension registered for %s.",
usr_mode ? "the current user. To register for all users, run as an administrator" :
"all users");
2012-05-12 15:13:06 +00:00
MessageBox(0, MBox, "Blender", MB_OK | MB_ICONINFORMATION);
}
2012-04-29 15:47:02 +00:00
TerminateProcess(GetCurrentProcess(), 0);
2002-10-12 11:37:38 +00:00
}
void BLI_windows_get_default_root_dir(char *root)
{
2012-05-12 15:13:06 +00:00
char str[MAX_PATH + 1];
2018-06-17 16:32:54 +02:00
/* the default drive to resolve a directory without a specified drive
* should be the Windows installation drive, since this was what the OS
* assumes. */
2012-05-12 15:13:06 +00:00
if (GetWindowsDirectory(str, MAX_PATH + 1)) {
root[0] = str[0];
root[1] = ':';
root[2] = '\\';
root[3] = '\0';
}
else {
2018-06-17 16:32:54 +02:00
/* if GetWindowsDirectory fails, something has probably gone wrong,
* we are trying the blender install dir though */
2012-05-12 15:13:06 +00:00
if (GetModuleFileName(NULL, str, MAX_PATH + 1)) {
2015-11-16 11:59:15 +11:00
printf(
"Error! Could not get the Windows Directory - "
"Defaulting to Blender installation Dir!\n");
root[0] = str[0];
root[1] = ':';
root[2] = '\\';
root[3] = '\0';
}
else {
DWORD tmp;
int i;
int rc = 0;
/* now something has gone really wrong - still trying our best guess */
2015-11-16 11:59:15 +11:00
printf(
"Error! Could not get the Windows Directory - "
"Defaulting to first valid drive! Path might be invalid!\n");
2012-05-12 15:13:06 +00:00
tmp = GetLogicalDrives();
for (i = 2; i < 26; i++) {
if ((tmp >> i) & 1) {
root[0] = 'a' + i;
root[1] = ':';
root[2] = '\\';
root[3] = '\0';
if (GetFileAttributes(root) != 0xFFFFFFFF) {
rc = i;
break;
}
}
}
if (0 == rc) {
printf("ERROR in 'BLI_windows_get_default_root_dir': can't find a valid drive!\n");
root[0] = 'C';
root[1] = ':';
root[2] = '\\';
root[3] = '\0';
}
}
}
}
2002-10-12 11:37:38 +00:00
#else
2009-01-17 00:51:42 +00:00
/* intentionally empty for UNIX */
2002-10-12 11:37:38 +00:00
#endif