1
1
mirror of https://github.com/qvacua/vimr.git synced 2024-11-28 11:35:35 +03:00

Use API to get tabs

This commit is contained in:
Tae Won Ha 2017-12-01 13:46:34 +01:00
parent 8eb994ffda
commit 28e092ab40
No known key found for this signature in database
GPG Key ID: E40743465B5B8B44
11 changed files with 90 additions and 94 deletions

View File

@ -59,7 +59,6 @@ typedef NS_ENUM(NSInteger, NeoVimAgentMsgId) {
NeoVimAgentMsgIdGetPwd, NeoVimAgentMsgIdGetPwd,
NeoVimAgentMsgIdGetEscapeFileNames, NeoVimAgentMsgIdGetEscapeFileNames,
NeoVimAgentMsgIdGetTabs,
NeoVimAgentMsgIdGetBoolOption, NeoVimAgentMsgIdGetBoolOption,
NeoVimAgentMsgIdSetBoolOption, NeoVimAgentMsgIdSetBoolOption,

View File

@ -72,8 +72,6 @@ static CFDataRef local_server_callback(CFMessagePortRef local, SInt32 msgid, CFD
case NeoVimAgentMsgIdScroll: return data_sync(data, outputCondition, neovim_scroll); case NeoVimAgentMsgIdScroll: return data_sync(data, outputCondition, neovim_scroll);
case NeoVimAgentMsgIdGetTabs: return data_sync(data, outputCondition, neovim_tabs);
case NeoVimAgentMsgIdGetBoolOption: return data_sync(data, outputCondition, neovim_get_bool_option); case NeoVimAgentMsgIdGetBoolOption: return data_sync(data, outputCondition, neovim_get_bool_option);
case NeoVimAgentMsgIdSetBoolOption: return data_sync(data, outputCondition, neovim_set_bool_option); case NeoVimAgentMsgIdSetBoolOption: return data_sync(data, outputCondition, neovim_set_bool_option);

View File

@ -15,7 +15,6 @@ extern void start_neovim(NSInteger width, NSInteger height, NSArray<NSString *>
extern void neovim_select_window(void **argv); extern void neovim_select_window(void **argv);
extern void neovim_scroll(void **argv); extern void neovim_scroll(void **argv);
extern void neovim_tabs(void **argv);
extern void neovim_vim_command_output(void **argv); extern void neovim_vim_command_output(void **argv);
extern void neovim_set_bool_option(void **argv); extern void neovim_set_bool_option(void **argv);
extern void neovim_get_bool_option(void **argv); extern void neovim_get_bool_option(void **argv);

View File

@ -684,32 +684,6 @@ static NSString *escaped_filename(NSString *filename) {
return result; return result;
} }
static NeoVimBuffer *buffer_for(buf_T *buf) {
// To be sure...
if (buf == NULL) {
return nil;
}
bool readonly = (bool) bt_nofile(buf);
NSString *fileName = nil;
if (buf->b_ffname != NULL) {
fileName = [NSString stringWithCString:(const char *) buf->b_ffname
encoding:NSUTF8StringEncoding];
}
bool current = curbuf == buf;
bool dirty = readonly ? false : (bool) buf->b_changed;
NeoVimBuffer *buffer = [[NeoVimBuffer alloc] initWithHandle:buf->handle
unescapedPath:fileName
dirty:dirty
readOnly:readonly
current:current];
return [buffer autorelease];
}
void neovim_scroll(void **argv) { void neovim_scroll(void **argv) {
work_and_write_data_sync(argv, ^NSData *(NSData *data) { work_and_write_data_sync(argv, ^NSData *(NSData *data) {
NSInteger *values = (NSInteger *) data.bytes; NSInteger *values = (NSInteger *) data.bytes;
@ -770,41 +744,6 @@ void neovim_select_window(void **argv) {
}); });
} }
void neovim_tabs(void **argv) {
work_and_write_data_sync(argv, ^NSData *(NSData *data) {
NSMutableArray *tabs = [[NSMutableArray new] autorelease];
FOR_ALL_TABS(t) {
NSMutableArray *windows = [NSMutableArray new];
bool currentTab = curtab ? t->handle == curtab->handle : false;
FOR_ALL_WINDOWS_IN_TAB(win, t) {
NeoVimBuffer *buffer = buffer_for(win->w_buffer);
if (buffer == nil) {
continue;
}
bool current = false;
// tp_curwin is only valid for tabs that aren't the current one
if (currentTab) current = curwin ? win->handle == curwin->handle : false;
else if (t->tp_curwin) current = win->handle == t->tp_curwin->handle;
NeoVimWindow *window = [[NeoVimWindow alloc] initWithHandle:win->handle buffer:buffer currentInTab:current];
[windows addObject:window];
[window release];
}
NeoVimTab *tab = [[NeoVimTab alloc] initWithHandle:t->handle windows:windows current:currentTab];
[windows release];
[tabs addObject:tab];
[tab release];
}
DLOG("tabs: %s", tabs.description.cstr);
return [NSKeyedArchiver archivedDataWithRootObject:tabs];
});
}
void neovim_vim_command_output(void **argv) { void neovim_vim_command_output(void **argv) {
work_and_write_data_sync(argv, ^NSData *(NSData *data) { work_and_write_data_sync(argv, ^NSData *(NSData *data) {
NSString *input = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]; NSString *input = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];

View File

@ -21,7 +21,11 @@ public class Nvim {
} }
} }
public struct Window { public struct Window: Equatable {
public static func ==(lhs: Window, rhs: Window) -> Bool {
return lhs.handle == rhs.handle
}
public let handle: Int public let handle: Int
@ -30,7 +34,11 @@ public class Nvim {
} }
} }
public struct Tabpage { public struct Tabpage: Equatable {
public static func ==(lhs: Tabpage, rhs: Tabpage) -> Bool {
return lhs.handle == rhs.handle
}
public let handle: Int public let handle: Int
@ -206,6 +214,7 @@ public class Nvim {
self.session.stop() self.session.stop()
} }
@discardableResult
public func checkBlocked<T>(_ fn: () -> Nvim.Response<T>) -> Nvim.Response<T> { public func checkBlocked<T>(_ fn: () -> Nvim.Response<T>) -> Nvim.Response<T> {
if self.getMode().value?.dictionaryValue?[.string("blocked")] == .bool(true) { if self.getMode().value?.dictionaryValue?[.string("blocked")] == .bool(true) {
return Nvim.Response.failure(Nvim.Error(type: .blocked, message: "Nvim is currently blocked.")) return Nvim.Response.failure(Nvim.Error(type: .blocked, message: "Nvim is currently blocked."))

View File

@ -64,6 +64,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func bufSetLines( public func bufSetLines(
buffer: Nvim.Buffer, buffer: Nvim.Buffer,
start: Int, start: Int,
@ -156,6 +157,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func bufSetVar( public func bufSetVar(
buffer: Nvim.Buffer, buffer: Nvim.Buffer,
name: String, name: String,
@ -177,6 +179,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func bufDelVar( public func bufDelVar(
buffer: Nvim.Buffer, buffer: Nvim.Buffer,
name: String, name: String,
@ -219,6 +222,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func bufSetOption( public func bufSetOption(
buffer: Nvim.Buffer, buffer: Nvim.Buffer,
name: String, name: String,
@ -261,6 +265,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func bufSetName( public func bufSetName(
buffer: Nvim.Buffer, buffer: Nvim.Buffer,
name: String, name: String,
@ -355,6 +360,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func bufClearHighlight( public func bufClearHighlight(
buffer: Nvim.Buffer, buffer: Nvim.Buffer,
src_id: Int, src_id: Int,
@ -422,6 +428,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func tabpageSetVar( public func tabpageSetVar(
tabpage: Nvim.Tabpage, tabpage: Nvim.Tabpage,
name: String, name: String,
@ -443,6 +450,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func tabpageDelVar( public func tabpageDelVar(
tabpage: Nvim.Tabpage, tabpage: Nvim.Tabpage,
name: String, name: String,
@ -525,6 +533,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func uiAttach( public func uiAttach(
width: Int, width: Int,
height: Int, height: Int,
@ -546,6 +555,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func uiDetach( public func uiDetach(
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
) -> Nvim.Response<Void> { ) -> Nvim.Response<Void> {
@ -562,6 +572,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func uiTryResize( public func uiTryResize(
width: Int, width: Int,
height: Int, height: Int,
@ -581,6 +592,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func uiSetOption( public func uiSetOption(
name: String, name: String,
value: Nvim.Value, value: Nvim.Value,
@ -600,6 +612,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func command( public func command(
command: String, command: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -663,6 +676,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func feedkeys( public func feedkeys(
keys: String, keys: String,
mode: String, mode: String,
@ -861,6 +875,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func setCurrentDir( public func setCurrentDir(
dir: String, dir: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -898,6 +913,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func setCurrentLine( public func setCurrentLine(
line: String, line: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -915,6 +931,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func delCurrentLine( public func delCurrentLine(
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
) -> Nvim.Response<Void> { ) -> Nvim.Response<Void> {
@ -952,6 +969,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func setVar( public func setVar(
name: String, name: String,
value: Nvim.Value, value: Nvim.Value,
@ -971,6 +989,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func delVar( public func delVar(
name: String, name: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1030,6 +1049,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func setOption( public func setOption(
name: String, name: String,
value: Nvim.Value, value: Nvim.Value,
@ -1049,6 +1069,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func outWrite( public func outWrite(
str: String, str: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1066,6 +1087,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func errWrite( public func errWrite(
str: String, str: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1083,6 +1105,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func errWriteln( public func errWriteln(
str: String, str: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1140,6 +1163,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func setCurrentBuf( public func setCurrentBuf(
buffer: Nvim.Buffer, buffer: Nvim.Buffer,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1197,6 +1221,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func setCurrentWin( public func setCurrentWin(
window: Nvim.Window, window: Nvim.Window,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1254,6 +1279,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func setCurrentTabpage( public func setCurrentTabpage(
tabpage: Nvim.Tabpage, tabpage: Nvim.Tabpage,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1271,6 +1297,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func subscribe( public func subscribe(
event: String, event: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1288,6 +1315,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func unsubscribe( public func unsubscribe(
event: String, event: String,
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
@ -1470,6 +1498,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func winSetCursor( public func winSetCursor(
window: Nvim.Window, window: Nvim.Window,
pos: [Int], pos: [Int],
@ -1510,6 +1539,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func winSetHeight( public func winSetHeight(
window: Nvim.Window, window: Nvim.Window,
height: Int, height: Int,
@ -1550,6 +1580,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func winSetWidth( public func winSetWidth(
window: Nvim.Window, window: Nvim.Window,
width: Int, width: Int,
@ -1592,6 +1623,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func winSetVar( public func winSetVar(
window: Nvim.Window, window: Nvim.Window,
name: String, name: String,
@ -1613,6 +1645,7 @@ public extension Nvim {
return .success(()) return .success(())
} }
@discardableResult
public func winDelVar( public func winDelVar(
window: Nvim.Window, window: Nvim.Window,
name: String, name: String,
@ -1655,6 +1688,7 @@ public extension Nvim {
return .success(result) return .success(result)
} }
@discardableResult
public func winSetOption( public func winSetOption(
window: Nvim.Window, window: Nvim.Window,
name: String, name: String,

View File

@ -48,8 +48,6 @@ NS_ASSUME_NONNULL_BEGIN
- (NSString * _Nullable)escapedFileName:(NSString *)fileName; - (NSString * _Nullable)escapedFileName:(NSString *)fileName;
- (NSArray<NSString *> *)escapedFileNames:(NSArray<NSString *> *)fileNames; - (NSArray<NSString *> *)escapedFileNames:(NSArray<NSString *> *)fileNames;
//- (NSArray<NeoVimBuffer *> *)buffers;
- (NSArray<NeoVimTab*> *)tabs;
- (void)scrollHorizontal:(NSInteger)horiz vertical:(NSInteger)vert at:(Position)position; - (void)scrollHorizontal:(NSInteger)horiz vertical:(NSInteger)vert at:(Position)position;
- (void)selectWindow:(NeoVimWindow *)window; - (void)selectWindow:(NeoVimWindow *)window;

View File

@ -373,26 +373,6 @@ static CFDataRef local_server_callback(CFMessagePortRef local __unused, SInt32 m
return [NSKeyedUnarchiver unarchiveObjectWithData:response]; return [NSKeyedUnarchiver unarchiveObjectWithData:response];
} }
//- (NSArray <NeoVimBuffer *> *)buffers {
// NSData *response = [self sendMessageWithId:NeoVimAgentMsgIdGetBuffers data:nil expectsReply:YES];
// if (response == nil) {
// log4Warn("The response for the msg %ld was nil.", (long) NeoVimAgentMsgIdGetBuffers);
// return @[];
// }
//
// return [NSKeyedUnarchiver unarchiveObjectWithData:response];
//}
- (NSArray<NeoVimWindow *> *)tabs {
NSData *response = [self sendMessageWithId:NeoVimAgentMsgIdGetTabs data:nil expectsReply:YES];
if (response == nil) {
log4Warn("The response for the msg %ld was nil.", (long) NeoVimAgentMsgIdGetTabs);
return @[];
}
return [NSKeyedUnarchiver unarchiveObjectWithData:response];
}
- (void)runLocalServer { - (void)runLocalServer {
@autoreleasepool { @autoreleasepool {
CFMessagePortContext localContext = { CFMessagePortContext localContext = {

View File

@ -41,13 +41,22 @@ extension NeoVimView {
return self.currentBuffer()?.isDirty ?? false return self.currentBuffer()?.isDirty ?? false
} }
public func allTabs() -> [NeoVimTab] {
let curBuf = self.nvim.checkBlocked { self.nvim.getCurrentBuf() }.value
let curTab = self.nvim.checkBlocked { self.nvim.getCurrentTabpage() }.value
return self.nvim.checkBlocked({ nvim.listTabpages() })
.value?
.flatMap { self.neoVimTab(for: $0, currentTabpage: curTab, currentBuffer: curBuf) } ?? []
}
public func newTab() { public func newTab() {
self.exec(command: "tabe") self.exec(command: "tabe")
} }
public func `open`(urls: [URL]) { public func `open`(urls: [URL]) {
let tabs = self.agent.tabs() let tabs = self.allTabs()
let buffers = self.allBuffers() let buffers = tabs.map { $0.windows }.flatMap { $0 }.map { $0.buffer }
let currentBufferIsTransient = buffers.first { $0.isCurrent }?.isTransient ?? false let currentBufferIsTransient = buffers.first { $0.isCurrent }?.isTransient ?? false
urls.enumerated().forEach { (idx, url) in urls.enumerated().forEach { (idx, url) in
@ -85,7 +94,7 @@ extension NeoVimView {
} }
public func select(buffer: NeoVimBuffer) { public func select(buffer: NeoVimBuffer) {
for window in self.agent.tabs().map({ $0.windows }).flatMap({ $0 }) { for window in self.allTabs().map({ $0.windows }).flatMap({ $0 }) {
if window.buffer.handle == buffer.handle { if window.buffer.handle == buffer.handle {
self.agent.select(window) self.agent.select(window)
return return
@ -191,6 +200,36 @@ extension NeoVimView {
return NeoVimBuffer(handle: buf.handle, unescapedPath: path, dirty: dirty, readOnly: readonly, current: current) return NeoVimBuffer(handle: buf.handle, unescapedPath: path, dirty: dirty, readOnly: readonly, current: current)
} }
private func neoVimWindow(for window: Nvim.Window,
currentWindow: Nvim.Window?,
currentBuffer: Nvim.Buffer?) -> NeoVimWindow? {
guard let buf = self.nvim.checkBlocked({ self.nvim.winGetBuf(window: window) }).value else {
return nil
}
guard let buffer = self.neoVimBuffer(for: buf, currentBuffer: currentBuffer) else {
return nil
}
return NeoVimWindow(handle: window.handle, buffer: buffer, currentInTab: window == currentWindow)
}
private func neoVimTab(for tabpage: Nvim.Tabpage,
currentTabpage: Nvim.Tabpage?,
currentBuffer: Nvim.Buffer?) -> NeoVimTab? {
let curWinInTab = self.nvim.checkBlocked { self.nvim.tabpageGetWin(tabpage: tabpage) }.value
let windows: [NeoVimWindow] = self.nvim.checkBlocked { self.nvim.tabpageListWins(tabpage: tabpage) }
.value?
.flatMap { self.neoVimWindow(for: $0,
currentWindow: curWinInTab,
currentBuffer: currentBuffer) } ?? []
return NeoVimTab(handle: tabpage.handle, windows: windows, current: tabpage == currentTabpage)
}
} }
fileprivate let neoVimQuitTimeout = TimeInterval(5) fileprivate let neoVimQuitTimeout = TimeInterval(5)

View File

@ -53,7 +53,7 @@ extension NeoVimView : NSTouchBarDelegate, NSScrubberDataSource, NSScrubberDeleg
func updateTouchBarCurrentBuffer() { func updateTouchBarCurrentBuffer() {
guard let tabsControl = getTabsControl() else { return } guard let tabsControl = getTabsControl() else { return }
tabsCache = self.agent.tabs() tabsCache = self.allTabs()
tabsControl.reloadData() tabsControl.reloadData()
(tabsControl.scrubberLayout as! NSScrubberProportionalLayout).numberOfVisibleItems = tabsControl.numberOfItems > 0 ? tabsControl.numberOfItems : 1 (tabsControl.scrubberLayout as! NSScrubberProportionalLayout).numberOfVisibleItems = tabsControl.numberOfItems > 0 ? tabsControl.numberOfItems : 1
tabsControl.selectedIndex = selectedTabIndex() tabsControl.selectedIndex = selectedTabIndex()
@ -61,7 +61,7 @@ extension NeoVimView : NSTouchBarDelegate, NSScrubberDataSource, NSScrubberDeleg
func updateTouchBarTab() { func updateTouchBarTab() {
guard let tabsControl = getTabsControl() else { return } guard let tabsControl = getTabsControl() else { return }
tabsCache = self.agent.tabs() tabsCache = self.allTabs()
tabsControl.reloadData() tabsControl.reloadData()
tabsControl.selectedIndex = selectedTabIndex() tabsControl.selectedIndex = selectedTabIndex()
} }

View File

@ -9,6 +9,7 @@ import os
void_func_template = Template('''\ void_func_template = Template('''\
@discardableResult
public func ${func_name}(${args} public func ${func_name}(${args}
expectsReturnValue: Bool = true expectsReturnValue: Bool = true
) -> Nvim.Response<Void> { ) -> Nvim.Response<Void> {