mirror of
https://github.com/gnustep/libs-base.git
synced 2025-05-30 00:11:26 +00:00
Get rid of some unused code. Fix error in debug logs for unicode defaults key.
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@21965 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
parent
c9c6734169
commit
4a5190d98e
8 changed files with 54 additions and 383 deletions
|
@ -35,8 +35,7 @@ win32_OBJC_FILES =\
|
|||
NSMessagePortWin32.m \
|
||||
NSRunLoopWin32.m \
|
||||
NSUserDefaultsWin32.m \
|
||||
Win32Support.m \
|
||||
Win32_Utilities.m
|
||||
|
||||
|
||||
-include Makefile.preamble
|
||||
|
||||
|
|
|
@ -231,13 +231,11 @@ struct NSUserDefaultsWin32_DomainInfo
|
|||
v = [NSString stringWithCString: data
|
||||
encoding: NSASCIIStringEncoding];
|
||||
v = [v propertyList];
|
||||
k = AUTORELEASE([[NSString alloc] initWithBytes: name
|
||||
length: namelen * sizeof(unichar)
|
||||
encoding: NSUnicodeStringEncoding]);
|
||||
k = [NSString stringWithCharacters: name length: namelen];
|
||||
[domainDict setObject: v forKey: k];
|
||||
}
|
||||
NS_HANDLER
|
||||
NSLog(@"Bad registry value for '%s'", name);
|
||||
NSLog(@"Bad registry value for '%S'", name);
|
||||
NS_ENDHANDLER
|
||||
}
|
||||
else if (rc == ERROR_MORE_DATA)
|
||||
|
@ -299,13 +297,11 @@ struct NSUserDefaultsWin32_DomainInfo
|
|||
v = [NSString stringWithCString: data
|
||||
encoding: NSASCIIStringEncoding];
|
||||
v = [v propertyList];
|
||||
k = AUTORELEASE([[NSString alloc] initWithBytes: name
|
||||
length: namelen * sizeof(unichar)
|
||||
encoding: NSUnicodeStringEncoding]);
|
||||
k = [NSString stringWithCharacters: name length: namelen];
|
||||
[domainDict setObject: v forKey: k];
|
||||
}
|
||||
NS_HANDLER
|
||||
NSLog(@"Bad registry value for '%s'", name);
|
||||
NSLog(@"Bad registry value for '%S'", name);
|
||||
NS_ENDHANDLER
|
||||
}
|
||||
else if (rc == ERROR_MORE_DATA)
|
||||
|
|
|
@ -1,48 +0,0 @@
|
|||
/* Useful support functions for GNUstep under MS-Windows
|
||||
Copyright (C) 2004-2005 Free Software Foundation, Inc.
|
||||
|
||||
Written by: Sheldon Gill <address@hidden>
|
||||
Created: Dec 2003
|
||||
|
||||
This file is part of the GNUstep Base Library.
|
||||
|
||||
This library is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU Library General Public
|
||||
License as published by the Free Software Foundation; either
|
||||
version 2 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
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
Library General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Library General Public
|
||||
License along with this library; if not, write to the Free
|
||||
Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111 USA.
|
||||
*/
|
||||
|
||||
#include "GNUstepBase/Win32_Utilities.h"
|
||||
//#include "GNUstepBase/Win32_FileManagement.h"
|
||||
|
||||
/*
|
||||
* Perform any and all necessary initialisation for supporting Win32
|
||||
* Called after first part of library initialisation so some Obj-C is okay
|
||||
*/
|
||||
void
|
||||
Win32Initialise(void)
|
||||
{
|
||||
/* We call the initialisation routines of all support modules in turn */
|
||||
Win32_Utilities_init();
|
||||
// Win32_FileManagement_init();
|
||||
}
|
||||
|
||||
/*
|
||||
* Free and finalise all things for supporting Win32
|
||||
*/
|
||||
void
|
||||
Win32Finalise(void)
|
||||
{
|
||||
/* We call the finalisation routines of all support modules in turn */
|
||||
Win32_Utilities_fini();
|
||||
// Win32_FileManagement_fini();
|
||||
}
|
|
@ -1,219 +0,0 @@
|
|||
/* Useful support functions for GNUstep under MS-Windows
|
||||
Copyright (C) 2004-2005 Free Software Foundation, Inc.
|
||||
|
||||
Written by: Sheldon Gill <address@hidden>
|
||||
Created: Dec 2003
|
||||
|
||||
This file is part of the GNUstep Base Library.
|
||||
|
||||
This library is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU Library General Public
|
||||
License as published by the Free Software Foundation; either
|
||||
version 2 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
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
Library General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Library General Public
|
||||
License along with this library; if not, write to the Free
|
||||
Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111 USA.
|
||||
*/
|
||||
#include <Foundation/NSString.h>
|
||||
#include <Foundation/NSException.h>
|
||||
#include <Foundation/NSLock.h>
|
||||
#include <Foundation/NSPathUtilities.h>
|
||||
#include <Foundation/NSProcessInfo.h>
|
||||
|
||||
#include "GNUstepBase/Win32_Utilities.h"
|
||||
|
||||
#define UNISTR(X) \
|
||||
((const unichar*)[(X) cStringUsingEncoding: NSUnicodeStringEncoding])
|
||||
|
||||
/* ------------------ */
|
||||
/* Internal Variables */
|
||||
/* ------------------ */
|
||||
|
||||
/* ------+---------+---------+---------+---------+---------+---------+---------+
|
||||
#pragma mark -
|
||||
#pragma mark -<Registry functions>-
|
||||
---------+---------+---------+---------+---------+---------+---------+------- */
|
||||
|
||||
/**
|
||||
* Returns a hive key or 0 if unable.
|
||||
*/
|
||||
HKEY
|
||||
Win32OpenRegistryW(HKEY hive, NSString *key)
|
||||
{
|
||||
HKEY regkey;
|
||||
|
||||
if (RegOpenKeyExW(hive, UNISTR(key), 0, KEY_READ, ®key) == ERROR_SUCCESS)
|
||||
{
|
||||
return regkey;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns an NSString as read from a registry STRING value.
|
||||
*/
|
||||
NSString *
|
||||
Win32NSStringFromRegistry(HKEY regkey, NSString *regValue)
|
||||
{
|
||||
unichar buf[MAX_PATH];
|
||||
DWORD bufsize = MAX_PATH;
|
||||
DWORD type;
|
||||
|
||||
if (RegQueryValueExW(regkey, UNISTR(regValue), 0, &type, (unsigned char*)buf,
|
||||
&bufsize) == ERROR_SUCCESS)
|
||||
{
|
||||
// FIXME check type is correct
|
||||
return [NSString stringWithCharacters: buf
|
||||
length: bufsize / sizeof(unichar)];
|
||||
}
|
||||
return nil;
|
||||
}
|
||||
|
||||
// NSNumber *Win32NSNumberFromRegistry(HKEY regkey, NSString *regValue);
|
||||
// NSData *Win32NSDataFromRegistry(HKEY regkey, NSString *regValue);
|
||||
|
||||
/* ------+---------+---------+---------+---------+---------+---------+---------+
|
||||
#pragma mark -
|
||||
#pragma mark -<Environment functions>-
|
||||
---------+---------+---------+---------+---------+---------+---------+------- */
|
||||
|
||||
/**
|
||||
* Obtains an NSString for the environment variable named envVar.
|
||||
*/
|
||||
NSString *
|
||||
Win32NSStringFromEnvironmentVariable(NSString *envVar)
|
||||
{
|
||||
unichar buf[1024], *nb;
|
||||
DWORD n;
|
||||
NSString *s = nil;
|
||||
|
||||
[gnustep_global_lock lock];
|
||||
n = GetEnvironmentVariableW(UNISTR(envVar), buf, 1024);
|
||||
if (n > 1024)
|
||||
{
|
||||
/* Buffer not big enough, so dynamically allocate it */
|
||||
nb = (unichar *)NSZoneMalloc(NSDefaultMallocZone(),
|
||||
sizeof(unichar)*(n + 1));
|
||||
if (nb != NULL)
|
||||
{
|
||||
n = GetEnvironmentVariableW(UNISTR(envVar), nb, n + 1);
|
||||
s = [NSString stringWithCharacters: nb length: n];
|
||||
NSZoneFree(NSDefaultMallocZone(), nb);
|
||||
}
|
||||
}
|
||||
else if (n > 0)
|
||||
{
|
||||
s = [NSString stringWithCharacters: buf length: n];
|
||||
}
|
||||
[gnustep_global_lock unlock];
|
||||
return s;
|
||||
}
|
||||
|
||||
/* ------+---------+---------+---------+---------+---------+---------+---------+
|
||||
#pragma mark -
|
||||
#pragma mark -<Path functions>-
|
||||
---------+---------+---------+---------+---------+---------+---------+------- */
|
||||
/**
|
||||
* Locates the users profile directory, roughly equivalent to ~/ on unix
|
||||
*/
|
||||
NSString *
|
||||
Win32GetUserProfileDirectory(NSString *loginName)
|
||||
{
|
||||
NSString *s;
|
||||
|
||||
if ([loginName isEqual: NSUserName()] == YES)
|
||||
{
|
||||
[gnustep_global_lock lock];
|
||||
/*
|
||||
* The environment variable HOMEPATH holds the home directory
|
||||
* for the user on Windows NT;
|
||||
* For OPENSTEP compatibility (and because USERPROFILE is usually
|
||||
* unusable because it contains spaces), we use HOMEPATH in
|
||||
* preference to USERPROFILE.
|
||||
*/
|
||||
s = Win32NSStringFromEnvironmentVariable(@"HOMEPATH");
|
||||
if (s != nil && ([s length] < 2 || [s characterAtIndex: 1] != ':'))
|
||||
{
|
||||
s = [Win32NSStringFromEnvironmentVariable(@"HOMEDRIVE")
|
||||
stringByAppendingString: s];
|
||||
}
|
||||
if (s == nil)
|
||||
{
|
||||
s = Win32NSStringFromEnvironmentVariable(@"USERPROFILE");
|
||||
}
|
||||
|
||||
if (s == nil)
|
||||
{
|
||||
; // FIXME: Talk to the NET API and get the profile path
|
||||
}
|
||||
|
||||
[gnustep_global_lock unlock];
|
||||
}
|
||||
else
|
||||
{
|
||||
s = nil;
|
||||
NSLog(@"Trying to get home for '%@' when user is '%@'",
|
||||
loginName, NSUserName());
|
||||
NSLog(@"Can't determine other user home directories in Win32.");
|
||||
}
|
||||
|
||||
if ([s length] == 0 && [loginName length] != 1)
|
||||
{
|
||||
s = nil;
|
||||
NSLog(@"NSHomeDirectoryForUser(%@) failed", loginName);
|
||||
}
|
||||
|
||||
return s;
|
||||
}
|
||||
|
||||
/**
|
||||
* Locates specified directory on Win32 systems
|
||||
*/
|
||||
NSString *
|
||||
Win32FindDirectory(DWORD DirCSIDL)
|
||||
{
|
||||
[NSException raise: NSInternalInconsistencyException
|
||||
format: @"Not implemented! Can't find directories in Win32."];
|
||||
return nil;
|
||||
}
|
||||
|
||||
/**
|
||||
* Initialises resources required by utilities
|
||||
*/
|
||||
void
|
||||
Win32_Utilities_init(void)
|
||||
{
|
||||
/*
|
||||
* Initialise the COM sub-system for this application
|
||||
*/
|
||||
//CoCreateInstance();
|
||||
|
||||
/*
|
||||
* Look for the libraries we need
|
||||
*/
|
||||
// GetDLLVersion
|
||||
|
||||
/*
|
||||
* Get pointers to the Explorer Shell memory functions
|
||||
*/
|
||||
// IShellMalloc, IShellFree
|
||||
// SHGetFolder
|
||||
}
|
||||
|
||||
/**
|
||||
* Closes down and releases resources
|
||||
*/
|
||||
void
|
||||
Win32_Utilities_fini(void)
|
||||
{
|
||||
/*
|
||||
* Release the pointers for Explorer Shell functions
|
||||
*/
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue