Search Criteria
Package Details: plutolang 0.10.3-1
Package Actions
Git Clone URL: | https://aur.archlinux.org/plutolang.git (read-only, click to copy) |
---|---|
Package Base: | plutolang |
Description: | A superset of Lua 5.4 with a focus on general-purpose programming. |
Upstream URL: | https://github.com/PlutoLang/Pluto |
Licenses: | MIT |
Conflicts: | pluto |
Provides: | libpluto.so |
Submitter: | Sainan |
Maintainer: | Sainan |
Last Packager: | Sainan |
Votes: | 1 |
Popularity: | 0.000524 |
First Submitted: | 2023-12-20 04:50 (UTC) |
Last Updated: | 2024-12-02 06:03 (UTC) |
Dependencies (4)
- gcc-libs (gcc-libs-gitAUR, gccrs-libs-gitAUR, gcc11-libsAUR, gcc-libs-snapshotAUR)
- glibc (glibc-gitAUR, glibc-linux4AUR, glibc-eacAUR, glibc-eac-binAUR)
- readline (readline-gitAUR)
- git (git-gitAUR, git-glAUR) (make)
Latest Comments
1 2 Next › Last »
alerque commented on 2024-04-07 07:52 (UTC)
@Sainan Providing and depending on sonames adds tooling to the packages that automatically tracks the library versions and makes sure they are compatible with things that depend on them so the package manager knows if a package can be upgraded without breaking or when things need to be recompiled against a new library version.
It isn't a crime that you don't understand the ins and outs of Arch Linux packaging since you're not even an Arch user, but it is pretty rude to continually insist evenything is fine when folks are contributing things that make it better for a system they do understand.
Sainan commented on 2024-04-06 12:22 (UTC) (edited on 2024-04-06 12:40 (UTC) by Sainan)
Are you just making up problems at this point? From what I understand, 'provides' merely serves as an alias for the package name. It is perfectly possible to use libpluto.so by simply adding 'plutolang' to 'depends'.
alerque commented on 2024-04-06 12:13 (UTC)
Besides the previously discussed issues which remain unfixed (improper job handling, not passing distro CXXFLAGS, etc., the v0.9.0 release also has a new problem in that it does not provide the soname and also does not include the checksums for the Git commit (this is new it current pacman tooling, but it is evident this was not properly updated with
updpkgsums
) after bumping the version).For anybody that wants a cleaned up version that can also be compared with the VCS package, apply this patch with
git am < file.patch
(make sure it has a trailing blank line if you copy it from here):alerque commented on 2024-01-19 12:18 (UTC)
No it did not. We're 90% of the way to where I tried to get you to in the first place with a patch and some notes, you've just made me rehash half of the guidelines found in the wiki here to convince you. I saw you were new to Arch and evidently had no idea what needed to be in the package; but I did not insult you at all (as you have done to me repeatedly) and decided to help out rather than just criticize this as a broken package. I package hundreds of projects for official Arch Linux repos and hundreds more here in the AUR and am quite familiar with many packaging issues. Rather than accusing me of having "no discipline" maybe you should have taken a moment to search the wiki for the things I mentioned.
As I explained already, this is incorrect usage. Enabling parallel builds is the job of
makepkg.conf
(either at system or user level). It should not be used in a package to set a number of jobs because different hardware and sofware configurations will want a different maximum number of threads. You overriding the tooling settings with a forced unlimited threads is the PKGBUILD is not appropriate. The only time it should be used is for-j1
to turn off parallel builds for known-broken upstream projects with race conditions in their builds.Sainan commented on 2024-01-19 11:25 (UTC) (edited on 2024-01-19 11:26 (UTC) by Sainan)
Again, your initial fix was way too big, way too broad, and made some obviously-unacceptable changes. I do not mind contributions in general, but I do mind when it's coming from a place of no discipline.
Anyway, the reason for the
-j
flag is that the build should be parallelised to make it faster. This clearly does not seem to be the default when I usemakepkg
without specifying-j
explicitly. Furthermore, specifying the-j
flag does not seem to slow down the build when installing it viayay
.alerque commented on 2024-01-19 10:46 (UTC)
And you didn't believe me when I ⓐ sent you a fix and ⓑ specifically mentioned it was broken. Your response even after those two steps was "it absolutely works". This attitude of assuming contributors are just wrong until they argue and fight and explain in detail makes it kind of unfriendly to contribute towards your projects.
Thanks for fixing. If you take it one step farther like I did in plutolang-git by specifying the
depends=(readline libreadline.so)
then Arch will log with SO version the package is built against and warn the user before they try to install a different readline version rather than finding out it just crashes afterwards because of an SO version mismatch. Readline doesn't update frequently so this isn't a big deal, but if you want a really quality package the way that it would be in the official repos that's how you should record it.Yes. With that line a package manager will be able to provide people the correct error message if they ever try to install both packages.
This is part of making FULL_RELRO work for these (and other Lua project derived) binaries. Different distros and use cases will have different requirements as far as build flags go. What you prefer to set by default upstream as far as compiler security and features flags is up to you, but passing the distribution preferences in as a starting point and only overriding ones upstream that matter for some specific reason to the project is the best way to handle it. In this case Arch requires a number of security and feature flags, and for the most part
namcap
on the generated package will show when the generated binaries are not living up to the expectations. That doesn't necessarily mean those flags should be set upstream because different distros will have their own defaults and support for different features. Also their compiler versions will differ.Per the wiki the only reason to use
-j
in your build is to disable parallel execution for upstream projects where it is known broken. This is not the case for Lua or Pluto, both of which seem to build fine with parallel jobs. The place to set the jobs if you want to override the defaults is inmakepkg.conf
. Otherwise leave it alone by not using the flag at all and let other users makepkg defaults get used. In this case if there is something I'm missing and the Pluto build can cause a race condition then you should probably note that upstream and either fix it or force it to not be parallel.Sainan commented on 2024-01-19 01:05 (UTC)
Thanks for the hint about
readline
. I wasn't aware that the arrow keys were not working.The conflict thing seems like a bit of a nitpick, but I guess it's technically better for us to specify this.
Afaik, PIC only matters for shared objects. I also don't know what "expected properties" you mean. It's possible these should rather be put into Pluto's actual Makefile rather than try to bandaid it by passing these flags.
Also I'm not sure what you mean by
-j
not being needed, at least it does look likemakepkg
needs it.alerque commented on 2024-01-18 12:13 (UTC) (edited on 2024-01-18 19:23 (UTC) by alerque)
You can think it is "asinine" that a dependency required to build (but not run) a package and is not part of
base-devel
needs to be specifiedmakedepends
, but you don't make the rules. Even I as a packager building Arch Linux for official repos don't get to make up those rules. Personally I think it seems to make some sense the way it is, but if you want to suggest addinggit
as a dependency tobase-devel
that would change this situation, but at this point it isn't.Almost all Arch Linux machines will have readline installed (because it is a dependency for bash as well as many other commonly used packages like
util-linux
,sqlite
,rlwrap
, etc.). Notably it is also used by the official lua packages. However it ends up not being used by this package because thelinux
target explicitly does not link it, whilelinux-readline
does. Since almost everybody has the package already and all the official lua variants use it by default, it makes sense to use it here. Otherwise as it stands the REPL starts up but does not function as people might expect: notable arrow keys cannot be used to get back to previous lines of code and other editing bindings they might expect don't work.Also you've fixed a number of other issues I've mentioned, but a couple are still missing:
conflicts=(pluto)
line since there is a bin name clash between packages.-fPIC
. You can do this withMYCFLAGS="$CXXFLAGS -fPIC" MYLDFLAGS="$LDFLAGS" linux-readline
.-j
as it is setup by the Arch linux package builder configuration.Sainan commented on 2024-01-16 23:31 (UTC) (edited on 2024-01-16 23:34 (UTC) by Sainan)
It is a bit asinine that I can define the source to be a Git repo, but must then also declare that Git is a build dependency. Nevertheless, I shall "fix" it.
Also, the REPL absolutely works without readline if you use
make PLAT=linux
instead ofmake PLAT=linux-readline
.alerque commented on 2024-01-16 23:15 (UTC)
Unable to point out specific issues? Dude seriously, I wrote a patch full of specific issues. And the Wiki packaging guidelines detail reasoning for the majority of my changes there. Since you can't be bothered to read and apparently you think I'm making things up here are some cliff notes:
You say it isn't broken, but it only builds because you installed things on your host system that you didn't declare in the dependencies. That makes it broken.
As one example,
makedepends=(git)
is absolutely required for this package. The REPL interface also doesn't work correctly withoutdepends=(readline)
. Not packaging the license file for MIT licenses is incorrect. There are more things in my patch that correctly fix legitimate issues, some outright broken some just improvements that are valid in the Arch package landscape (like the conflicts declaration).If you still don't believe me run
namcap
on the package you generated frommakepkg
, it will point out 4 warnings and 3 errors, only one of which are even things that I mentioned above so far.1 2 Next › Last »