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

Build Error : cannot define new methods on non-local type #391

Closed
aicynide opened this issue Sep 12, 2023 · 15 comments
Closed

Build Error : cannot define new methods on non-local type #391

aicynide opened this issue Sep 12, 2023 · 15 comments
Assignees
Labels
bug Something isn't working

Comments

@aicynide
Copy link

github.com/anacrolix/go-libutp
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:16:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:24:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:28:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:32:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:36:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/utp.go:29:12: cannot define new methods on non-local type *C.utp_context
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/utp.go:40:12: cannot define new methods on non-local type *C.utp_context
make: *** [Makefile:21: app] Error 1
Error: Process completed with exit code 2.

@varbhat
Copy link
Owner

varbhat commented Oct 13, 2023

Yes. This is the reason and major obstacle for this project. I will take a look into it

@nlevee
Copy link
Collaborator

nlevee commented Nov 3, 2023

Hi,
I made a PR to optimize docker image size that seem to fix this issue:

docker build -t "exatorrent" .
[+] Building 77.4s (25/25) FINISHED                                                                             docker:default
 => [internal] load build definition from Dockerfile                                                                      0.0s
 => => transferring dockerfile: 1.05kB                                                                                    0.0s
 => [internal] load .dockerignore                                                                                         0.0s
 => => transferring context: 119B                                                                                         0.0s
 => resolve image config for docker.io/docker/dockerfile:1                                                                0.8s
 => [auth] docker/dockerfile:pull token for registry-1.docker.io                                                          0.0s
 => CACHED docker-image://docker.io/docker/dockerfile:1@sha256:ac85f380a63b13dfcefa89046420e1781752bab202122f8f50032edf3  0.0s
 => [internal] load metadata for docker.io/library/node:18                                                                0.6s
 => [internal] load metadata for docker.io/library/golang:1.20-alpine                                                     0.7s
 => [auth] library/node:pull token for registry-1.docker.io                                                               0.0s
 => [auth] library/golang:pull token for registry-1.docker.io                                                             0.0s
 => [build-node 1/5] FROM docker.io/library/node:18@sha256:7ce8b205d15e30fd395e5fa4000bcdf595fcff3f434fe75822e54e82a5f5c  0.0s
 => [build-go 1/7] FROM docker.io/library/golang:1.20-alpine@sha256:cd83dbc874245451226392246bc3f08fbae9138e9fa387dab8e9  0.0s
 => [internal] load build context                                                                                         0.0s
 => => transferring context: 56.59kB                                                                                      0.0s
 => CACHED [build-node 2/5] WORKDIR /exa                                                                                  0.0s
 => [build-node 3/5] ADD internal/web /exa/internal/web                                                                   0.1s
 => CACHED [build-go 2/7] WORKDIR /exa                                                                                    0.0s
 => CACHED [build-go 3/7] COPY go.mod go.sum ./                                                                           0.0s
 => CACHED [build-go 4/7] RUN go mod download                                                                             0.0s
 => [build-go 5/7] COPY . ./                                                                                              0.1s
 => [build-node 4/5] ADD Makefile /exa/                                                                                   0.1s
 => [build-node 5/5] RUN make web                                                                                         5.7s
 => [build-go 6/7] COPY --from=build-node /exa/internal/web/build /exa/internal/web/build                                 0.1s
 => [build-go 7/7] RUN apk add --no-cache make gcc g++ &&     make app                                                   69.4s 
 => [stage-2 1/2] COPY --from=build-go --chown=1000:1000 /exa/build/exatorrent /exatorrent                                0.1s 
 => [stage-2 2/2] WORKDIR /exa                                                                                            0.0s 
 => exporting to image                                                                                                    0.1s 
 => => exporting layers                                                                                                   0.1s 
 => => writing image sha256:8cda5252d4d46920420c59f63d2572535a70e0d68d2f16bc02a099905028af88                              0.0s 
 => => naming to docker.io/library/exatorrent                                                                             0.0s

@nlevee
Copy link
Collaborator

nlevee commented Nov 6, 2023

Hi @aicynide,

If you want I made a fork here : https://github.com/nlevee/exatorrent compilation work as expected

@mckaygerhard
Copy link

mckaygerhard commented Nov 7, 2023

@nlevee @aicynide there is only one issue left . the user alisaing is not the xpected case.. this fail in my system: cos in fact that useer 1000 doe snot exits in my docker image

image

main...nlevee:exatorrent:feat/optimize-dockerfile#diff-dd2c0eb6ea5cfc6c4bd4eac30934e2d5746747af48fef6da689e85b752f39557R34

@nlevee
Copy link
Collaborator

nlevee commented Nov 7, 2023

Yes, I can fix it, but I'll hope this PR to pass before.

@varbhat can you merge ? Else I can continue on my fork.

@varbhat
Copy link
Owner

varbhat commented Nov 7, 2023

@nlevee,

I am glad that you are working on improving exatorrent.

But, two things.

  1. Use alpine as final image instead of scratch image. You get TLS certs managed in alpine image. In scratch, you need to copy TLS certs to the image which is not very good way compared to directly basing upon alpine images. Maybe we can look into using linuxcontainers.io images too but we can do this later.

  2. Have you tried updating the deps in go.mod and compiling then? I am facing issues compiling after updating deps in go.mod probably from anacrolix/torrent packages and deps (esp. sqlite). See it if possible

@nlevee
Copy link
Collaborator

nlevee commented Nov 7, 2023

  1. Ok, I change to alpine and add ca-certificates.
  2. No I don't try to update go.mod, the latest version of anacrolix/torrent drop compatibility with go 1.20. I have to update all deps. I'll try in another PR If it's ok for you and to keep this PR clean

@mckaygerhard I fix the image startup if you don't load a volume and do not change "-dir" param

@nlevee
Copy link
Collaborator

nlevee commented Nov 7, 2023

I fixed compilation on golang 1.21 with all libraries updated, you can check the PR #404

@varbhat
Copy link
Owner

varbhat commented Nov 8, 2023

@nlevee ,

Thank you very much. Can you make da81de4 as seperate PR?

@mckaygerhard
Copy link

mckaygerhard commented Nov 8, 2023

@nlevee .. i talked with @varbhat so you can work in this now, and @varbhat he made a PR in #404

@varbhat
Copy link
Owner

varbhat commented Nov 8, 2023

@nlevee ,

Once upon a time, we used to provide statically linked binaries for all three platforms (see https://github.com/varbhat/exatorrent/blob/15d4e8c73d5572dedd2c504ff33d2008d1caf5ba/.github/workflows/build.yml ). But, unfortunately i couldn't maintain the toolchain i used to build exatorrent for all three platforms, and that's why i only kept docker builds.

Can you please look into it if you have time? Only linux (amd64, arm64) is desirable right now. if you have time, you can also add build definitions for linux i386, arm32. use alpine image for building as musl makes static linking a breeze.

Thank you very much. I have also invited you as collaborator.

CC: @mckaygerhard

@mckaygerhard
Copy link

@nlevee you should still solve this issue

bvy example you requested specific permissions not only cited by me.. also cited here: awesome-selfhosted/awesome-selfhosted-data#143 (review)

@nlevee @aicynide there is only one issue left . the user alisaing is not the xpected case.. this fail in my system: cos in fact that useer 1000 doe snot exits in my docker image

image

main...nlevee:exatorrent:feat/optimize-dockerfile#diff-dd2c0eb6ea5cfc6c4bd4eac30934e2d5746747af48fef6da689e85b752f39557R34

@nlevee
Copy link
Collaborator

nlevee commented Nov 8, 2023

@nlevee ,

Once upon a time, we used to provide statically linked binaries for all three platforms (see https://github.com/varbhat/exatorrent/blob/15d4e8c73d5572dedd2c504ff33d2008d1caf5ba/.github/workflows/build.yml ). But, unfortunately i couldn't maintain the toolchain i used to build exatorrent for all three platforms, and that's why i only kept docker builds.

Can you please look into it if you have time? Only linux (amd64, arm64) is desirable right now. if you have time, you can also add build definitions for linux i386, arm32. use alpine image for building as musl makes static linking a breeze.

Thank you very much. I have also invited you as collaborator.

CC: @mckaygerhard

I'll take this one too yes.

Btw there's already an issue on this #377

@nlevee
Copy link
Collaborator

nlevee commented Nov 8, 2023

@nlevee you should still solve this issue

bvy example you requested specific permissions not only cited by me.. also cited here: awesome-selfhosted/awesome-selfhosted-data#143 (review)

@nlevee @aicynide there is only one issue left . the user alisaing is not the xpected case.. this fail in my system: cos in fact that useer 1000 doe snot exits in my docker image
image
main...nlevee:exatorrent:feat/optimize-dockerfile#diff-dd2c0eb6ea5cfc6c4bd4eac30934e2d5746747af48fef6da689e85b752f39557R34

This one was partly fixed in my previous PR. You can check if you want 😉

I'll make another PR to permit mounting volume

@nlevee
Copy link
Collaborator

nlevee commented Nov 10, 2023

@aicynide

github.com/anacrolix/go-libutp
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:16:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:24:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:28:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:32:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/callbacks.go:36:10: cannot define new methods on non-local type *C.utp_callback_arguments
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/utp.go:29:12: cannot define new methods on non-local type *C.utp_context
/github/home/go/pkg/mod/github.com/anacrolix/[email protected]/utp.go:40:12: cannot define new methods on non-local type *C.utp_context
make: *** [Makefile:21: app] Error 1
Error: Process completed with exit code 2.

You can know build locally with:

make web && make app

Or with docker:

make docker

@nlevee nlevee added the bug Something isn't working label Nov 10, 2023
@nlevee nlevee self-assigned this Nov 10, 2023
@nlevee nlevee closed this as completed Nov 13, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

4 participants