-
-
Notifications
You must be signed in to change notification settings - Fork 89
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
vala: Port Vala to Meson #969
base: main
Are you sure you want to change the base?
Conversation
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.
Thanks for working on this!
One thing to keep in mind is we need to keep compiling existing Vala project so please make sure that's working
I will let @lw64 do the first review
@sonnyp Existing sessions and all the demos work as expected. Projects don't, because meson won't accept the file paths given by a portal. I tested this with Rust/cargo and it happens too. A possible solution might be copying the Vala sources to a temporary folder that meson accepts (like the cache directory) and compile it there. The source files are usually small so it shouldn't be expensive. What do you think? |
why not? |
Same as #846 unfortunately :( |
I see
Sounds interesting, perhaps we can solve #846 the same way if it turns out to be a good idea. I'm also interested to avoid having a Wanna give it a try? |
I tested this and besides projects it seems to work great. I also merged main into your branch and fixed conflicts. |
I think it would be better too, since Meson's builddirs can break between major versions, and old projects may break as a consequence of this. I'll give it a try this week :) |
Initial work to port Vala to Meson
This function will allow to create temporary directory. This will allow, for instance, meson to create a builddir that will not be stored inside a session.
This allows to compile projects without granting access to the filesystem. Additionally, all sessions opened that compile Vala code will use the same build directory, allowing us to reuse the same meson configuration.
a4447eb
to
4696398
Compare
7bb18f8
to
fc77803
Compare
I think this PR is ready! A little summary of the changes:
Also updated the newer demos in workbenchdev/demos#187, tested locally and CI passed, so this is ready for review. |
const current_dir = Gio.File.new_for_path(GLib.get_current_dir()); | ||
|
||
const template_dir = GLib.getenv("FLATPAK_ID") | ||
? Gio.File.new_for_path( | ||
`/app/share/${GLib.getenv("FLATPAK_ID")}/langs/vala/template`, | ||
) | ||
: current_dir.resolve_relative_path("src/langs/vala/template"); | ||
|
||
const api_file = template_dir.get_child("workbench.vala"); | ||
api_file.copy( |
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.
const current_dir = Gio.File.new_for_path(GLib.get_current_dir()); | |
const template_dir = GLib.getenv("FLATPAK_ID") | |
? Gio.File.new_for_path( | |
`/app/share/${GLib.getenv("FLATPAK_ID")}/langs/vala/template`, | |
) | |
: current_dir.resolve_relative_path("src/langs/vala/template"); | |
const api_file = template_dir.get_child("workbench.vala"); | |
api_file.copy( | |
const template_dir = Gio.File.new_for_path(pkg.pkgdatadir).get_child("langs/vala/template"); | |
template_dir.get_child("workbench.vala").copy( |
|
||
// Takes a string starting with the line | ||
// #!/usr/bin/env -S vala workbench.vala --pkg gtk4 --pkg libadwaita-1 | ||
// and return ["--pkg", "gtk4", "--pkg", "libadwaita-1"] | ||
// FIXME: consider using https://docs.gtk.org/glib/struct.OptionContext.html instead | ||
function getValaCompilerArguments(text) { | ||
return text.split("\n")[0]?.split("-S vala ")[1]?.split(" ") || []; | ||
} |
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.
🎉
"--vapi", | ||
"/dev/null", | ||
...args, | ||
const meson_clean = meson_launcher.spawnv([ |
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.
why cleaning?
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.
When replacing the file in the build dir, meson will not detect any changes on the file, thus not compiling anything and just running the project right away. This is a problem when a user has two open projects and working on them simultaneously, so I went for cleaning the build files and recompiling. I thought this approach was OK since we don't really compile much.
import { createTmpDir, copy } from "../../util.js"; | ||
import { setupValaProject } from "./vala.js"; | ||
|
||
let ready_to_build = false; |
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.
I'm confused about why this is needed
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.
I did this to know if the Vala builddir was already setup (as it needs a meson file and the workbench API). This could be done checking if a build file (like workbench.vala
) exists, but I went for this instead as it is one less I/O operation.
dependency('libadwaita-1'), | ||
dependency('shumate-1.0'), | ||
dependency('libportal-gtk4'), | ||
dependency('libsoup-3.0'), | ||
dependency('webkitgtk-6.0'), | ||
dependency('gstreamer-1.0'), | ||
dependency('gtksourceview-5'), | ||
dependency('json-glib-1.0'), |
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.
dependency('libadwaita-1'), | |
dependency('shumate-1.0'), | |
dependency('libportal-gtk4'), | |
dependency('libsoup-3.0'), | |
dependency('webkitgtk-6.0'), | |
dependency('gstreamer-1.0'), | |
dependency('gtksourceview-5'), | |
dependency('json-glib-1.0'), | |
dependency('libadwaita-1'), | |
dependency('shumate-1.0'), | |
dependency('libportal-gtk4'), | |
dependency('libsoup-3.0'), | |
dependency('webkitgtk-6.0'), | |
dependency('gstreamer-1.0'), | |
dependency('gtksourceview-5'), | |
dependency('json-glib-1.0'), | |
dependency('libspelling-1'), |
// VLS needs the project to be already setup once it starts, | ||
// otherwise it won't pick it up later. | ||
setupValaProject(file.get_parent()).catch(console.error); |
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.
is it possible to move the meson and workbench.vala files under a subdir? to avoid cluttering the project
and we might need meson.build
for other purposes too
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.
Sure, I think this is possible. Would that subdir still be inside the project folder? Or do you mean saving just the main.vala
in the project directory and get rid of all of the build stuff? I'm guessing this last option is also possible.
|
||
const tmp_dirs = {}; | ||
|
||
export async function createTmpDir(filename) { |
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.
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.
Thanks, I'll check them out!
This PR ports Vala from scripts to Meson, and introduces a minimal Vala template with the Workbench API file and a meson build file.
Fixes #964
Fixes #913