Skip to content

Commit

Permalink
Merge pull request #12760 from keymanapp/refactor/mac/12499-load-keyb…
Browse files Browse the repository at this point in the history
…oard-from-blob

refactor(mac): pass kmx data blob to keyman core instead of file path
  • Loading branch information
sgschantz authored Dec 4, 2024
2 parents 00815e3 + 8bc144b commit 4ddcfc9
Showing 1 changed file with 17 additions and 5 deletions.
22 changes: 17 additions & 5 deletions mac/KeymanEngine4Mac/KeymanEngine4Mac/CoreWrapper/CoreWrapper.m
Original file line number Diff line number Diff line change
Expand Up @@ -110,11 +110,23 @@ -(void) dealloc{

-(void)loadKeyboardUsingCore:(NSString*) path {
km_core_path_name keyboardPath = [path UTF8String];
km_core_status result = km_core_keyboard_load(keyboardPath, &_coreKeyboard);
NSError* dataError = nil;
NSData *data = [NSData dataWithContentsOfFile:path options:0 error:&dataError];

if (result != KM_CORE_STATUS_OK) {
NSString *message = [NSString stringWithFormat:@"Unexpected Keyman Core result: %u", result];
[NSException raise:@"LoadKeyboardException" format:@"%@", message];
if (dataError != nil) {
os_log_error([KMELogs coreLog], "loadKeyboardUsingCore, path: %{public}@\n dataError: %{public}@", path, dataError);
[NSException raise:@"LoadKeyboardException" format:@"%@", dataError];
} else {
NSUInteger dataLength = data.length;
os_log_info([KMELogs coreLog], "loadKeyboardUsingCore, path: %{public}@\n dataLength: %lu", path, dataLength);

km_core_status result = km_core_keyboard_load_from_blob(keyboardPath,
data.bytes, dataLength, &_coreKeyboard);
if (result != KM_CORE_STATUS_OK) {
NSString *message = [NSString stringWithFormat:@"Unexpected Keyman Core result: %u", result];
os_log_error([KMELogs coreLog], "loadKeyboardUsingCore, path: %{public}@\n core result: %{public}@", path, message);
[NSException raise:@"LoadKeyboardException" format:@"%@", message];
}
}
}

Expand All @@ -126,7 +138,7 @@ -(void)readKeyboardAttributesUsingCore {
if (result==KM_CORE_STATUS_OK) {
_keyboardVersion = [self.coreHelper createNSStringFromUnicharString:keyboardAttributes->version_string];
_keyboardId = [self.coreHelper createNSStringFromUnicharString:keyboardAttributes->id];
os_log_debug([KMELogs coreLog], "readKeyboardAttributesUsingCore, keyboardVersion: %{public}@\n, keyboardId: %{public}@\n", _keyboardVersion, _keyboardId);
os_log_debug([KMELogs coreLog], "readKeyboardAttributesUsingCore, keyboardVersion: %{public}@, keyboardId: %{public}@\n", _keyboardVersion, _keyboardId);
} else {
os_log_error([KMELogs coreLog], "km_core_keyboard_get_attrs() failed with result = %u\n", result);
}
Expand Down

0 comments on commit 4ddcfc9

Please sign in to comment.