Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Vertical Cursor Guide #383

Open
wants to merge 32 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
68e3d2e
Render a vertical guide over the column the cursor is in (Metal View …
Mar 26, 2019
6827cb3
Separate control of the vertical cursor guide from the horizontal gu…
Mar 26, 2019
ed11a8e
Render a vertical cursor guide in the software rendered view (known i…
Mar 26, 2019
51d1fed
Fill out cursor column tracking API.
Mar 26, 2019
5b8119b
Fix names and style inconsistencies.
Apr 2, 2019
1b12bae
Rename a couple more "col" variables to use full names.
Apr 2, 2019
59f1be9
Fix bug with variable name type ("...Line" should be "...Column"). R…
Apr 2, 2019
683f718
Remove extraneous shared vertex buffer in favor of keeping more in th…
Apr 7, 2019
7af2a50
Remove bad boolean checks.
Apr 7, 2019
c8743a8
Use bounds from iTermCursorGuideRendererTransientState's cellConfigur…
Apr 7, 2019
1706bf1
Since [...textView setNeedsDisplayOnColumn...] is expensive (causes a…
Apr 7, 2019
933ed96
Factor out rectangle tessellation and vertex buffer creation.
Apr 7, 2019
7540e63
Do not double-draw the cursor guide under the cursor.
Apr 8, 2019
b7b9430
Render a vertical guide over the column the cursor is in (Metal View …
Mar 26, 2019
516e4bb
Separate control of the vertical cursor guide from the horizontal guide.
Mar 26, 2019
e99e660
Render a vertical cursor guide in the software rendered view.
Mar 26, 2019
139103b
Fill out cursor column tracking API.
Mar 26, 2019
025b02b
Fix bug with variable name type ("...Line" should be "...Column"). R…
Apr 2, 2019
921b5cf
Remove extraneous shared vertex buffer in favor of keeping more in th…
Apr 7, 2019
cd25d8c
Factor out rectangle tessellation and vertex buffer creation.
Apr 7, 2019
bdbe918
Use bounds from iTermCursorGuideRendererTransientState's cellConfigur…
Apr 7, 2019
48a48cc
Since [...textView setNeedsDisplayOnColumn...] is expensive (causes a…
Apr 7, 2019
262e707
Do not double-draw the cursor guide under the cursor.
Apr 8, 2019
64bf5c4
Fix style nits.
Apr 13, 2019
7c6142d
Fix rebase conflict.
Apr 13, 2019
a0bb3d5
Resolved conflicts with upstream branch.
Apr 13, 2019
1618e45
Remove merge/conflict resolution detritus.
Apr 13, 2019
7f4a4a4
Remove unused variable that seems to be causing CI build fails.
Apr 13, 2019
18c8e57
Add ability to render a vertical guide over the column the cursor is in.
Mar 26, 2019
c12ee73
Merged with upstream branch
Apr 18, 2019
66cf560
Remove code duplicated as a result of merge with upstream branch.
Apr 18, 2019
ed738eb
Disable code that references an undeclared identifier (brought in fro…
Apr 18, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions Interfaces/MainMenu.xib
Original file line number Diff line number Diff line change
Expand Up @@ -668,6 +668,12 @@ Gw
<action selector="toggleCursorGuide:" target="-1" id="Vxk-ww-Ugb"/>
</connections>
</menuItem>
<menuItem title="Show Vertical Cursor Guide" identifier="Show Vertical Cursor Guide" id="pPk-Wb-7b8">
ahelsley marked this conversation as resolved.
Show resolved Hide resolved
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleVerticalCursorGuide:" target="-1" id="I31-ik-Ak8"/>
</connections>
</menuItem>
<menuItem title="Show Timestamps" keyEquivalent="E" identifier="Show Timestamps" id="TnF-kz-Lf0">
<connections>
<action selector="toggleShowTimestamps:" target="-1" id="oGg-h2-Ex7"/>
Expand Down
17 changes: 15 additions & 2 deletions Interfaces/PreferencePanel.xib
Original file line number Diff line number Diff line change
Expand Up @@ -1545,6 +1545,7 @@ DQ
<outlet property="_useSmartCursorColor" destination="4889" id="GhQ-EU-ndl"/>
<outlet property="_useTabColor" destination="j7F-r8-oes" id="HoY-6m-E99"/>
<outlet property="_useUnderlineColor" destination="Cqf-RZ-UnO" id="HoY-6m-xxx"/>
<outlet property="_useVerticalGuide" destination="CDY-GW-Oi5" id="31z-FX-BPt"/>
<outlet property="delegate" destination="HVI-63-mNz" id="NFg-pP-EcM"/>
<outlet property="view" destination="SCN-fS-hNB" id="yvb-17-eJa"/>
</connections>
Expand Down Expand Up @@ -2272,7 +2273,7 @@ DQ
</textFieldCell>
</textField>
<customView id="Yny-j0-8Wk" customClass="CPKColorWell">
<rect key="frame" x="304" y="73" width="32" height="21"/>
<rect key="frame" x="304" y="84" width="32" height="21"/>
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMinY="YES"/>
<userDefinedRuntimeAttributes>
<userDefinedRuntimeAttribute type="boolean" keyPath="alphaAllowed" value="YES"/>
Expand Down Expand Up @@ -2323,7 +2324,7 @@ DQ
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMinY="YES"/>
</customView>
<button id="Rpk-o3-4ec">
<rect key="frame" x="193" y="74" width="105" height="18"/>
<rect key="frame" x="173" y="85" width="105" height="18"/>
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMinY="YES"/>
<buttonCell key="cell" type="check" title="Cursor guide" bezelStyle="regularSquare" imagePosition="left" alignment="left" state="on" inset="2" id="Ai2-im-FjJ">
<behavior key="behavior" changeContents="YES" doesNotDimImage="YES" lightByContents="YES"/>
Expand All @@ -2334,6 +2335,18 @@ DQ
<outlet property="nextKeyView" destination="4896" id="kw5-A8-LVc"/>
</connections>
</button>
<button id="CDY-GW-Oi5" userLabel="Use Vertical Guide">
<rect key="frame" x="173" y="65" width="148" height="18"/>
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMinY="YES"/>
<buttonCell key="cell" type="check" title="Vertical cursor guide" bezelStyle="regularSquare" imagePosition="left" alignment="left" state="on" inset="2" id="2Co-vY-kv7">
<behavior key="behavior" changeContents="YES" doesNotDimImage="YES" lightByContents="YES"/>
<font key="font" metaFont="system"/>
</buttonCell>
<connections>
<action selector="settingChanged:" target="p8i-eM-oBc" id="T94-1y-jPl"/>
<outlet property="nextKeyView" destination="4896" id="H8S-V8-cYY"/>
</connections>
</button>
<customView id="2286" customClass="CPKColorWell">
<rect key="frame" x="442" y="211" width="32" height="21"/>
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMinY="YES"/>
Expand Down
15 changes: 15 additions & 0 deletions iTerm2XCTests/PTYTextViewTest.m
Original file line number Diff line number Diff line change
Expand Up @@ -991,6 +991,21 @@ - (void)testCursorGuide {
size:VT100GridSizeMake(5, 5)];
}

// Draws a cursor guide on the col with b.
- (void)testVerticalCursorGuide {
[self doGoldenTestForInput:@"abcd\x1b[2A"
name:NSStringFromSelector(_cmd)
hook:^(PTYTextView *textView) {
textView.drawingHook = ^(iTermTextDrawingHelper *helper) {
helper.shouldDrawFilledInCursor = YES;
helper.highlightCursorColumn = YES;
};
}
profileOverrides:nil
createGolden:YES
size:VT100GridSizeMake(5, 5)];
}

// Draws a badge which blends with nondefault background colors.
- (void)testBadge {
[self doGoldenTestForInput:@"\n\n\n\nxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\x1b[42mabc"
Expand Down
3 changes: 3 additions & 0 deletions iTerm2XCTests/VT100GridTest.m
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,9 @@ - (screen_char_t)gridBackgroundColorCode {
- (void)gridCursorDidChangeLine {
}

- (void)gridCursorDidChangeColumn {
}

- (iTermUnicodeNormalization)gridUnicodeNormalizationForm {
return iTermUnicodeNormalizationNone;
}
Expand Down
6 changes: 6 additions & 0 deletions iTerm2XCTests/VT100ScreenTest.m
Original file line number Diff line number Diff line change
Expand Up @@ -748,6 +748,12 @@ - (void)screenSetHighlightCursorLine:(BOOL)highlight {
- (void)screenCursorDidMoveToLine:(int)line {
}

- (void)screenSetHighlightCursorColumn:(BOOL)highlight {
}

- (void)screenCursorDidMoveToColumn:(int)line {
}

- (void)screenSaveScrollPosition {
}

Expand Down
1 change: 1 addition & 0 deletions sources/ITAddressBookMgr.h
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,7 @@
#define KEY_USE_UNDERLINE_COLOR @"Use Underline Color"
#define KEY_CURSOR_BOOST @"Cursor Boost"
#define KEY_USE_CURSOR_GUIDE @"Use Cursor Guide"
#define KEY_USE_VERTICAL_CURSOR_GUIDE @"Use Vertical Cursor Guide"
#define KEY_CURSOR_GUIDE_COLOR @"Cursor Guide Color"
#define KEY_BADGE_COLOR @"Badge Color"

Expand Down
7 changes: 4 additions & 3 deletions sources/Metal/Renderers/iTermCursorGuideRenderer.h
Original file line number Diff line number Diff line change
@@ -1,17 +1,18 @@
#import <Foundation/Foundation.h>

#import "iTermMetalCellRenderer.h"
#import "VT100GridTypes.h"

NS_ASSUME_NONNULL_BEGIN

@interface iTermCursorGuideRendererTransientState : iTermMetalCellRendererTransientState
// set to -1 if cursor's row is not currently visible.
- (void)setRow:(int)row;
- (void)setCursorCoord:(VT100GridCoord)coord within:(VT100GridSize)bounds;
ahelsley marked this conversation as resolved.
Show resolved Hide resolved
@end

@interface iTermCursorGuideRenderer : NSObject<iTermMetalCellRenderer>

@property (nonatomic) BOOL enabled;
@property (nonatomic) BOOL horizontalEnabled;
@property (nonatomic) BOOL verticalEnabled;

- (nullable instancetype)initWithDevice:(id<MTLDevice>)device NS_DESIGNATED_INITIALIZER;
- (instancetype)init NS_UNAVAILABLE;
Expand Down
Loading