Skip to content

Latest commit

 

History

History
194 lines (170 loc) · 11.3 KB

CONTRIBUTING.md

File metadata and controls

194 lines (170 loc) · 11.3 KB

Contributing to this fork of Harbour

Table of Content

  1. How to Donate
  2. How to Share
  3. How to Get Involved
  4. Troubleshooting

How to Donate

You can donate to support the effort that goes into responding to issues.

How to Share

Share by linking to this project from your forum, blog or Twitter. Link to commits, issues or source files, or whatever else you find worthy to pass to someone. This is the easiest, most useful and self-updating way of referring to this project. It's also the best form of crediting and appreciating this work without donating or participating directly.

Examples:

How to Get Involved

Troubleshooting

Evaluate these points before reporting an issue:

  1. Make sure to have carefully read this document.

  2. Make sure to do a make clean before doing a build after refreshing the sources.

  3. If that still fails, make sure to install fresh source tree in a new local directory and start over. See How to Get for instructions to get the source. In case you installed Harbour into system locations (this used to be the case with some *nix users, albeit mostly completely unnecessarily or wrongly - f.e. for unstable versions), you will need to remember cleaning off Harbour from all of these locations, too. Hint: Never install unstable Harbour versions to system locations.

  4. If you are doing a cross-build, make sure to have rebuilt the native Harbour executables for your host platform. See HB_HOST_BIN build messages to find their location.

  5. Keep your PATH clean from old, mixed compiler tools or other Harbour versions when building Harbour. The surest way to achieve this is to leave only the C compiler directory in PATH:

    set PATH=C:\<c-compiler-bin-dir>
    

    If you use Harbour official binary distro on Windows, even above is unnecessary and should be avoided.

  6. Remove all old, unnecessary environment variables (for both Harbour and C compiler) from your environment. Also remove any custom settings for your C compiler. Use only those documented in this file.

  7. Remove any Harbour build settings documented in Build Options.

  8. Do no or only minor modifications at once to the examples included in Build Examples. If it doesn't work, fall back to documented examples as is.

  9. If everything fails and you are to report a build problem to Harbour developers, make sure to include your OS version/language/CPU architecture, Harbour revision, C compiler name/release and version, environment variables and verbose log output containing both STDERR and STDOUT in one combined stream (use make > log.txt 2>&1). Enable verbose mode using HB_BUILD_VERBOSE=yes and do not enable multi-threaded (parallel) build. Configure your tools to output English language messages using HB_LANG=en and LANG=en_GB.UTF-8. Complete log output is rarely necessary, but make sure to include the top of the output (lines starting with !) and the area where problematic behavior occurred first. Make sure to not only include a link failure or a make tool failure, as it's most often not enough information. Compress your log using zip if it is larger than 25 kB (use the extension .zip). With these, you have much better chance to get useful or any response.

  10. Do not alter the directory layout and files in Harbour and 3rd party packages and tools (including C compilers).

  11. If you are to report a build problem with a Harbour application, all the above points apply, plus make sure to use hbmk2 with the -trace command-line option and redirect its output to a file (see above how). Also include your full command-line and any referenced build script in your report. It is good idea to first remove all manual references to Harbour core components from make-files and custom environment. F.e. it's common mistake to add C compiler header and/or lib dirs, Harbour core header and/or lib dirs, built-in constants to make-files or environment. No such thing is necessary as all of these are automatically handled by hbmk2. In other words: start simple and don't be over-busy with fine-tuning your configuration. If you need to, the problem is most probably elsewhere. It's also good idea to try with the latest Harbour revision or Harbour's mainline branch first.

  12. If you are to report a problem with Harbour itself, provide self-contained, minimal source code example. Do not use xhb contrib library (including hbcompat.ch), nor any 3rd party Harbour libraries. The example shall reproduce the problem using the latest Harbour revision (with no local commits or pending local modifications) at the time of the report. Do not post links to executables and other binary files. If your source contains non-ASCII and non-UTF-8 national, accented, special chars, make sure to mark the codepage/encoding used and use Chr()/hb_BCode() calls to form the strings. Use UTF-8 if possible. Notice that code examples are likely to be executed as hbrun scripts for testing, so it's a good idea to make them work this way.
    Also make sure not to report multiple issues under a single GitHub Issue.

  13. Please do not report warnings or bugs — except build errors — in 3rd party components hosted inside the Harbour source tree. You can recognize these by their source path, which always contain a subdirectory named /3rd/. Report these directly to the maintainer of the respective component instead.

  14. If your example or report contains human readable text, use English only.

  15. If your example involves compatibility components, make sure to test it against original implementation (e.g. legacy Cl*pper core language elements against real CA-Cl*pper 5.2e or 5.3b, or hbct functions against CT3 library, etc.) Notice that Harbour is Cl*pper Summer '87 compatible exactly as much as Cl*pper 5.2e/5.3b is, meaning: almost, but not completely. For tests with Cl*pper, use this free, open-source MS-DOS emulator (requires Windows/Wine).


This document Copyright © 2009–present Viktor Szakats (vszakats.net/harbour)
Creative Commons Attribution-ShareAlike 4.0