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

Fixed Cursor Bug. #92

Open
wants to merge 5 commits into
base: master
Choose a base branch
from
Open

Conversation

top1million
Copy link

The cursor issue has been resolved by implementing a method that accounts for new lines. This method retrieves the current line number and updates the cursor position accordingly in both the append and delete functions within onKey().

Copy link
Contributor

@pgervais pgervais left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A few comments to make the code better. There are several lines that are either debugging code or code that does nothing. Dropping them will make the diff shorter and more readable.

I haven't tried very hard to understand whether the way you did the fix was the best possible solution - I'll let @fundamental comment on that. I suspect the fix might not fully work on Windows where there are two newline characters at the end of each line (\r and \n). Could you work with @marahmbawwab to test that branch on Windows?

return @cursor_row
end

def calc_cursor_y()
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This method's name is confusing because it doesn't do what it says (there's no calculation involved, and 'y' is a bit ambiguous).
In that case you're returning @cursor_row, so a better name would be get_cursor_row. But Ruby makes it possible to shorten it further by simply using the same name as the attribute:

def cursor_row
  @cursor_row
end

This technique is used line 254 with pos.

See also https://ruby-doc.org/docs/ruby-doc-bundle/UsersGuide/rg/accessors.html

@@ -55,6 +55,14 @@ def initialize(vg, string, width, height)
calc_cursor_x
end

def calc_cursor_x()
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is already a method called calc_cursor_x on line 234, which means that one will shadow the other. And this particular definition of the method is also unused (you're not calling it in TextEdit.qml). You can drop the entire method then.

@@ -123,6 +131,7 @@ def string_to_stats
@chrcls << :space
elsif(c == "\n" || c == "\r")
@chrcls << :line

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This blank line does not seem to add much to the readability of the code and makes the overall diff longer. I think you can just drop that line.

@@ -65,15 +65,18 @@ Widget {
pos = self.label.length
pos = @edit.pos if @edit
ll = self.label
size = ll.split(" ").length
line = @edit.calc_cursor_y
puts @cursor[1]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is debugging code, right? Worth dropping it.

@@ -65,15 +65,18 @@ Widget {
pos = self.label.length
pos = @edit.pos if @edit
ll = self.label
size = ll.split(" ").length
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This defines the variable size which is then unused. You can drop the entire line then.

@@ -65,15 +65,18 @@ Widget {
pos = self.label.length
pos = @edit.pos if @edit
ll = self.label
size = ll.split(" ").length
line = @edit.calc_cursor_y
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some comment on the variable name: I tend to interpret line as meaning "the content of one line", instead of a number of lines. I think it'd be better named cursor_row in that case.

@pgervais
Copy link
Contributor

pgervais commented Apr 1, 2023

The change looks good to me now, thanks for your patience! @fundamental How does it look to you?

@fundamental
Copy link
Member

Can I have a bit of clarification as to the exact bug being fixed? I'm fine if this is documented in the source issue, but one is not linked. Specifically, "Setup", "Expected behavior", and "Actual behavior" (before fix). I'll assume after this fix the behavior is as is expected.

Additionally it looks like the comment about changing to an attr_reader :cursor_row is unresolved.

@top1million
Copy link
Author

It is important to note that attempting to insert or delete characters from lines with an index greater than 0 can result in an error. Specifically, this error arises because the new line character is not properly accounted for, leading to the omission of one character in each affected line.

For instance, if the cursor is positioned at index 0 of line 5 and an attempt is made to insert a character, the inserted character will actually appear at index -5 of line 4 instead of index 0 of line 5. To resolve this issue, it is necessary to recover the new line character and adjust the position accordingly to ensure that the intended modifications are made in the correct location.

@top1million
Copy link
Author

I am not sure about the attr_reader:cursor_row i recall my self doing it in later commits.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants