Michal Privoznik ac7f3667f2 meson: Work around configure_file(copy:true) deprecation
In our meson scripts, we use configure_file(copy:true) to copy
files from srcdir into builddir. However, as of meson-0.64.0,
this is deprecated [1] in favor of using:

  fs = import('fs')
  fs.copyfile(in, out)

Except, the submodule's new method wasn't introduced until
0.64.0. And since we can't bump the minimal meson version we
require, we have to work with both: new and old versions.

Now, the fun part: fs.copyfile() is not a drop in replacement as
it returns different type (a custom_target object). This is
incompatible with places where we store the configure_file()
retval in a variable to process it further.

While we could just replace 'copy:true' with a dummy
'configuration:...' (say 'configuration: configmake_conf') we
can't do that for binary files (like src/fonts/ or src/images/).

Therefore, places where we are not interested in the retval can
be switched to fs.copyfile() and places where we are interested
in the retval will just use a dummy 'configuration:'.

Except, src/network/meson.build. In here we not just copy the
file but also specify alternative install dir and that's not
something that fs.copyfile() can handle. Yet, using 'copy: true'
is viewed wrong [2].

1: https://mesonbuild.com/Release-notes-for-0-64-0.html#fscopyfile-to-replace-configure_filecopy-true
2: https://github.com/mesonbuild/meson/pull/10042

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
2023-04-20 15:30:18 +02:00
..

Libvirt Logo README

The master SVG files were created in InkScape, using the Overpass font from Red Hat:

https://overpassfont.org/

Logo formats

The following SVG files are provided, along with standard bitmap sizes in PNG format:

logo-base.svg

image

The basic "sardine tin" graphic used to create the other forms of the libvirt logo.

The tin is rotated by 20 degrees, so its angle matches the angle of the left side of the letter "v" in the Overpass font

Never use this logo file directly. It exists merely as a base for building the other logos

logo-square.svg

image

The minimal square format logo for libvirt. Simply embeds the word "libvirt" into the basic logo graphic.

This is intended for use where a compact, square format representation of the logo is required.

Bitmap sizes: 96, 128, 192, 256 px square

  • 96px:

image

  • 128px:

image

  • 192px:

image

  • 256px:

image

logo-square-powered.svg

image

A variant of the square logo for use by 3rd party applications, to advertise their use of libvirt.

Bitmap sizes: 96, 128, 192, 256 px square

  • 96px:

image

  • 128px:

image

  • 192px:

image

  • 256px:

image

logo-banner-light.svg

image

A wide banner format of the logo. Embeds the words "libvirt virtualization API" into the basic logo graphic. The text is rendered in a light color, so suitable for placement over a dark background.

Bitmap sizes: 256x92, 800x286 px

  • 256x92px:

image

  • 800x286px:

image

logo-banner-dark.svg

image

A wide banner format of the logo. Embeds the words "libvirt virtualization API" into the basic logo graphic. The text is rendered in a dark color, so suitable for placement over a light background.

Bitmap sizes: 256x92, 800x286 px

  • 256x92px:

image

  • 800x286px:

image

logo-sticker-square.svg

image

A logo formatted into a square shape with outline, suitable for printing as a sticker. See https://github.com/terinjokes/StickerConstructorSpec

logo-sticker-hexagon.svg

image

A logo formatted into a hexagon shape with outline, suitable for printing as a sticker. See https://github.com/terinjokes/StickerConstructorSpec

PNG file creation

The bitmap images should not be created in Inkscape, since its anti-aliasing of the rendered bitmaps is too aggressive, resulting in fuzzy images. Instead the GIMP is used to create bitmaps as follows:

  • File -> Open, select the SVG file

    When prompted for the image size, enter 1024 as the width and allow height to be auto-set based on aspect ratio

  • Image -> Scale Image

    Enter desired final bitmap size and use "Cubic" as scaling method.

  • File -> Export As

It is important to let GIMP render initially at 1024 and then scale down, rather than rendering directly at the target size, since this the manual scaling step produces better quality