-
Notifications
You must be signed in to change notification settings - Fork 817
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
fix: crash in robotic arm activity #2652
base: development
Are you sure you want to change the base?
fix: crash in robotic arm activity #2652
Conversation
Reviewer's Guide by SourceryThis pull request fixes a crash in the Robotic Arm activity that occurred when the app tried to parse an empty string to an integer. To fix this, the code was modified to validate the input from the EditText fields. If the input is empty, the code now restores the previous valid value. No diagrams generated as the changes look simple and do not need a visual representation. File-Level Changes
Tips and commandsInteracting with Sourcery
Customizing Your ExperienceAccess your dashboard to:
Getting Help
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hey @rahul31124 - I've reviewed your changes - here's some feedback:
Overall Comments:
- Consider refactoring the duplicated code into a separate method to improve readability and maintainability.
- The logic for restoring the previous degree when the input is empty could be simplified.
Here's what I looked at during the review
- 🟡 General issues: 1 issue found
- 🟢 Security: all looks good
- 🟢 Testing: all looks good
- 🟡 Complexity: 1 issue found
- 🟢 Documentation: all looks good
Help me be more useful! Please click 👍 or 👎 on each comment and I'll use the feedback to improve your reviews.
@@ -354,8 +354,20 @@ public boolean onLongClick(View v) { | |||
@Override | |||
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) { | |||
removeStatusBar(); | |||
int previousDegree = degree; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
suggestion: Consider consolidating similar logic into a helper method.
The same pattern of retrieving, trimming, checking if empty, and conditionally setting the 'degree' value is repeated for each text field. Extracting the common logic into a private helper method would reduce duplication and make future maintenance easier.
@@ -354,8 +354,20 @@ public boolean onLongClick(View v) { | |||
@Override | |||
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) { | |||
removeStatusBar(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
issue (complexity): Consider extracting the duplicated degree parsing and updating logic into a helper method to reduce redundancy and improve code maintainability by calling the helper method in each listener with the corresponding text view and seek arc parameters, instead of repeating the logic in each listener.
Consider centralizing the duplicated degree parsing/updating logic into a helper method. This avoids duplicating the if/else statements and state updates in each listener. For example, you could do the following:
-
Extract a Helper Method
Define a method that processes the degree input and updates the associated seek arc:
private void processDegreeInput(TextView degreeText, SeekArc seekArc) { int previousDegree = degree; String degreeStr = degreeText.getText().toString().trim(); if (degreeStr.isEmpty()) { degree = (degree == 0) ? (int) (seekArc.getProgress() * 3.6) : previousDegree; } else { degree = Integer.parseInt(degreeStr); } if (degree > 360 || degree < 0) { degreeText.setText(getResources().getString(R.string.zero)); seekArc.setProgress(0); toastInvalidValueMessage(); } else { seekArc.setProgress((int) (degree / 3.6)); editEnter = true; } }
-
Refactor Each Listener
Then update each
OnEditorActionListener
to call this method:degreeText1.setOnEditorActionListener(new TextView.OnEditorActionListener() { @Override public boolean onEditorAction(TextView v, int actionId, KeyEvent event) { removeStatusBar(); if (actionId == EditorInfo.IME_ACTION_DONE) { processDegreeInput(degreeText1, seekArc1); } return false; } });
Repeat similarly for
degreeText2
,degreeText3
, anddegreeText4
, passing the corresponding seek arc.
These steps reduce duplicate code while preserving existing functionality.
Build successful. APKs to test: https://github.com/fossasia/pslab-android/actions/runs/13923868879/artifacts/2772511544 |
2c464c1
to
445cf8c
Compare
Crash Fix
The Robotic Arm screen was crashing due to a java.lang.NumberFormatException when the EditText view was empty and the "Done" button was pressed
Exception
java.lang.NumberFormatException: For input string: ""
at java.lang.Integer.parseInt(Integer.java:807)
at java.lang.Integer.valueOf(Integer.java:1128)
at io.pslab.activity.RoboticArmActivity$15.onEditorAction(RoboticArmActivity.java:436)
at android.widget.TextView.onEditorAction(TextView.java:7967)
Changes
Added validation to check if the EditText is empty before parsing the value.
If the input is empty, the previous valid value is restored.
Screenshots / Recordings
Before
Robotic_Arm_Before.webm
After
Robotic_Arm_After.webm
Checklist:
strings.xml
,dimens.xml
andcolors.xml
without hard coding any value.strings.xml
,dimens.xml
orcolors.xml
.Summary by Sourcery
Bug Fixes: