Skip to content

Latest commit

 

History

History
183 lines (140 loc) · 8.24 KB

changes.md

File metadata and controls

183 lines (140 loc) · 8.24 KB

Testing (Quintijn)

  • Before being able to test, Nils helped me setting up things -- Install Visual Studio Code 2019 (was already done with previous testing with Doug) -- Install Visual Studio Tools 2019 (in order to find a proper C++ compiler) -- Install innosetup (from jrsoftware.org) -- pip install pytest (for the testing) -- ?? -- working in a branch of the natlink-light branch

  • Configure a UserDirectory in ~.natlink

  • I was then able to, at last, to get the _sampleXX.py scripts to work

  • Note: natlink.playString seems to be better functioning than in earlier versions

Changes for programmers:

  • all qualified imports: prev: from natlinkutils import * now: from natlink.natlinkutils import *
  • natlink.playString obsolete, use sendkeys from dtactions: prev: import natlink natlink.playString('xxx') now: from dtactions.sendkeys import sendkeys as playString playString('xxx')

or: from dtactions.sendkeys import sendkeys as playString sendkeys('xxx')

Changes Quintijn:

  1. made specific grammars also recognised

  2. made traceback when exception in loader.run occurs

  3. exclude invalid directories from the loader sequence of directories

  4. trace after a trigger_load for new files, and load them too

configure: UserDirectory = C:\Users\Gebruiker.natlink\UserDirectory FollowDirectory = C:\Users\Gebruiker.natlink\FollowDirectory

In UserDirectory is _follow_master.py.

This file empties FollowDirectory and then writes: _sample_follow.py, which recognises "demo follow one".

With first test, _sample_follow will be recognised in the second round as new file.

In a second round, _sample_follow still rewrites _sample_follow, but this grammar file is loaded in the first round, because it was already in the list of files to be loaded. But is loads, because it has a newer date than at the start of the trigger_load process.

So in both cases, it seems to be safe to let for example vocola write its compiled grammar files to the VocolaUserDirectory, when it is place after the VocolaDirectory


import lines change:

natlinkmain.py is now called loader.py

The core modules are found by qualified import from natlink import ..., so: from natlink import natlinkutils from natlink import loader

Natlink

Natlink is a compatibility module for Dragon NaturallySpeaking (DNS/DPI) v13-v15 on Windows that allows the user to run Python scripts that interact with DNS. This fork does not include Dragonfly, Unimacro, or Vocolo. These should be installed separately and included in the Natlink config as necessary. The currently supported versions of Python are: 3.8-32

Installation

Easy installation/uninstallation is one of the primary goals of this repository. If you had to install any extra dependencies first in order to get it working, please file a bug report.

To install:

  • Install Dragon NaturallySpeaking
  • Install Python (32 bit required) for your user and do not add to path.
  • Pip install your desired extra packages (e.g. dragonfly)
  • Download and run the Natlink installer
  • Put a .natlink file in your home directory (see example below)
  • Add your scripts
  • Start Dragon

To uninstall:

  • Run the uninstaller, which will be found in the Natlink start menu entry or the installation directory.

Configuration

Configuration is done in .natlink ini-style files. Upon starting, Natlink will first look in the user's home directory for .natlink. If no config is found there, it will then look for .natlink in INSTALL_DIRECTORY\natlink. Here is an example config.

[directories]
# for most users, this section is all you need
my_scripts=C:\Users\user\dragonfly-scripts
system_wide_scripts=C:\Path\To\Shared\Scripts

[userenglish-directories]
only_loaded_if_profile_userenglish_active=C:\User\user\english-only-scripts

[userspanish-directories]
only_loaded_if_profile_userspanish_active=C:\User\user\spanish-only-scripts

[settings]
log_level=INFO

Section: [directories]

These are directories that Natlink will look for scripts to load in. Each directory has a name that may be used for debugging purposes and a value that is the absolute path to the directory. The directories are loaded in the order they appear. Scripts starting with an underscore and ending in .py (_*.py) will be imported in alphabetical order, except __init__.py will be loaded first if it exists. If no directories are listed or this section is omitted, then no scripts will be loaded.

Section: [<user>-directories] (optional)

Same as [directories], but scripts are only loaded if the active user profile is <user>. This section may be repeated any number of times for different users. This is useful e.g. if you have multiple user profiles for different languages. The relative load order between global and user directories is the order of appearance in the config.

Section: [settings] (optional)

The currently supported settings are:

  • log_level: the log level to set the Natlink logger to. Possible values are: CRITICAL, FATAL, ERROR, WARNING, INFO, DEBUG, NOTSET.
  • load_on_begin_utterance (default: False): check for and load or reload any new or changed scripts at the beginning of each utterance.
  • load_on_mic_on (default: True): check for and load or reload any new or changed scripts when the microphone state changes to "on".
  • load_on_startup (default: True): check for and load scripts as soon as Dragon loads Natlink.
  • load_on_user_changed (default: True): check for and load scripts when the user profile changes.

COM Module (C++)

The folder NatlinkSource, which contains all the C++ code, is for generating an in-process Component Object Model (COM) server. The output is natlink.pyd (a .pyd is essentially a .dll that is also a python module). The natlink.pyd can be used both as a COM server or just as a plain python package. When Dragon starts, it will start natlink.pyd, which does some setup and quickly passes things off to the Python side by importing natlinkmain.py. NOTE: Currently, a version tested for v. 14 and 15 is provided. (A different version of natlink.pyd is compiled for each supported version of Python. )

Compilation

To compile, run the CMakeLists.txt file from Visual Studio 2019 after selecting the desired Python. Or, use Visual Studio Code CMake extension. First configure for a compiler version, known as a kit. It must be specified (by suffix) to force crosscompilation from amd64 to x86, that is from 64-bit to 32-bit. This is a CMAKE configuration setting.

After configuration, the build system is generated in the build directory created as the only thing that's changed in the source directoy. At this point, build contains all information that relates to the actual build process, such as choice of compilers, build flags, settings configured by CMAKE, and of course the Visual Studio project files. Now, the build can be initated after choosing the 'Debug' variant. The 'Debug' subdirectories in the build tree will be populated by object code and the Python code that is to be part of the installation. Also, the installer phase of the build wraps everything up in the distributable executable.

CMake settings for different versions of Python are included in CMakeSettings.json.

You must have the corresponding Python (and it must be 32 bit) already installed on your system.

Main (Python)

The Python layer is found in MacroSystem\core. The file natlinkmain.py is imported when Dragon starts, and its job is to load the configuration files and then load any user scripts.

Installer (Inno Setup)

The installer/uninstaller is compiled using Inno Setup. The inno setup script is found under the InstallerSource directory. Make sure the Inno Setup compiler iscc.exe is in your PATH. To compile, run the CMakeLists.txt file from Visual Studio after selecting the desired Python. The installer will appear as \build\InstallerSource\natlinkX.X-pyY.Y-32-setup.exe
The installer executable is self-contained and may be distributed.

Why 32-bit?

Currently Dragon NaturallySpeaking (up to version 15) is itself a 32-bit application and it is therefore not possible for it to directly call a 64-bit .pyd.