Newer
Older
//
// LogViewController.m
// xchighlight
//
// Created by EthanRDoesMC on 3/18/21.
//
#import "LogViewController.h"
#import <Foundation/Foundation.h>
#import "NSTask.h"
@interface LogViewController ()
@property (strong, nonatomic) IBOutlet UITextView *logField;
@end
@implementation LogViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view from its nib.
NSLog(@"Hello, World!");
NSMutableArray *arguments = [[NSMutableArray alloc] init];
//[arguments addObject:@"/Users/ethanrdoesmc/Downloads/mautrix-imessage-amd64/mautrix-imessage"];
//[arguments addObject:@"-c/var/mobile/Documents/mautrix-imessage-armv7/config.yaml"]; // Any arguments you want here...
[arguments addObject:@"-r/var/mobile/Documents/mautrix-imessage-armv7/registration.yaml"]; // Any arguments you want here...
_task = [[NSTask alloc] init];
[_task waitUntilExit];
_task.launchPath = @"/var/mobile/Documents/mautrix-imessage-armv7/mautrix-imessage";
_task.currentDirectoryPath = @"/var/mobile/Documents/mautrix-imessage-armv7/";
NSMutableDictionary *defaultEnv = [[NSMutableDictionary alloc] initWithDictionary:[[NSProcessInfo processInfo] environment]];
[defaultEnv setObject:@"YES" forKey:@"NSUnbufferedIO"];
// [defaultEnv setObject:@"/Users/ethanrdoesmc/" forKey:@"HOME"];
NSPipe *writePipe = [NSPipe pipe];
NSFileHandle *writeHandle = [writePipe fileHandleForWriting];
[task setStandardInput: writePipe];
_task.standardOutput = [NSPipe pipe];
[[_task.standardOutput fileHandleForReading] setReadabilityHandler:^(NSFileHandle *file) {
NSData *data = [file availableData]; // this will read to EOF, so call only once
NSString *string = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
NSLog(@"Task output! %@", string);
dispatch_async(dispatch_get_main_queue(), ^{
self->_logField.text = [self->_logField.text stringByAppendingString: string];
[self->_logField scrollRangeToVisible: NSMakeRange(self->_logField.text.length, 0)];
});
}];
_task.standardError = [NSPipe pipe];
[[_task.standardError fileHandleForReading] setReadabilityHandler:^(NSFileHandle *errfile) {
NSData *errdata = [errfile availableData]; // this will read to EOF, so call only once
NSString *errstring = [[NSString alloc] initWithData:errdata encoding:NSUTF8StringEncoding];
NSLog(@"Task output! %@", errstring);
dispatch_async(dispatch_get_main_queue(), ^{
self->_logField.text = [self->_logField.text stringByAppendingString: errstring];
[self->_logField scrollRangeToVisible: NSMakeRange(self->_logField.text.length, 0)];
});
}];
}
/*
#pragma mark - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
// Get the new view controller using [segue destinationViewController].
// Pass the selected object to the new view controller.
}
*/
@end