wxWidgets/docs
Vadim Zeitlin 46973762ba Explain how to build the tests
It may not be obvious how to build the tests, so add a section
explaining this to the existing file containing the instructions about
writing the tests and add a README to the tests directory itself to
increase chances that this file will be found -- hopefully anybody
interested in the tests will look at the README in the directory
containing them.
2021-11-12 14:21:41 +01:00
..
base Change documentation references from OS X to macOS (#1927) 2020-07-04 22:08:24 +02:00
contributing Explain how to build the tests 2021-11-12 14:21:41 +01:00
dfb
doxygen Define wxICON_IS_BITMAP when this is indeed the case 2021-10-25 13:40:18 +01:00
gtk Update configure --enable-debug[_flag] options description 2021-09-05 16:04:56 +02:00
ios Change documentation references from OS X to macOS (#1927) 2020-07-04 22:08:24 +02:00
motif Integrate X11 and Motif install instructions into doxygen 2018-10-03 19:42:32 +02:00
msw Fix appearance of "%" in wxMSW install instructions 2021-09-05 17:44:57 +02:00
osx Change documentation references from OS X to macOS (#1927) 2020-07-04 22:08:24 +02:00
publicity Update README and announcement for 3.1.5 2021-04-11 17:28:16 +02:00
qt Fixup the QT architecture markdown page 2021-05-21 02:48:05 +01:00
tech Use HTTPS with Trac links. 2017-07-04 13:15:14 -06:00
univ Remove setup0.h files 2021-01-31 19:02:56 +01:00
vms Remove all trailing spaces 2019-01-30 17:35:54 +01:00
wine Fix spelling mistakes found by codespell 2020-07-13 17:38:47 +02:00
x11 Fix doxygen section bugs 2021-05-21 02:26:24 +01:00
changes_30.txt Remove all trailing spaces 2019-01-30 17:35:54 +01:00
changes.txt Fix handling of single letter shares in UNC paths in wxFileName 2021-09-15 01:51:35 +01:00
gpl.txt Update GPL and LGPL license texts to the latest versions 2020-03-26 19:50:13 -04:00
index.htm Fix spelling mistakes found by codespell 2020-07-13 17:38:47 +02:00
lgpl.txt Update GPL and LGPL license texts to the latest versions 2020-03-26 19:50:13 -04:00
licence.txt Remove all trailing spaces 2019-01-30 17:35:54 +01:00
licendoc.txt Remove all trailing spaces 2019-01-30 17:35:54 +01:00
preamble.txt
readme.txt Use PCRE as built-in regex library 2021-07-24 19:17:59 +02:00
release.md Mention support for MSVS 2022 in the documentation 2021-08-26 00:04:28 +02:00
xserver.txt Remove all trailing spaces 2019-01-30 17:35:54 +01:00

wxWidgets 3.1.6 Release Notes
=============================

Welcome to the latest development release of wxWidgets, a free and open source
cross-platform C++ framework for writing advanced GUI applications using native
controls.

wxWidgets allows you to write native-looking GUI applications for all the major
desktop platforms and also helps with abstracting the differences in the non-GUI
aspects between them. It is free for the use in both open source and commercial
applications, comes with the full, easy to read and modify, source and extensive
documentation and a collection of more than a hundred examples. You can learn
more about wxWidgets at:

* https://www.wxwidgets.org/

Documentation is available online at:

* https://docs.wxwidgets.org/3.1.6/

wxWidgets sources and binaries for the selected platforms are available for
download from:

* https://www.wxwidgets.org/downloads/

or, for a more more permanent but less convenient to use link, from

* https://github.com/wxWidgets/wxWidgets/releases/tag/v3.1.6/

Please see https://docs.wxwidgets.org/3.1.6/overview_install.html for full
installation instructions.



Changes since 3.1.4
-------------------

In the nine months since the previous release, there have been more than 1600
commits from 70 unique contributors (40 with multiple contributions), so it is
impossible to summarize all the changes in this document without making it too
long, please see the fuller changelog at

https://raw.githubusercontent.com/wxWidgets/wxWidgets/v3.1.6/docs/changes.txt

for more details, but here are some of the most important changes:

- New wxWebRequest and related classes provide a simple way to use HTTPS and
  HTTP/2 from wxWidgets applications using native libraries or libcurl.
- Support EGL in wxGLCanvas and Wayland in wxMediaCtrl under Linux.
- Many appearance and other fixes for macOS 11.
- More improvements to wxGrid UI, API and performance.
- wxImage improvements: add alpha support in Paste() and clipboard support.
- API additions: wxPersistentComboBox, wxFileName::ResolveLink(),
  wxFileHistory::SetMenuPathStyle(), wxString::utf8_string(), wxEVT_FULLSCREEN.
- Improvements: wxConfig now supports 64-bit integers, wxLog uses millisecond
  resolution in timestamps, XRC files can be loaded from URLs.
- Yet more bug fixes, fixes for API inconsistencies and optimizations, notably
  in wxDataViewCtrl, wxListCtrl, wxPropertyGrid.

Notice that in spite of all the changes, this release remains almost completely
compatible with 3.1.4 at the API level, so upgrading to it if you're already
using wxWidgets 3 should be straightforward.


Changes since 3.0
-----------------

Compared to the stable 3.0.x series, this version brings too many
improvements and even more bug fixes to list them all, but here is the
maximally condensed summary:

- Build system improvements: support for new compilers (up to MSVS 2019, g++ 10)
  with an even simpler way of using wxWidgets from MSVS, with wxwidgets.props
  file, and OS versions as well as an entirely new CMake build system.
- Support for native dark mode under macOS 10.14 Mojave and later.
- New features: HTTPS and HTTP/2 support with wxWebRequest and friends;
  support for freezing rows/columns in wxGrid; mouse gesture events (GSoC 2017
  project); non-integer font sizes and arbitrary font weights in wxFont;
  fractional pen widths in wxGraphicsContext; arbitrary label windows in
  wxStaticBox; markup in wxDataViewCtrl items text; better support for high
  DPI monitors and per-monitor DPI and dynamic DPI changes support under MSW;
  support for ZIP 64 files; LZMA compression; much improved accessibility
  support under MSW; new Edge-based wxWebView implementation.
- New classes: wxActivityIndicator, wxAddRemoveCtrl, wxAppProgressIndicator,
  wxNativeWindow, wxPersistentComboBox, wxPowerResourceBlocker, wxSecretStore,
  wxTempFFile and many new features in the existing classes.
- Significant improvements to: wxBusyInfo, wxDataViewCtrl, wxDirDialog, wxGrid,
  wxNotificationMessage, wxSpinCtrl, wxStaticBox, wxStyledTextCtrl,
  wxUIActionSimulator.
- Latest versions of all bundled 3rd party libraries, including all the
  security fixed and support for WebKit 2 and GStreamer 1.7 under Unix.
- Revamped OpenGL support better suited to modern OpenGL (3.2+) and EGL support
  and better support for Wayland in wxGTK.
- Further C++11 and later support improvements, wxWidgets can be built using
  C++20 compilers.
- A lot of bug fixes, especially in wxGTK3 and wxOSX/Cocoa ports.
- New experimental wxQt port.



Platforms Supported
-------------------

This version of wxWidgets supports the following primary platforms:

* Windows XP, Vista, 7, 8 and 10 (32/64 bits).
* Most Unix variants using the GTK+ toolkit (version 2.6 or newer)
* macOS (10.10 or newer) using Cocoa (32/64 bits)

There is some support for the following platforms:

* Most Unix variants with X11
* Most Unix variants with Motif/Lesstif
* Most Unix variants with GTK+ 1.2
* Most Unix variants with Qt 5 or newer (experimental)

All C++ compilers in common use are supported.


Licence
-------

For licensing information, please see the files:

* docs/preamble.txt
* docs/licence.txt
* docs/licendoc.txt
* docs/gpl.txt
* docs/lgpl.txt
* docs/xserver.txt

Although this may seem complex, it is there to allow authors of proprietary,
commercial applications to use wxWidgets in addition to those writing GPL'ed
applications. In summary, the licence is LGPL plus a clause allowing
unrestricted distribution of application binaries. To answer a FAQ, you don't
have to distribute any source if you wish to write commercial applications using
wxWidgets.

However, if you distribute wxGTK, wxQt or wxMotif (with Lesstif) version of your
application, don't forget that it is linked against GTK+, Qt or Lesstif, which
are covered by LGPL *without* exception notice and so is bound by its
requirements.

If you use TIFF image handler, please see src/tiff/COPYRIGHT for libtiff licence
details.

If you use JPEG image handler, documentation for your program should contain
following sentence: "This software is based in part on the work of the
Independent JPEG Group". See src/jpeg/README for details.

If you use wxRegEx class, please see 3rdparty/pcre/LICENCE for PCRE licence
details.

If you use wxXML classes or XRC, see src/expat/COPYING for licence details.


Reporting Bugs
--------------

The wxWidgets bug tracker can be found here:

* https://trac.wxwidgets.org/newticket

Please use the search function of our Trac installation to find any possibly
relevant bugs before reporting new ones. Also please notice that often trying to
correct the bug yourself is the quickest way to fix it. Even if you fail to do
it, you may discover valuable information allowing us to fix it while doing it.
We also give much higher priority to bug reports with patches fixing the
problems so this ensures that your report will be addressed sooner.


Further Information
-------------------

If you are looking for community support, you can get it from

* Mailing Lists: https://www.wxwidgets.org/support/mailing-lists/
* Discussion Forums: https://forums.wxwidgets.org/
* #wxwidgets IRC Channel: https://www.wxwidgets.org/support/irc/
* Stack Overflow (tag your questions with "wxwidgets"):
  https://stackoverflow.com/questions/tagged/wxwidgets

Commercial support is also available, please see
https://www.wxwidgets.org/support/commercial/

Finally, keep in mind that wxWidgets is an open source project collaboratively
developed by its users and your contributions to it are always welcome!


Have fun!

The wxWidgets Team, April 2021