4 comments

  • shoo 1 hour ago
    If I follow, this isn't a compile time inline directive, it's a `go fix` time source transformation of client code calling the annotated function.

    Per the post, it sounds like this is most effective in closed-ecosystem internal monorepo-like contexts where an organisation has control over every instance of client code & can `go fix` all of the call sites to completely eradicate all usage of a deprecated APIs:

    > For many years now, our Google colleagues on the teams supporting Java, Kotlin, and C++ have been using source-level inliner tools like this. To date, these tools have eliminated millions of calls to deprecated functions in Google’s code base. Users simply add the directives, and wait. During the night, robots quietly prepare, test, and submit batches of code changes across a monorepo of billions of lines of code. If all goes well, by the morning the old code is no longer in use and can be safely deleted. Go’s inliner is a relative newcomer, but it has already been used to prepare more than 18,000 changelists to Google’s monorepo.

    It could still have some incremental benefit for public APIs where client code is not under centralised control, but would not allow deprecated APIs to be removed without breakage.

    • avabuildsdata 8 minutes ago
      yeah this is the part that got me excited honestly. we're not google-scale by any stretch but we have ~8 internal Go modules and deprecating old helper functions is always this awkward dance of "please update your imports" in slack for weeks. even if it doesn't let you delete the function immediately for external consumers, having the tooling nudge internal callers toward the replacement automatically is huge. way better than grep + manual PRs
  • tapirl 1 hour ago
    It looks the following code will be rewritten badly, but no ways to avoid it? If this is true, maybe the blog article should mention this.

        package main
        
        //go:fix inline
        func handle() {
            recover()
        }
        
        func foo() {
            handle()
        }
        
        func main() {
            defer foo()
            panic("bye")
        }
    • tapirl 6 minutes ago
      Another example (fixable):

          package main
      
          import "unsafe"
      
          //go:fix inline
          func foo[T any]() {
              var t T
              _ = 1 / unsafe.Sizeof(t)
          }
      
          func main() {
              foo[struct{}]()
          }
      
      Go is a language full of details: https://go101.org/details-and-tips/101.html
    • shoo 46 minutes ago
      Great example, illustrating go1.26.1 go fix source inline transformation breaking program semantics. Raise it as a bug against go fix?
      • tapirl 17 minutes ago
        As I have mentioned, no ways to fix it. Because it is hard to know whether or not the handle function is called in a deferred call.
    • arccy 52 minutes ago
      Or: your buggy code is no longer buggy.
      • tapirl 14 minutes ago
        You claim listens right for this specified example. :D

        It is just a demo.

  • omoikane 31 minutes ago
    I wonder why they chose to add these directives as comments as opposed to adding new syntax for them. It feels like a kludge.

    https://wiki.c2.com/?HotComments

    • kjksf 14 minutes ago
      Go designers distinguish between Go language as defined by Go spec and implementation details.

      //go:fix is something understood by a particular implementation of Go. Another implementation could implement Go without implementing support for //go:fix and it would be a fully compliant implementation of Go, the language.

      If they made it part of the syntax, that would require other implementations to implement it.

      • dwattttt 4 minutes ago
        If the comments impact correctness (which inlining doesn't, but I believe there are other directives that do), saying it's "an implementation detail" waves away "it's an implementation detail that everyone needs" aka part of the spec.

        The reason it feels like a kludge is that "comments" are normally understood to be non-impactful. Is a source transformation that removes all comments valid? If comments have no impact per the spec, yes. But that's not the case here.

        In practice comments in go are defined to be able to carry semantic meaning extensibly. Whether they're safe to ignore depends on what meaning is given to the directives, e.g. conditional compilation directives.

      • bheadmaster 11 minutes ago
        That's such an elegant solution.

        I keep being impressed at subtle but meaningful things that Go does right.

    • 0x696C6961 25 minutes ago
      The //go:xyz comments are an established pattern in the Go tooling.
      • Mond_ 11 minutes ago
        This is begging the question. Yes, but why did they do that over dedicated syntax?

        (My personal theory is that early go had a somewhat misguided idea of simplicity, and preferred overloading existing concepts with special cases over introducing new keywords. Capitalization for visibility is another example of that.)

        • thwarted 4 minutes ago
          //go:xyz is dedicated syntax that is compatible with both the language spec and other toolchains that don't know about it.
  • measurablefunc 1 hour ago