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

idea: postfix pointer-dereference operator #10011

Closed
1fish2 opened this issue Oct 22, 2013 · 5 comments
Closed

idea: postfix pointer-dereference operator #10011

1fish2 opened this issue Oct 22, 2013 · 5 comments

Comments

@1fish2
Copy link

1fish2 commented Oct 22, 2013

This is something of a wild idea: Use a postfix operator to dereference a pointer (as in Pascal) for fewer mistakes:

(*rect).area() becomes rect~.area()

That reads left-to-right with nary a precedence mistake.

Although Rust’s auto-dereference feature and type checker will sometimes catch the mistaken *rect.area(), it's good to just fix the failure mode. (All security holes in the field got past the type checker and the unit tests.)

The disadvantages are (1) the changeover work, and (2) being different than C/C++. C defined it that way to reuse the expression parser to help fit the compiler on a 16-bit CPU.

David Piepgrass points out that if pointer dereference were a suffix operator, it would have to be changed from * to (e.g.) ~. Why? Because if foo* means "dereference foo" then it becomes ambiguous whether foo * - bar means (foo*)-bar "dereference foo and subtract bar" or foo*(-bar) "multiply foo by negated bar". Due to this ambiguity, it is difficult for a language to simultaneously have

  1. Operators that can be prefix or infix, and
  2. Operators that can be infix or suffix.

To avoid the ambiguity, one can introduce an operator like ~ that is prefix or suffix but never infix.

@Thiez
Copy link
Contributor

Thiez commented Oct 22, 2013

(All security holes in the field got past the type checker and the unit tests.)

I am interested, could you elaborate on this?

@1fish2
Copy link
Author

1fish2 commented Oct 22, 2013

Rich Hickey points out in http://www.infoq.com/presentations/Simple-Made-Easy that all bugs in shipped software got past the type checker and the unit tests. Automatic array bounds checks and other run-time checks limit the damage of some additional problems.

Security holes are bugs that are exploitable. They could come about due to memory safety problems, trusting externally-supplied data, numeric overflow, underlying OS and network flaws, etc.

Something I learned in an IEEE Reliability Society talk is the path to reliability is eliminating as many failure modes as possible. Their example was automotive: Rather than diddle with the probability of A/C hoses rusting out, just use a material that doesn't corrode.

@Aatch
Copy link
Contributor

Aatch commented Nov 5, 2013

I'd like to see a Rust example where this is actually a possibility. Between autoderef and the type checker, I'm not sure if it's possible to introduce an actual bug. I mean, sure, there probably is some case, but I can't think of one that is caused purely by operator precedence mistakes.

If you do *foo.abc() you are dereferencing the result of caling the abc method. If that type is not a pointer, then you'll get an error. If it is a pointer, then it should either be safe to dereference, a raw pointer (and therefore in an unsafe block), or a compile time error. The same ideas apply to (*foo).abc() except that code would only make sense if foo was a raw pointer, making the dereference itself unsafe.

I'm closing this as unproductive, with no obvious advantage beyond "don't have to worry about operator precedence in this one case where it probably doesn't matter anyway", I can't see this happening. If you can provide a compelling example, this issue can be re-opened.

@Aatch Aatch closed this as completed Nov 5, 2013
@1fish2
Copy link
Author

1fish2 commented Nov 5, 2013

Fair enough.

[(*foo).abc() and (*foo).abc also work for unique, borrowed, and managed pointers, right?]

I don't have a compelling example, and consistent use of autoderef avoids the problem. Maybe if state points to an FSM state and (*state).next(token) returns the next FSM state pointer given an input token, then *state.next(token) === *(state.next(token)) gets the next state (not state pointer)... The type checker will catch that. With type inference the error message might be downstream but hopefully it'll still be a clear enough message.

"Closed" is fine. Sorry for the digression.

@huonw
Copy link
Member

huonw commented Nov 5, 2013

[(*foo).abc() and (*foo).abc also work for unique, borrowed, and managed pointers, right?]

Yes

Jarcho pushed a commit to Jarcho/rust that referenced this issue Feb 26, 2023
…dnet

Fix test function checker in `unwrap_used`, `expect_used`

After rust-lang#9686 , `unwrap` and `expect` in integration tests and raw test functions won't be allowed.

fixes rust-lang#10011
fixes rust-lang#10238
fixes rust-lang#10264

---

changelog: Fix: [`expect_used`], [`unwrap_used`], [`dbg_macro`], [`print_stdout`], [`print_stderr`]: No longer lint in test functions, if the related configuration is set
[rust-lang#10391](rust-lang/rust-clippy#10391)
<!-- changelog_checked -->
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

No branches or pull requests

4 participants