meson.build 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. softmmu_ss.add(pixman)
  2. specific_ss.add(when: ['CONFIG_SOFTMMU'], if_true: pixman) # for the include path
  3. softmmu_ss.add(files(
  4. 'clipboard.c',
  5. 'console.c',
  6. 'cursor.c',
  7. 'input-keymap.c',
  8. 'input-legacy.c',
  9. 'input-barrier.c',
  10. 'input.c',
  11. 'kbd-state.c',
  12. 'keymaps.c',
  13. 'qemu-pixman.c',
  14. 'util.c',
  15. ))
  16. softmmu_ss.add([spice_headers, files('spice-module.c')])
  17. softmmu_ss.add(when: spice_protocol, if_true: files('vdagent.c'))
  18. softmmu_ss.add(when: 'CONFIG_LINUX', if_true: files(
  19. 'input-linux.c',
  20. 'udmabuf.c',
  21. ))
  22. softmmu_ss.add(when: cocoa, if_true: files('cocoa.m'))
  23. vnc_ss = ss.source_set()
  24. vnc_ss.add(files(
  25. 'vnc.c',
  26. 'vnc-enc-zlib.c',
  27. 'vnc-enc-hextile.c',
  28. 'vnc-enc-tight.c',
  29. 'vnc-palette.c',
  30. 'vnc-enc-zrle.c',
  31. 'vnc-auth-vencrypt.c',
  32. 'vnc-ws.c',
  33. 'vnc-jobs.c',
  34. 'vnc-clipboard.c',
  35. ))
  36. vnc_ss.add(zlib, png, jpeg, gnutls)
  37. vnc_ss.add(when: sasl, if_true: files('vnc-auth-sasl.c'))
  38. softmmu_ss.add_all(when: vnc, if_true: vnc_ss)
  39. softmmu_ss.add(when: vnc, if_false: files('vnc-stubs.c'))
  40. specific_ss.add(when: ['CONFIG_SOFTMMU'], if_true: opengl)
  41. ui_modules = {}
  42. if curses.found()
  43. curses_ss = ss.source_set()
  44. curses_ss.add(when: [curses, iconv], if_true: [files('curses.c'), pixman])
  45. ui_modules += {'curses' : curses_ss}
  46. endif
  47. if config_host.has_key('CONFIG_OPENGL')
  48. opengl_ss = ss.source_set()
  49. opengl_ss.add(gbm)
  50. opengl_ss.add(when: [opengl, pixman, 'CONFIG_OPENGL'],
  51. if_true: files('shader.c', 'console-gl.c', 'egl-helpers.c', 'egl-context.c'))
  52. ui_modules += {'opengl' : opengl_ss}
  53. endif
  54. if config_host.has_key('CONFIG_OPENGL') and gbm.found()
  55. egl_headless_ss = ss.source_set()
  56. egl_headless_ss.add(when: [opengl, gbm, pixman, 'CONFIG_OPENGL'],
  57. if_true: files('egl-headless.c'))
  58. ui_modules += {'egl-headless' : egl_headless_ss}
  59. endif
  60. if dbus_display
  61. dbus_ss = ss.source_set()
  62. dbus_display1 = custom_target('dbus-display gdbus-codegen',
  63. output: ['dbus-display1.h', 'dbus-display1.c'],
  64. input: files('dbus-display1.xml'),
  65. command: [config_host['GDBUS_CODEGEN'],
  66. '@INPUT@',
  67. '--glib-min-required', '2.64',
  68. '--output-directory', meson.current_build_dir(),
  69. '--interface-prefix', 'org.qemu.',
  70. '--c-namespace', 'QemuDBus',
  71. '--generate-c-code', '@BASENAME@'])
  72. dbus_ss.add(when: [gio, pixman, opengl, 'CONFIG_GIO'],
  73. if_true: [files(
  74. 'dbus-console.c',
  75. 'dbus-error.c',
  76. 'dbus-listener.c',
  77. 'dbus.c',
  78. ), dbus_display1])
  79. ui_modules += {'dbus' : dbus_ss}
  80. endif
  81. if gtk.found()
  82. softmmu_ss.add(when: 'CONFIG_WIN32', if_true: files('win32-kbd-hook.c'))
  83. gtk_ss = ss.source_set()
  84. gtk_ss.add(gtk, vte, pixman, files('gtk.c', 'gtk-clipboard.c'))
  85. gtk_ss.add(when: x11, if_true: files('x_keymap.c'))
  86. gtk_ss.add(when: [opengl, 'CONFIG_OPENGL'], if_true: files('gtk-gl-area.c'))
  87. gtk_ss.add(when: [x11, opengl, 'CONFIG_OPENGL'], if_true: files('gtk-egl.c'))
  88. ui_modules += {'gtk' : gtk_ss}
  89. endif
  90. if sdl.found()
  91. softmmu_ss.add(when: 'CONFIG_WIN32', if_true: files('win32-kbd-hook.c'))
  92. sdl_ss = ss.source_set()
  93. sdl_ss.add(sdl, sdl_image, pixman, glib, files(
  94. 'sdl2-2d.c',
  95. 'sdl2-input.c',
  96. 'sdl2.c',
  97. ))
  98. sdl_ss.add(when: [opengl, 'CONFIG_OPENGL'], if_true: files('sdl2-gl.c'))
  99. sdl_ss.add(when: x11, if_true: files('x_keymap.c'))
  100. ui_modules += {'sdl' : sdl_ss}
  101. endif
  102. if spice.found()
  103. spice_core_ss = ss.source_set()
  104. spice_core_ss.add(spice, pixman, files(
  105. 'spice-core.c',
  106. 'spice-input.c',
  107. 'spice-display.c'
  108. ))
  109. ui_modules += {'spice-core' : spice_core_ss}
  110. endif
  111. if spice.found() and config_host.has_key('CONFIG_GIO')
  112. spice_ss = ss.source_set()
  113. spice_ss.add(spice, gio, pixman, files('spice-app.c'))
  114. ui_modules += {'spice-app': spice_ss}
  115. endif
  116. keymaps = [
  117. ['atset1', 'qcode'],
  118. ['linux', 'qcode'],
  119. ['qcode', 'atset1'],
  120. ['qcode', 'atset2'],
  121. ['qcode', 'atset3'],
  122. ['qcode', 'linux'],
  123. ['qcode', 'qnum'],
  124. ['qcode', 'sun'],
  125. ['qnum', 'qcode'],
  126. ['usb', 'qcode'],
  127. ['win32', 'qcode'],
  128. ['x11', 'qcode'],
  129. ['xorgevdev', 'qcode'],
  130. ['xorgkbd', 'qcode'],
  131. ['xorgxquartz', 'qcode'],
  132. ['xorgxwin', 'qcode'],
  133. ['osx', 'qcode'],
  134. ]
  135. if have_system or xkbcommon.found()
  136. foreach e : keymaps
  137. output = 'input-keymap-@0@-to-@1@.c.inc'.format(e[0], e[1])
  138. genh += custom_target(output,
  139. output: output,
  140. capture: true,
  141. input: files('keycodemapdb/data/keymaps.csv'),
  142. command: [python, files('keycodemapdb/tools/keymap-gen'),
  143. 'code-map',
  144. '--lang', 'glib2',
  145. '--varname', 'qemu_input_map_@0@_to_@1@'.format(e[0], e[1]),
  146. '@INPUT0@', e[0], e[1]])
  147. endforeach
  148. endif
  149. subdir('shader')
  150. if have_system
  151. subdir('icons')
  152. install_data('qemu.desktop', install_dir: qemu_desktopdir)
  153. endif
  154. modules += {'ui': ui_modules}