diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 74ff6544..b5f35519 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -1,6 +1,6 @@ name: build and test concurrency: - group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }} + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }}-build cancel-in-progress: true on: @@ -27,7 +27,7 @@ on: jobs: format-checks: uses: ./.github/workflows/format.yml - meson: + linux-amd64: strategy: fail-fast: false matrix: @@ -81,7 +81,7 @@ jobs: name: ubuntu-meson-logs path: | build/meson-logs/**/* - macos: + macos-arm64: runs-on: macos-14 timeout-minutes: 8 env: diff --git a/.github/workflows/docker-test.yml b/.github/workflows/docker-test.yml index 28244598..c5f32939 100644 --- a/.github/workflows/docker-test.yml +++ b/.github/workflows/docker-test.yml @@ -1,6 +1,6 @@ name: Test Build-Env Docker Image concurrency: - group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }} + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }}-docker-test cancel-in-progress: true on: diff --git a/.github/workflows/docker.yml b/.github/workflows/docker.yml index d18b3d0e..e2270da9 100644 --- a/.github/workflows/docker.yml +++ b/.github/workflows/docker.yml @@ -1,16 +1,15 @@ name: Build-Env Docker Image concurrency: - group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }} + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }}-docker cancel-in-progress: true on: - workflow_call: + workflow_dispatch: push: branches: master paths: - "**Dockerfile" - "**docker.yml" - workflow_dispatch: schedule: - cron: "25 1 5 * *" diff --git a/.github/workflows/format.yml b/.github/workflows/format.yml index c4d99eec..6ad21987 100644 --- a/.github/workflows/format.yml +++ b/.github/workflows/format.yml @@ -1,9 +1,13 @@ name: build and test concurrency: - group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }} + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }}-format cancel-in-progress: true on: workflow_call: jobs: + fake-job: + runs-on: ubuntu-latest + steps: + - run: exit 0 #Add here a task for each language to be supported. diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 7c3d8723..d023bcf6 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,6 +1,6 @@ name: Build-Env Docker Image concurrency: - group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }} + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }}-release cancel-in-progress: true on: @@ -9,15 +9,16 @@ on: tags: - "v*.*.*(-.*)?" branches: master - jobs: - build-checks: - uses: ./.github/workflows/build.yml - release: - needs: [build-checks] - name: release - runs-on: ubuntu-latest - if: ${{ startsWith(github.ref, 'refs/tags/v') }} - permissions: - contents: write - steps: - #TODO https://github.com/quickjs-ng/quickjs/blob/master/.github/workflows/release.yml or https://github.com/saghul/txiki.js/blob/master/.github/workflows/release.yml for reference? +jobs: + build-checks: + uses: ./.github/workflows/build.yml + release: + needs: [build-checks] + name: release + runs-on: ubuntu-latest + if: ${{ startsWith(github.ref, 'refs/tags/v') }} + permissions: + contents: write + steps: + - run: exit 0 + #TODO https://github.com/quickjs-ng/quickjs/blob/master/.github/workflows/release.yml or https://github.com/saghul/txiki.js/blob/master/.github/workflows/release.yml for reference? diff --git a/meson2.build b/meson2.build new file mode 100644 index 00000000..d4869c24 --- /dev/null +++ b/meson2.build @@ -0,0 +1,306 @@ +project( + 'vs-fltk', + ['c', 'cpp', 'swift'], + # + version: '0.1.1-alpha', + # + meson_version: '>= 1.1', + default_options: ['c_std=gnu23', 'cpp_std=gnu++23'], +) + +cc = meson.get_compiler('c') +cxx = meson.get_compiler('cpp') + +#Used by pugi to enable compact mode. I might want to disable execptions too. +add_global_arguments(['-DPUGIXML_COMPACT'], language: ['cpp', 'c']) + +meson.add_devenv( + { + 'VS_COMMONS_DIR': join_paths(meson.project_source_root(), 'build', 'commons'), + }, +) +meson.add_devenv({'VS_LOG_LEVEL': 'debug'}) +#TODO: Add a custom profile to devenv to avoid "polluting" or making user's one invalid. + +cmake = import('cmake') + +opt_fltk = cmake.subproject_options() +opt_fltk.add_cmake_defines( + { + 'FLTK_BUILD_FLUID': false, + 'FLTK_BUILD_EXAMPLES': false, + 'FLTK_BUILD_TEST': false, + 'FLTK_BUILD_OPTIONS': false, + 'FLTK_BUILD_SHARED_LIBS': true, + 'CMAKE_POSITION_INDEPENDENT_CODE': true, + }, +) + +if get_option('force_x11_backend') == true + opt_fltk.add_cmake_defines({'FLTK_BACKEND_X11': true}) +endif + +libfltk_proj = cmake.subproject('libfltk', options: opt_fltk) +libfltk_dep = libfltk_proj.dependency(['fltk-shared']) +libfltk_images_dep = libfltk_proj.dependency(['fltk-images-shared']) +libfltk_forms_dep = libfltk_proj.dependency(['fltk-forms-shared']) +#libfltk_gl_dep = libfltk_proj.dependency(['fltk-gl']) + +opt_wamr = cmake.subproject_options() +opt_wamr.add_cmake_defines( + { + 'WAMR_BUILD_INTERP': 1, + 'WAMR_BUILD_PLATFORM': 'linux', #TODO: Make it generic based on target arch + }, +) + +wamr_proj = cmake.subproject('wamr', options: opt_wamr) +wamr_dep = wamr_proj.dependency('wamr') + +opt_quickjs = cmake.subproject_options() +opt_quickjs.add_cmake_defines( + { + 'CMAKE_POSITION_INDEPENDENT_CODE': true, + }, +) + +quickjs_proj = cmake.subproject('quickjs', options: opt_quickjs) +quickjs_dep = quickjs_proj.dependency('qjs') + +md4c_proj = cmake.subproject('md4c') +md4c_dep = md4c_proj.dependency('md4c') + +opt_fmt = cmake.subproject_options() +opt_fmt.add_cmake_defines( + {'CMAKE_POSITION_INDEPENDENT_CODE': true, 'BUILD_SHARED_LIBS': false}, +) +fmt_proj = cmake.subproject('fmt', options: opt_fmt) +fmt_dep = fmt_proj.dependency('fmt') + +hashlib_proj = subproject('hashlib') +hashlib_dep = hashlib_proj.get_variable('hashlib_dep') + +json_proj = subproject('nlohmann_json') +json_dep = json_proj.get_variable('nlohmann_json_dep') + +pugixml_proj = subproject('pugixml') +pugixml_dep = pugixml_proj.get_variable('pugixml_dep') + +vs_templ_proj = subproject('vs-templ') +vs_templ_dep = vs_templ_proj.get_variable('vs_templ_dep') + +treesitter_proj = subproject('tree-sitter') +treesitter_dep = treesitter_proj.get_variable('tree_sitter_dep') + +libtcc_proj = subproject('libtcc') +libtcc_dep = libtcc_proj.get_variable('libtcc_dep') + +#uv_proj = subproject('libuv') +#uv_dep = uv_proj.get_variable('libuv_dep') + +mio_proj = cmake.subproject('mio') +mio_dep = mio_proj.dependency('mio') + +sqlitecpp_dep = dependency('sqlitecpp', required: false) +if not sqlitecpp_dep.found() + sqlitecpp_dep = cxx.find_library('SQLiteCpp', required: false) + if not sqlitecpp_dep.found() + sqlitecpp_dep = dependency( + 'sqlitecpp', + fallback: ['sqlitecpp', 'sqlitecpp_dep'], + default_options: 'default_library=static', + ) + endif +endif + +sqlite_dep = dependency( + 'sqlite3', + version: '>=3.0.0', + fallback: ['sqlite3', 'sqlite3_dep'], + default_options: 'default_library=static', +) + +#TODO handle the case in which libcurl does not exist. Missing is fine, just no https/http prefix for paths. +curl = dependency('libcurl', required: false) + +include_dirs = include_directories(['./include']) + +# Prepare `vs` + +vs_fltk_deps = [ + libfltk_dep, + libfltk_images_dep, + libfltk_forms_dep, + + pugixml_dep, + json_dep, + vs_templ_dep, + fmt_dep, + mio_dep, + #uv_dep, The one provided with the system if present should be fine for our tasks + hashlib_dep, + + libtcc_dep, + quickjs_dep, + sqlite_dep, + sqlitecpp_dep, + + md4c_dep, + treesitter_dep, +] + +vs_fltk_flags = ['-Wno-c23-extensions', '-Wno-vla-cxx-extension', '-Wno-unused-variable'] + +if curl.found() + vs_fltk_deps += [curl] + vs_fltk_flags += '-DHAS_CURL' +else +endif + +#vs_fltk_flags += '-DPUGIXML_COMPACT' + +subdir('./src/components') + +vs_fltk = shared_library( + 'vs-fltk', + [ + './src/cache/memory-storage.cpp', + './src/cache/kv-storage.cpp', + './src/cache/res-storage.cpp', + './src/cache/secrets.cpp', + + './src/utils/paths.cpp', + './src/utils/strings.cpp', + './src/utils/env.cpp', + './src/utils/policies.cpp', + './src/utils/policies.internal.cpp', + './src/utils/tcc-wrap.cpp', + + './src/fetcher.cpp', + + './src/loader.cpp', + + src_components, + autogen_components, + + './src/ui-frame.cpp', + './src/ui.cpp', + './src/ui-base.cpp', + + './src/xml2native.cpp', + + './src/ui-tree.cpp', + './src/ui-tree.xml.cpp', + './src/ui-tree.wasm.cpp', + './src/ui-tree.cnative.cpp', + './src/ui-tree.dylib.cpp', + + './src/ui-field.types.cpp', + + './src/pipelines/tcc-c.cpp', + './src/pipelines/tcc-cello.cpp', + './src/pipelines/quickjs-js.cpp', + './src/pipelines/wasm-wat.cpp', + './src/pipelines/lua-lua.cpp', + + './src/themes/default-cute.cpp', + + './src/cbindings/vs.cpp', + './src/cbindings/components.autogen.cpp', + + './src/globals.cpp', + ], + dependencies: vs_fltk_deps, + include_directories: include_dirs, + override_options: ['c_std=gnu23', 'cpp_std=gnu++23'], + cpp_args: vs_fltk_flags, + c_args: vs_fltk_flags, + install: true, +) + +vs_fltk_dep = declare_dependency( + include_directories: include_dirs, + link_with: vs_fltk, +) + +cello_project = subproject('cello') +cello_dep = cello_project.get_variable('cello_dep') + +shared_library('vs-cello', dependencies: [cello_dep]) + +#TODO add also a vs_codegen to introduce that step within meson instead of keeping it separate. +#I need to run it not from the builddir but from the root. +#vs_codegen_cmd = find_program('./scripts/codegen/index.ts') +#vs_codegen = custom_target(command: 'vs-codegen', output: 'vs-codegen', command: [vs_codegen_cmd], depends:[]) + +vs_commons_cmd = find_program('./scripts/gen-commons.sh') +vs_commons = custom_target( + 'vs-commons', + output: 'commons', + command: [vs_commons_cmd], + depends: [], + build_always_stale: true, +) + +executable( + 'vs', + [ + './src/app/main.cpp', + './src/app/settings.cpp', + './src/app/updater.cpp', + ], + dependencies: [vs_fltk_dep], + link_depends: [vs_commons], + override_options: ['c_std=gnuc23', 'cpp_std=gnu++23'], + install: true, + #install_rpath: '' +) + +executable( + 'swift_vs', + [ + './src/swift-app/app.swift', + ], + dependencies: [vs_fltk_dep], +) + +subdir(['./experiments/']) + +if get_option('tests') + subdir(['./test/']) + subdir(['./benchmark/']) +endif + +# Install stuff + +install_headers( + [ + './include/cbindings/vs.h', + './include/cbindings/components.autogen.h', + './include/cbindings/module.modulemap', + ], + preserve_path: false, + subdir: 'vs-fltk', +) + +install_subdir( + 'commons', + exclude_files: ['.gitignore'], + install_dir: 'share/vs-fltk', + strip_directory: true, +) +install_subdir('docs', install_dir: 'share/vs-fltk') +install_data( + ['./LICENCE.md', './README.md', './RELEASE.md'], + install_dir: 'share/vs-fltk/', +) + +#install_man() + +pconf = import('pkgconfig') +pconf.generate( + vs_fltk, + description: 'VS fltk library (C interface only)', + url: 'https://github.com/KaruroChori/vs-fltk/', + version: meson.project_version(), +) \ No newline at end of file