Cocoa Port:

- Fix a bug where duplicate commands would appear in the input profile viewer whenever a command had zero inputs mapped to it.
- Fix device info summary of the Touch command in the Default input profile.
This commit is contained in:
rogerman 2013-04-17 18:26:17 +00:00
parent d18a0e1782
commit ac5191161a
3 changed files with 85 additions and 20 deletions

View File

@ -227,7 +227,7 @@
<array> <array>
<dict> <dict>
<key>deviceInfoSummary</key> <key>deviceInfoSummary</key>
<string>Keyboard: Primary Button</string> <string>Mouse: Primary Button</string>
<key>deviceCode</key> <key>deviceCode</key>
<string>NSEventMouse</string> <string>NSEventMouse</string>
<key>deviceName</key> <key>deviceName</key>

View File

@ -54,6 +54,7 @@
NSDictionary *inputSettingsMappings; NSDictionary *inputSettingsMappings;
NSUInteger _defaultProfileListCount; NSUInteger _defaultProfileListCount;
NSMutableArray *defaultProfilesList;
NSMutableArray *savedProfilesList; NSMutableArray *savedProfilesList;
} }

View File

@ -56,16 +56,77 @@
return self; return self;
} }
// Note that we manually reconstruct the profile dictionaries down to the mappings since
// we depend on the input lists having unique pointers. In other words, since all empty
// NSArrays have the same pointer, we remake them into NSMutableArrays to force their
// pointers to be unique. The reason we do this is because commandTagFromInputList: depends
// on searching for unique pointers to match up command tags. If we don't do this, there
// will be duplicate entries in the NSOutlineViews for every empty input list.
NSDictionary *defaultKeyMappingsDict = [NSDictionary dictionaryWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"DefaultKeyMappings" ofType:@"plist"]]; NSDictionary *defaultKeyMappingsDict = [NSDictionary dictionaryWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"DefaultKeyMappings" ofType:@"plist"]];
NSArray *defaultProfileList = [defaultKeyMappingsDict valueForKey:@"DefaultInputProfiles"]; NSArray *internalDefaultProfilesList = (NSArray *)[defaultKeyMappingsDict valueForKey:@"DefaultInputProfiles"];
_defaultProfileListCount = [defaultProfileList count]; _defaultProfileListCount = [internalDefaultProfilesList count];
defaultProfilesList = [[NSMutableArray alloc] initWithCapacity:_defaultProfileListCount];
for (NSDictionary *theProfile in internalDefaultProfilesList)
{
NSMutableDictionary *reconstructedProfile = [[NSMutableDictionary alloc] initWithCapacity:[theProfile count]];
for (NSString *profileKey in theProfile)
{
if ([profileKey isEqualToString:@"Mappings"])
{
NSDictionary *profileMappings = (NSDictionary *)[theProfile objectForKey:profileKey];
NSMutableDictionary *reconstructedMappings = [[NSMutableDictionary alloc] initWithCapacity:[profileMappings count]];
for (NSString *mappingKey in profileMappings)
{
NSArray *inputList = (NSArray *)[profileMappings objectForKey:mappingKey];
NSMutableArray *newInputList = [[NSMutableArray alloc] initWithArray:inputList copyItems:YES];
[reconstructedMappings setObject:[newInputList autorelease] forKey:mappingKey];
}
[reconstructedProfile setObject:[reconstructedMappings autorelease] forKey:profileKey];
}
else
{
[reconstructedProfile setObject:[theProfile objectForKey:profileKey] forKey:profileKey];
}
}
[defaultProfilesList addObject:[reconstructedProfile autorelease]];
}
NSArray *userDefaultsSavedProfilesList = (NSArray *)[[NSUserDefaults standardUserDefaults] arrayForKey:@"Input_SavedProfiles"]; NSArray *userDefaultsSavedProfilesList = (NSArray *)[[NSUserDefaults standardUserDefaults] arrayForKey:@"Input_SavedProfiles"];
savedProfilesList = [[NSMutableArray alloc] initWithCapacity:32]; savedProfilesList = [[NSMutableArray alloc] initWithCapacity:32];
for (NSDictionary *savedProfile in userDefaultsSavedProfilesList) for (NSDictionary *theProfile in userDefaultsSavedProfilesList)
{ {
[savedProfilesList addObject:[NSMutableDictionary dictionaryWithDictionary:savedProfile]]; NSMutableDictionary *reconstructedProfile = [[NSMutableDictionary alloc] initWithCapacity:[theProfile count]];
for (NSString *profileKey in theProfile)
{
if ([profileKey isEqualToString:@"Mappings"])
{
NSDictionary *profileMappings = (NSDictionary *)[theProfile objectForKey:profileKey];
NSMutableDictionary *reconstructedMappings = [[NSMutableDictionary alloc] initWithCapacity:[profileMappings count]];
for (NSString *mappingKey in profileMappings)
{
NSArray *inputList = (NSArray *)[profileMappings objectForKey:mappingKey];
NSMutableArray *newInputList = [[NSMutableArray alloc] initWithArray:inputList copyItems:YES];
[reconstructedMappings setObject:[newInputList autorelease] forKey:mappingKey];
}
[reconstructedProfile setObject:[reconstructedMappings autorelease] forKey:profileKey];
}
else
{
[reconstructedProfile setObject:[theProfile objectForKey:profileKey] forKey:profileKey];
}
}
[savedProfilesList addObject:[reconstructedProfile autorelease]];
} }
configInputTargetID = nil; configInputTargetID = nil;
@ -765,10 +826,22 @@
newProfileName = [NSString stringWithFormat:@"Untitled %ld", (unsigned long)++untitledCount]; newProfileName = [NSString stringWithFormat:@"Untitled %ld", (unsigned long)++untitledCount];
} }
// Reconstruct the mappings dictionary to use NSMutableArrays to prevent duplicate
// entries from showing up in the NSOutlineView.
NSDictionary *profileMappings = [inputManager inputMappings];
NSMutableDictionary *reconstructedMappings = [[NSMutableDictionary alloc] initWithCapacity:[profileMappings count]];
for (NSString *mappingKey in profileMappings)
{
NSArray *inputList = (NSArray *)[profileMappings objectForKey:mappingKey];
NSMutableArray *newInputList = [[NSMutableArray alloc] initWithArray:inputList copyItems:YES];
[reconstructedMappings setObject:[newInputList autorelease] forKey:mappingKey];
}
NSMutableDictionary *newProfile = [NSMutableDictionary dictionaryWithObjectsAndKeys: NSMutableDictionary *newProfile = [NSMutableDictionary dictionaryWithObjectsAndKeys:
newProfileName, @"Name", newProfileName, @"Name",
[NSNumber numberWithBool:NO], @"IsDefaultType", [NSNumber numberWithBool:NO], @"IsDefaultType",
[[[NSMutableDictionary alloc] initWithDictionary:[inputManager inputMappings] copyItems:YES] autorelease], @"Mappings", [reconstructedMappings autorelease], @"Mappings",
nil]; nil];
[savedProfilesList addObject:newProfile]; [savedProfilesList addObject:newProfile];
@ -883,22 +956,12 @@
- (IBAction) profileSelect:(id)sender - (IBAction) profileSelect:(id)sender
{ {
const NSInteger profileID = [CocoaDSUtil getIBActionSenderTag:sender]; const NSInteger profileID = [CocoaDSUtil getIBActionSenderTag:sender];
NSArray *profileList = nil;
if (profileID < 0 || profileID >= (NSInteger)(_defaultProfileListCount + [savedProfilesList count])) if (profileID < 0 || profileID >= (NSInteger)(_defaultProfileListCount + [savedProfilesList count]))
{ {
return; return;
} }
if (profileID < (NSInteger)_defaultProfileListCount) // Select one of the default profiles NSArray *profileList = (profileID < (NSInteger)_defaultProfileListCount) ? defaultProfilesList : savedProfilesList;
{
NSDictionary *defaultKeyMappingsDict = [NSDictionary dictionaryWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"DefaultKeyMappings" ofType:@"plist"]];
profileList = [defaultKeyMappingsDict valueForKey:@"DefaultInputProfiles"];
}
else // Select one of the saved configs
{
profileList = savedProfilesList;
}
[inputProfilePreviousButton setTag:profileID-1]; [inputProfilePreviousButton setTag:profileID-1];
[inputProfilePreviousButton setEnabled:(profileID > 0) ? YES : NO]; [inputProfilePreviousButton setEnabled:(profileID > 0) ? YES : NO];
@ -910,7 +973,8 @@
[inputProfileMenu selectItemAtIndex:(profileID < (NSInteger)_defaultProfileListCount) ? profileID : profileID+1]; [inputProfileMenu selectItemAtIndex:(profileID < (NSInteger)_defaultProfileListCount) ? profileID : profileID+1];
} }
[inputProfileController setContent:[profileList objectAtIndex:(profileID < (NSInteger)_defaultProfileListCount) ? profileID : (profileID - _defaultProfileListCount)]]; NSMutableDictionary *selectedProfile = (NSMutableDictionary *)[profileList objectAtIndex:(profileID < (NSInteger)_defaultProfileListCount) ? profileID : (profileID - _defaultProfileListCount)];
[inputProfileController setContent:selectedProfile];
[[inputProfileController profileOutlineView] reloadData]; [[inputProfileController profileOutlineView] reloadData];
[[inputProfileController profileOutlineView] expandItem:nil expandChildren:YES]; [[inputProfileController profileOutlineView] expandItem:nil expandChildren:YES];
} }