diff --git a/dox/dev_guides/building/3rdparty/3rdparty_windows.md b/dox/dev_guides/building/3rdparty/3rdparty_windows.md index 2148d2c6df..69a0697b6e 100644 --- a/dox/dev_guides/building/3rdparty/3rdparty_windows.md +++ b/dox/dev_guides/building/3rdparty/3rdparty_windows.md @@ -11,12 +11,12 @@ You need to use the same version of MS Visual Studio for building all third-part The links for downloading the third-party products are available on the web site of OPEN CASCADE SAS at http://www.opencascade.org/getocc/require/. There are two types of third-party products used by OCCT: * Mandatory products: - * Tcl/Tk 8.5 - 8.6; - * FreeType 2.4.10 - 2.5.3. + * Tcl/Tk 8.5 -- 8.6; + * FreeType 2.4.10 -- 2.5.3. * Optional products: - * TBB 3.x - 4.x; - * gl2ps 1.3.5 - 1.3.8; - * FreeImage 3.14.1 -3.16.0; + * TBB 3.x -- 4.x; + * gl2ps 1.3.5 -- 1.3.8; + * FreeImage 3.14.1 -- 3.16.0; * VTK 6.1.0. It is recommended to create a separate new folder on your workstation, where you will unpack the downloaded archives of the third-party products, and where you will build these products (for example, *c:\\occ3rdparty*). @@ -168,9 +168,9 @@ You can download its sources from http://geuz.org/gl2ps/src/. As a result, you will get a folder named, for example, *3rdparty\\gl2ps-1.3.5-source*. Rename it into gl2ps-platform-compiler-building mode, where - * **platform** is *win32* or *win64*; - * **compiler** is *vc8*, *vc9* or *vc10*; - * **building mode** - *opt* (for release) or *deb* (for debug). + * **platform** -- *win32* or *win64*; + * **compiler** -- *vc8*, *vc9* or *vc10*; + * **building mode** -- *opt* (for release) or *deb* (for debug). For example, gl2ps-win64-vc10-deb @@ -208,7 +208,7 @@ You can download its sources from http://geuz.org/gl2ps/src/. @image html /dev_guides/building/3rdparty/images/3rdparty_image004.png @image latex /dev_guides/building/3rdparty/images/3rdparty_image004.png - * Select the generator (the compiler and the target platform - 32 or 64 bit) in the pop-up window. + * Select the generator (the compiler and the target platform -- 32 or 64 bit) in the pop-up window. @image html /dev_guides/building/3rdparty/images/3rdparty_image005.png @image latex /dev_guides/building/3rdparty/images/3rdparty_image005.png diff --git a/dox/dev_guides/building/android/android.md b/dox/dev_guides/building/android/android.md index f6b81552f7..7ae6b4ed58 100644 --- a/dox/dev_guides/building/android/android.md +++ b/dox/dev_guides/building/android/android.md @@ -35,7 +35,7 @@ Select "MinGW MakeFiles" item from the list - Click "Finish" @figure{/dev_guides/building/android/images/android_image003.png} -If ANDROID_NDK environment variable is not defined in current OS, add cache entry ANDROID_NDK (entry type is PATH) - path to the NDK folder ("Add Entry" button) +If ANDROID_NDK environment variable is not defined in current OS, add cache entry ANDROID_NDK (entry type is PATH) -- path to the NDK folder ("Add Entry" button) @figure{/dev_guides/building/android/images/android_image004.png} If on Windows the message is appeared: "CMake Error: CMake was unable to find a build program corresponding to "MinGW Makefiles" diff --git a/dox/dev_guides/building/automake.md b/dox/dev_guides/building/automake.md index 3a6166a16d..98a4d43ebb 100644 --- a/dox/dev_guides/building/automake.md +++ b/dox/dev_guides/building/automake.md @@ -60,7 +60,7 @@ To prevent this, it is suggested to make links: Example: - \> ./configure -prefix=/PRODUCTS/occt-6.5.5 --with-tcl=/PRODUCTS/tcltk-8.5.8/lib --with-tk=/PRODUCTS/tcltk-8.5.8/lib --with-freetype=/PRODUCTS/freetype-2.4.10 --with-gl2ps=/PRODUCTS/gl2ps-1.3.5 --with-freeimage=/PRODUCTS/freeimage-3.14.1 --with-tbb-include=/PRODUCTS/tbb30_018oss/include --with-tbb-library=/PRODUCTS/tbb30_018oss/lib/ia32/cc4.1.0_libc2.4_kernel2.6.16.21 -–with-vtk-include=/PRODUCTS/VTK-6.1.0/include/vtk-6.1 –with-vtk-library=/PRODUCTS/ /VTK-6.1.0//lib + \> ./configure -prefix=/PRODUCTS/occt-6.5.5 --with-tcl=/PRODUCTS/tcltk-8.5.8/lib --with-tk=/PRODUCTS/tcltk-8.5.8/lib --with-freetype=/PRODUCTS/freetype-2.4.10 --with-gl2ps=/PRODUCTS/gl2ps-1.3.5 --with-freeimage=/PRODUCTS/freeimage-3.14.1 --with-tbb-include=/PRODUCTS/tbb30_018oss/include --with-tbb-library=/PRODUCTS/tbb30_018oss/lib/ia32/cc4.1.0_libc2.4_kernel2.6.16.21 --with-vtk-include=/PRODUCTS/VTK-6.1.0/include/vtk-6.1 -with-vtk-library=/PRODUCTS/ /VTK-6.1.0//lib 3.If configure exits successfully, you can build OCCT with *make* command. diff --git a/dox/dev_guides/building/cmake/cmake.md b/dox/dev_guides/building/cmake/cmake.md index 9c28bbaaa0..421fd17ae1 100644 --- a/dox/dev_guides/building/cmake/cmake.md +++ b/dox/dev_guides/building/cmake/cmake.md @@ -35,7 +35,7 @@ The bare sources distribution contains not only the sources of Open CASCADE Tech Now it is time to run a CMake tool which will generate the actual project files for the target IDE (e.g., Visual Studio 2010 solution). -It is recommended to use *cmake-gui* - cross-platform GUI tool provided by CMake on Windows, Mac and Linux. As a command-line alternative, *ccmake* also can be used. +It is recommended to use *cmake-gui* -- cross-platform GUI tool provided by CMake on Windows, Mac and Linux. As a command-line alternative, *ccmake* also can be used. CMake deals with three directories: source, build or binary and install. @@ -47,11 +47,11 @@ CMake deals with three directories: source, build or binary and install. **Note**: The good practice is not to mix up different build configurations in a single directory and not to use the source directory as a build one, for example: - d:/occt/ - the source directory - d:/tmp/occt-build-vc10-x64 - the build directory with the generated - solution and other intermediate files created during a CMake tool working - d:/occt-install - the installation directory that is - able to contain several OCCT configuratoion + d:/occt/ -- the source directory + d:/tmp/occt-build-vc10-x64 -- the build directory with the generated + solution and other intermediate files created during a CMake tool working + d:/occt-install -- the installation directory that is + able to contain several OCCT configuratoion ## Configuration process @@ -93,9 +93,9 @@ The following table enumerates the full list of environment variables used at co | CMAKE_BUILD_TYPE | String | Specifies the build type on single-configuration generators (sush as make). Possible values are Debug, Release and RelWithDebInfo | | USE_FREEIMAGE | Boolean flag | Indicates whether Freeimage product should be used in OCCT visualization module for support of popular graphics image formats (PNG, BMP etc) | | USE_GL2PS | Boolean flag | Indicates whether GL2PS product should be used in OCCT visualization module for support of vector image formats (PS, EPS etc) | -| USE_TBB | Boolean flag | Indicates whether TBB 3-rd party is used or not. TBB stands for Threading Building Blocks, the technology of Intel Corp, which comes with different mechanisms and patterns for injecting parallelism into your application. OCCT remains parallel even without TBB product | -| USE_VTK | Boolean flag | Indicates whether VTK 3-rd party is used or not. VTK stands for Visualization ToolKit, the technology of Kitware Inc intended for general-purpose scientific visualization. OCCT comes with a bridge between CAD data representation and VTK by means of its dedicated VIS component (VTK Integration Services). You may skip this 3-rd party unless you are planning to use VTK visualization for OCCT geometry. The official documentation @ref occt_user_guides__vis for the details on VIS | -| 3RDPARTY_DIR | Path | Defines the root directory where all required 3-rd party products will be searched. Once you define this path it is very convenient to click "Configure" button in order to let CMake automatically detect all necessary products| +| USE_TBB | Boolean flag | Indicates whether TBB 3rd party is used or not. TBB stands for Threading Building Blocks, the technology of Intel Corp, which comes with different mechanisms and patterns for injecting parallelism into your application. OCCT remains parallel even without TBB product | +| USE_VTK | Boolean flag | Indicates whether VTK 3rd party is used or not. VTK stands for Visualization ToolKit, the technology of Kitware Inc intended for general-purpose scientific visualization. OCCT comes with a bridge between CAD data representation and VTK by means of its dedicated VIS component (VTK Integration Services). You may skip this 3rd party unless you are planning to use VTK visualization for OCCT geometry. The official documentation @ref occt_user_guides__vis for the details on VIS | +| 3RDPARTY_DIR | Path | Defines the root directory where all required 3rd party products will be searched. Once you define this path it is very convenient to click "Configure" button in order to let CMake automatically detect all necessary products| | 3RDPARTY_FREETYPE_* | Path | Path to Freetype binaries | | 3RDPARTY_TCL_* 3RDPARTY_TK_* | Path | Path to Tcl/Tk binaries | | 3RDPARTY_FREEIMAGE* | Path | Path to Freeimage binaries | @@ -125,18 +125,18 @@ OCCT sources. This way you are able to introduce patches to Open CASCADE Technol **Note:** In those CMake options defining paths only the forward slashes ("/") are acceptable. -### 3rd-party search mechanism (The variables with 3RDPARTY_ prefix) +### 3rd party search mechanism (The variables with 3RDPARTY_ prefix) -If *3RDPARTY_DIR* directory is defined, required 3rd-party binaries are sought in it, default system folders are ignored. +If *3RDPARTY_DIR* directory is defined, required 3rd party binaries are sought in it, default system folders are ignored. -The procedure expects to find binary and header files of each 3rd-party product in its own sub-directory: *bin*, *lib* and *include*. +The procedure expects to find binary and header files of each 3rd party product in its own sub-directory: *bin*, *lib* and *include*. The result of the search (achived on the next pass of the configuration process) are recorded in the corresponding variables: -* *3RDPARTY_\_DIR* - path to the 3rdparty directory (with directory name) (e.g. D:/3rdparty/tcltk-86-32) -* *3RDPARTY_\_LIBRARY_DIR* - path to directory containing a library (e.g. D:/3rdparty/tcltk-86-32/lib). -* *3RDPARTY_\_INCLUDE_DIR* - path to the directory containing a header file (e.g., D:/3rdparty/tcltk-86-32/include) -* *3RDPARTY_\_DLL_DIR* - path to the directory containing a shared library (e.g., D:/3rdparty/tcltk-86-32/bin) This variable is only relevant to Windows platforms +* *3RDPARTY_\_DIR* -- path to the 3rdparty directory (with directory name) (e.g. D:/3rdparty/tcltk-86-32) +* *3RDPARTY_\_LIBRARY_DIR* -- path to the directory containing a library (e.g. D:/3rdparty/tcltk-86-32/lib). +* *3RDPARTY_\_INCLUDE_DIR* -- path to the directory containing a header file (e.g., D:/3rdparty/tcltk-86-32/include) +* *3RDPARTY_\_DLL_DIR* -- path to the directory containing a shared library (e.g., D:/3rdparty/tcltk-86-32/bin) This variable is only relevant to Windows platforms. Note: each library and include directory should be the children of product directory if the last one is defined. @@ -194,14 +194,14 @@ Normally you use the installation directory of OCCT to link against your specifi the directory structure is follow: - data - data files for OCCT (brep, iges, stp) - doc - OCCT overview documentation in HTML format - inc - header files - samples - samples - src - all required source files for OCCT - tests - OCCT test suite - win32\vc10\bind - binary files (installed 3rdparties and occt) - \libd - libraries (installed 3rdparties and occt) + data -- data files for OCCT (brep, iges, stp) + doc -- OCCT overview documentation in HTML format + inc -- header files + samples -- samples + src -- all required source files for OCCT + tests -- OCCT test suite + win32\vc10\bind -- binary files (installed 3rdparties and occt) + \libd -- libraries (installed 3rdparties and occt) **Note:** The above example is given for debug configuration. However, it is generally safe to use the same installation directory for the release build. In the latter case the contents of install directory will be enriched with subdirectories and files related to the release configuration. In particular, the binaries directory win64 will be expanded as follows: @@ -211,6 +211,6 @@ follows: \bin \lib -If CMake installation flags are enabled for the 3-rd party products (e.g. INSTALL_FREETYPE), then the corresponding binaries will be copied to the same bin(d) and lib(d) directories together with the native binaries of OCCT. Such organization of libraries can be especially helpful if your OCCT-based software does not use itself the 3-rd parties of Open CASCADE Technology (thus, there is no sense to pack them into dedicated directories) +If CMake installation flags are enabled for the 3rd party products (e.g. INSTALL_FREETYPE), then the corresponding binaries will be copied to the same bin(d) and lib(d) directories together with the native binaries of OCCT. Such organization of libraries can be especially helpful if your OCCT-based software does not use itself the 3rd parties of Open CASCADE Technology (thus, there is no sense to pack them into dedicated directories) The installation folder contains the scripts to run *DRAWEXE* (*draw.bat* or *draw.sh*), samples (if its were installed) and overview.html (short-cut for installed OCCT overview documentation). diff --git a/dox/dev_guides/building/msvc.md b/dox/dev_guides/building/msvc.md index c1997ba5dc..7f0572d200 100644 --- a/dox/dev_guides/building/msvc.md +++ b/dox/dev_guides/building/msvc.md @@ -13,11 +13,11 @@ paragraph 1 of \ref occt_dev_guides__building for instructions. 1. Edit file *custom.bat* to define the environment: - - *VCVER* - version of Visual Studio (vc8, vc9, vc10, vc11 or vc12), + - *VCVER* -- version of Visual Studio (vc8, vc9, vc10, vc11 or vc12), and relevant *VCVARS* path - - *ARCH* - architecture (32 or 64), affects only *PATH* variable for execution - - HAVE_* - flags to enable or disable use of optional third-party products - - CSF_OPT_* - paths to search for includes and binaries of all used + - *ARCH* -- architecture (32 or 64), affects only *PATH* variable for execution + - HAVE_* -- flags to enable or disable use of optional third-party products + - CSF_OPT_* -- paths to search for includes and binaries of all used third-party products 2. Launch *msvc.bat* to start Visual Studio with all necessary environment diff --git a/dox/dev_guides/building/wok/wok.md b/dox/dev_guides/building/wok/wok.md index 177488ccec..bb9219c3cd 100644 --- a/dox/dev_guides/building/wok/wok.md +++ b/dox/dev_guides/building/wok/wok.md @@ -115,14 +115,14 @@ and third-party components required for building OCCT. LOC:dev:occt> wgenproj [ -target= ] [ -no_wprocess ] ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ TARGET: - * *vc8* - Visual Studio 2005; - * *vc9* - Visual Studio 2008; - * *vc10* - Visual Studio 2010; - * *vc11* - Visual Studio 2012; - * *cbp* - CodeBlocks; - * *cmake* - CMake; - * *amk* - AutoMake; - * *xcd* - Xcode; + * *vc8* -- Visual Studio 2005; + * *vc9* -- Visual Studio 2008; + * *vc10* -- Visual Studio 2010; + * *vc11* -- Visual Studio 2012; + * *cbp* -- CodeBlocks; + * *cmake* -- CMake; + * *amk* -- AutoMake; + * *xcd* -- Xcode; * -no_wprocess option skips generation of derived headers and source files. Note that this command takes several minutes to complete at the first call. @@ -135,14 +135,14 @@ To regenerate derived headers and source files without regeneration of projects LOC:dev:occt> wprocess -DGroups=Src,Xcpp ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The generated building project has been placed into $CASROOT/adm folder: - * for vc8 - $CASROOT/adm/msvc/vc8; - * for vc9 - $CASROOT/adm/msvc/vc9; - * for vc10 - $CASROOT/adm/msvc/vc10; - * for vc11 - $CASROOT/adm/msvc/vc11; - * for cbp - $CASROOT/adm/\/cbp; - * for cmake - $CASROOT/adm/cmake; - * for amk - $CASROOT/adm/lin/amk; - * xcd - $CASROOT/adm/\/xcd + * for vc8 -- $CASROOT/adm/msvc/vc8; + * for vc9 -- $CASROOT/adm/msvc/vc9; + * for vc10 -- $CASROOT/adm/msvc/vc10; + * for vc11 -- $CASROOT/adm/msvc/vc11; + * for cbp -- $CASROOT/adm/\/cbp; + * for cmake -- $CASROOT/adm/cmake; + * for amk -- $CASROOT/adm/lin/amk; + * xcd -- $CASROOT/adm/\/xcd @section wok4 Generation of documentation @@ -152,11 +152,11 @@ The generated building project has been placed into $CASROOT/adm folder: :LOC:dev:occt> wgendoc ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The following options can be used: - * -wb=\ the name of OCCT workbench (the current one by default); - * -m=\ the list of modules that will be contained in the documentation; - * -outdir=\ the output directory for the documentation; - * -chm the option to generate CHM file; - * -hhc=\ the path to HTML Help Compiler *hhc.exe* or equivalent; - * -qthelp=\ the option to generate Qt Help file, where \ is the required path to *qthelpgenerator* executable; - * -doxygen=\ the path to Doxygen executable; - * -dot=\ the path to GraphViz dot executable. + * -wb=\ -- the name of OCCT workbench (the current one by default); + * -m=\ -- the list of modules that will be contained in the documentation; + * -outdir=\ -- the output directory for the documentation; + * -chm -- the option to generate CHM file; + * -hhc=\ -- the path to HTML Help Compiler *hhc.exe* or equivalent; + * -qthelp=\ -- the option to generate Qt Help file, where \ is the required path to *qthelpgenerator* executable; + * -doxygen=\ -- the path to Doxygen executable; + * -dot=\ -- the path to GraphViz dot executable. diff --git a/dox/dev_guides/contribution/coding_rules.md b/dox/dev_guides/contribution/coding_rules.md index 36e6d40610..e9426f7a0f 100644 --- a/dox/dev_guides/contribution/coding_rules.md +++ b/dox/dev_guides/contribution/coding_rules.md @@ -67,10 +67,10 @@ Names of units should not contain underscores, unless the use of underscores is The following extensions should be used for source files, depending on their type: -* .cdl - CDL declaration files -* .cxx - C++ source files -* .hxx - C++ header files -* .lxx - headers with definitions of inline methods (CDL packages) +* .cdl -- CDL declaration files +* .cxx -- C++ source files +* .hxx -- C++ header files +* .lxx -- headers with definitions of inline methods (CDL packages) ### Prefix for toolkit names [MANDATORY] @@ -452,7 +452,7 @@ The source code is one of the most important references for documentation. The comments in the source code should be complete enough to allow understanding the corresponding code and to serve as basis for other documents. The main reasons why the comments are regarded as documentation and should be maintained are: -- The comments are easy to reach - they are always together with the source code; +- The comments are easy to reach -- they are always together with the source code; - It is easy to update a description in the comment when the source is modified; - The source by itself is a good context to describe various details that would require much more explanations in a separate document; - As a summary, this is the most cost-effective documentation. @@ -950,7 +950,7 @@ Command should warn the user about unknown arguments, including cases when extra ### Message printing -Informative messages should be printed into standard output *std::cout*, whilst command results (if any) - into Draw Interpreter. +Informative messages should be printed into standard output *std::cout*, whilst command results (if any) -- into Draw Interpreter. Information printed into Draw Interpreter should be well-structured to allow usage in TCL script. diff --git a/dox/dev_guides/contribution_workflow/contribution_workflow.md b/dox/dev_guides/contribution_workflow/contribution_workflow.md index 217ae48c8b..22bc8463b6 100644 --- a/dox/dev_guides/contribution_workflow/contribution_workflow.md +++ b/dox/dev_guides/contribution_workflow/contribution_workflow.md @@ -198,9 +198,9 @@ The following lines should provide a description of the context and details on t The contents and the recommended structure of the description depend on the nature of the bug. In a general case, the following elements should be present: -* **Problem** – a description of the unwanted behavior; -* **Change** – a description of the implemented changes, including the names of involved classes / methods / enumerations etc.; -* **Result** – a description of the current behavior (after the implementation). +* **Problem** -- a description of the unwanted behavior; +* **Change** -- a description of the implemented changes, including the names of involved classes / methods / enumerations etc.; +* **Result** -- a description of the current behavior (after the implementation). Example: diff --git a/dox/dev_guides/debug/debug.md b/dox/dev_guides/debug/debug.md index e1e4838f04..cf0ac3317e 100644 --- a/dox/dev_guides/debug/debug.md +++ b/dox/dev_guides/debug/debug.md @@ -59,8 +59,8 @@ const char* DBRep_Set (const char* theNameStr, void* theShapePtr) ~~~~~ Sets the specified shape as a value of DRAW interpreter variable with the given name. -- *theNameStr* - the DRAW interpreter variable name to set. -- *theShapePtr* - a pointer to *TopoDS_Shape* variable. +- *theNameStr* -- the DRAW interpreter variable name to set. +- *theShapePtr* -- a pointer to *TopoDS_Shape* variable. ~~~~~ const char* DrawTrSurf_Set (const char* theNameStr, void* theHandlePtr) @@ -69,10 +69,10 @@ const char* DrawTrSurf_SetPnt2d (const char* theNameStr, void* thePnt2dPtr) ~~~~~ Sets the specified geometric object as a value of DRAW interpreter variable with the given name. -- *theNameStr* - the DRAW interpreter variable name to set. -- *theHandlePtr* - a pointer to the geometric variable (Handle to *Geom_Geometry* or *Geom2d_Curve* or descendant) to be set. -- *thePntPtr* - a pointer to the variable of type *gp_Pnt* to be set. -- *thePnt2dPtr* - a pointer to the variable of type *gp_Pnt2d* to be set. +- *theNameStr* -- the DRAW interpreter variable name to set. +- *theHandlePtr* -- a pointer to the geometric variable (Handle to *Geom_Geometry* or *Geom2d_Curve* or descendant) to be set. +- *thePntPtr* -- a pointer to the variable of type *gp_Pnt* to be set. +- *thePnt2dPtr* -- a pointer to the variable of type *gp_Pnt2d* to be set. All these functions are defined in *TKDraw* toolkit and return a string indicating the result of execution. @@ -85,8 +85,8 @@ const char* BRepTools_Write (const char* theFileNameStr, void* theShapePtr) ~~~~~ Saves the specified shape to a file with the given name. -- *theFileNameStr* - the name of the file where the shape is saved. -- *theShapePtr* - a pointer to *TopoDS_Shape* variable. +- *theFileNameStr* -- the name of the file where the shape is saved. +- *theShapePtr* -- a pointer to *TopoDS_Shape* variable. ~~~~~ const char* BRepTools_Dump (void* theShapePtr) @@ -94,7 +94,7 @@ const char* BRepTools_DumpLoc (void* theShapePtr) ~~~~~ Dumps shape or its location to cout. -- *theShapePtr* - a pointer to *TopoDS_Shape* variable. +- *theShapePtr* -- a pointer to *TopoDS_Shape* variable. The following function is provided by *TKMesh* toolkit: @@ -103,8 +103,8 @@ const char* BRepMesh_Dump (void* theMeshHandlePtr, const char* theFileNameStr) ~~~~~ Stores mesh produced in parametric space to BREP file. -- *theMeshHandlePtr* - a pointer to *Handle(BRepMesh_DataStructureOfDelaun)* variable. -- *theFileNameStr* - the name of the file where the mesh is stored. +- *theMeshHandlePtr* -- a pointer to *Handle(BRepMesh_DataStructureOfDelaun)* variable. +- *theFileNameStr* -- the name of the file where the mesh is stored. The following additional function is provided by *TKGeomBase* toolkit: @@ -113,7 +113,7 @@ const char* GeomTools_Dump (void* theHandlePtr) ~~~~~ Dump geometric object to cout. -- *theHandlePtr* - a pointer to the geometric variable (Handle to *Geom_Geometry* or *Geom2d_Curve* or descendant) to be set. +- *theHandlePtr* -- a pointer to the geometric variable (Handle to *Geom_Geometry* or *Geom2d_Curve* or descendant) to be set. @section occt_debug_vstudio Using Visual Studio debugger diff --git a/dox/dev_guides/documentation/documentation.md b/dox/dev_guides/documentation/documentation.md index f53fb88d4f..a84c770b0d 100644 --- a/dox/dev_guides/documentation/documentation.md +++ b/dox/dev_guides/documentation/documentation.md @@ -117,16 +117,16 @@ If you want to use the same image for several documents, you can place it in *do The documentation is generated in subfolder *doc* : -* *html* - a directory for generated HTML pages; -* *pdf* - a directory for generated PDF files. +* *html* -- a directory for generated HTML pages; +* *pdf* -- a directory for generated PDF files. @section OCCT_DM_SECTION_4 Adding a New Document Place a new document in the folder taking into account its logical position in the documentation hierarchy. For instance, the document *svn.md* about the use of SVN to work with OCCT source code can be placed into /dox/dev_guides/. If there are images in the document, it should be placed in its own folder containing a subfolder for images. For instance: -* /dox/dev_guides/svn/ - for *svn.md* file; -* /dox/dev_guides/svn/images/ - for images. +* /dox/dev_guides/svn/ -- for *svn.md* file; +* /dox/dev_guides/svn/images/ -- for images. Add a relative path to *svn.md* in file dox/FILES.txt. For instance @@ -168,9 +168,9 @@ The table of contents, page numbers (in PDF), and figure numbers (in PDF) are ge @subsection OCCT_DM_SECTION_A_1 Headers and hierarchic document structure Headers of different levels can be specified with the following tags: -* \@section - for the first-level headers; -* \@subsection - for the second level headers; -* \@subsubsection - for the third level headers. +* \@section -- for the first-level headers; +* \@subsection -- for the second level headers; +* \@subsubsection -- for the third level headers. For example: diff --git a/dox/dev_guides/git_guide/git_guide.md b/dox/dev_guides/git_guide/git_guide.md index 8126490da0..de5a9ee2af 100644 --- a/dox/dev_guides/git_guide/git_guide.md +++ b/dox/dev_guides/git_guide/git_guide.md @@ -66,7 +66,7 @@ The official repository contains: Integration of contributions that have passed certification testing is made exclusively by the Bugmaster. Normally this is made by rebasing the contribution branch on the current master and squashing it into a single commit. This is made to have the master branch history plain and clean, - following the general rule “one issue – one commit”. + following the general rule “one issue -- one commit”. The description of the commit integrated to the master branch is taken from the Mantis issue (ID, 'Summary', followed by the information from 'Documentation' field if present). @@ -222,8 +222,8 @@ The official repository contains: On Windows, make sure to note the complete path to the generated files (the location of your $HOME might be not obvious). Two key files will be created in the specified location (by default in $HOME/.ssh/): - * *id_rsa* - private key - * *id_rsa.pub* - public key + * *id_rsa* -- private key + * *id_rsa.pub* -- public key The content of the public key file (one text line) is the key to be added to the user account on the site (see below). @@ -358,7 +358,7 @@ In TortoiseGit: > git commit -a -m "Write meaningful commit message here" ~~~~~ - Option –a tells the command to automatically include (stage) files + Option -a tells the command to automatically include (stage) files that have been modified or deleted, but it will omit the new files that might have been added by you. To commit such new files, you must add (stage) them before commit command. @@ -437,7 +437,7 @@ Note that Git forbids pushing a branch if the corresponding remote branch alread @image html OCCT_GitGuide_V2_image019.png @image latex OCCT_GitGuide_V2_image019.png -Note that the local branches of your repository are the primary place, where your changes are stored until they get integrated to the official version of OCCT (master branch). The branches submitted to official repository are for collaborative work, review, and integration - that repository should not be used for long-term storage of incomplete changes. +Note that the local branches of your repository are the primary place, where your changes are stored until they get integrated to the official version of OCCT (master branch). The branches submitted to official repository are for collaborative work, review, and integration -- that repository should not be used for long-term storage of incomplete changes. Remove the local branches that you do not need any more. Note that you cannot delete the current branch. It means that you need to switch to another one (e.g. master) if the branch you are going to delete is the current one. diff --git a/dox/dev_guides/tests/tests.md b/dox/dev_guides/tests/tests.md index 484ce70010..2870b2cf8b 100644 --- a/dox/dev_guides/tests/tests.md +++ b/dox/dev_guides/tests/tests.md @@ -101,7 +101,7 @@ Example: The tests are considered as non-regressive if only OK, BAD (i.e. known problem), and SKIPPED (i.e. not executed, typically because of lack of a data file) statuses are reported. See @ref testmanual_details_results "Interpretation of test results" for details. The results and detailed logs of the tests are saved by default to a new subdirectory of the subdirectory *results* in the current folder, whose name is generated automatically using the current date and time, prefixed by Git branch name (if Git is available and current sources are managed by Git). -If necessary, a non-default output directory can be specified using option –outdir followed by a path to the directory. This directory should be new or empty; use option –overwrite to allow writing results in the existing non-empty directory. +If necessary, a non-default output directory can be specified using option -outdir followed by a path to the directory. This directory should be new or empty; use option -overwrite to allow writing results in the existing non-empty directory. Example: ~~~~~ @@ -199,7 +199,7 @@ Example: * Added files: ~~~~~ -git status –short +git status -short A tests/bugs/heal/data/bug210_a.brep A tests/bugs/heal/data/bug210_b.brep A tests/bugs/heal/bug210_1 @@ -570,7 +570,7 @@ Other Tcl variables defined during the test execution are: In order to ensure that the test works as expected in different environments, observe the following additional rules: * Avoid using external commands such as *grep, rm,* etc., as these commands can be absent on another system (e.g. on Windows); use facilities provided by Tcl instead. -* Do not put call to *locate_data_file* in catch statement – this can prevent correct interpretation of the missing data file by the test system. +* Do not put call to *locate_data_file* in catch statement -- this can prevent correct interpretation of the missing data file by the test system. * Do not use commands *decho* and *dlog* in the test script, to avoid interference with use of these commands by the test system. @subsection testmanual_details_results Interpretation of test results @@ -705,15 +705,15 @@ testdiff dir1 dir2 [groupname [gridname]] [options...] Here *dir1* and *dir2* are directories containing logs of two test runs. Possible options are: -* -save \ - saves the resulting log in a specified file ($dir1/diff-$dir2.log by default). HTML log is saved with the same name and extension .html; -* -status {same|ok|all} - allows filtering compared cases by their status: - * *same* - only cases with same status are compared (default); - * *ok* - only cases with OK status in both logs are compared; - * *all* - results are compared regardless of status; -* -verbose \ - defines the scope of output data: - * 1 - outputs only differences; - * 2 - additionally outputs the list of logs and directories present in one of directories only; - * 3 - (by default) additionally outputs progress messages; +* -save \ -- saves the resulting log in a specified file ($dir1/diff-$dir2.log by default). HTML log is saved with the same name and extension .html; +* -status {same|ok|all} -- allows filtering compared cases by their status: + * *same* -- only cases with same status are compared (default); + * *ok* -- only cases with OK status in both logs are compared; + * *all* -- results are compared regardless of status; +* -verbose \ -- defines the scope of output data: + * 1 -- outputs only differences; + * 2 -- additionally outputs the list of logs and directories present in one of directories only; + * 3 -- (by default) additionally outputs progress messages; Example: @@ -760,9 +760,9 @@ This group allows testing Boolean operations. DRAW module: MODELING (packages *BOPTest* and *BRepTest*). Grids names are based on name of the command used, with suffixes: -* _2d – for tests operating with 2d objects (wires, wires, 3d objects, etc.); -* _simple – for tests operating on simple shapes (boxes, cylinders, toruses, etc.); -* _complex – for tests dealing with complex shapes. +* _2d -- for tests operating with 2d objects (wires, wires, 3d objects, etc.); +* _simple -- for tests operating on simple shapes (boxes, cylinders, toruses, etc.); +* _complex -- for tests dealing with complex shapes. | Grid | Commands | Functionality | | :---- | :----- | :------- | @@ -1223,9 +1223,9 @@ To check pixel color command *checkcolor* can be used. Use: checkcolor x y red green blue - x y - pixel coordinates + x, y -- pixel coordinates - red green blue - expected pixel color (values from 0 to 1) + red green blue -- expected pixel color (values from 0 to 1) This procedure checks color with tolerance (5x5 area) diff --git a/dox/dev_guides/upgrade/upgrade.md b/dox/dev_guides/upgrade/upgrade.md index f9b02949f6..148d873439 100644 --- a/dox/dev_guides/upgrade/upgrade.md +++ b/dox/dev_guides/upgrade/upgrade.md @@ -438,7 +438,7 @@ To display this object use command *vdisplay*. For example: ~~~~~ pload VISUALIZATION vinit -vcolorscale cs –demo +vcolorscale cs -demo pload MODELING box b 100 100 100 vdisplay b diff --git a/dox/overview/overview.md b/dox/overview/overview.md index 53dd94673d..7c2dac5515 100644 --- a/dox/overview/overview.md +++ b/dox/overview/overview.md @@ -59,8 +59,8 @@ OPEN CASCADE S.A.S. **Mac** and the Mac logo are trademarks of Apple Inc., registered in the U.S. and other countries. - Acknowledgements ------------------- + Acknowledgments +----------------- The following parties are acknowledged for producing tools which are used within Open CASCADE Technology libraries or for release preparation. @@ -115,7 +115,7 @@ implementation of 3D viewer. OpenGL specification is developed by the Khronos group, http://www.khronos.org/opengl/. OCCT code includes header file *glext.h* obtained from Khronos web site. -**VTK** - The **Visualization Toolkit (VTK)** is an open-source, freely available software system for 3D computer graphics, image processing and visualization. OCCT VIS component provides adaptation functionality for visualization of OCCT topological shapes by means of VTK library. If you need further information on VTK, please, refer to VTK Homepage http://www.vtk.org/. +**VTK** -- The **Visualization Toolkit (VTK)** is an open-source, freely available software system for 3D computer graphics, image processing and visualization. OCCT VIS component provides adaptation functionality for visualization of OCCT topological shapes by means of VTK library. If you need further information on VTK, please, refer to VTK Homepage http://www.vtk.org/. **Doxygen** developed by Dimitri van Heesch is open source documentation system for C++, C, Java, Objective-C, Python, IDL, PHP and C#. This product is used in Open CASCADE Technology @@ -312,7 +312,7 @@ To run any Open CASCADE Technology application you need to set the environment v You can define the environment variables with env.bat script located in the $CASROOT folder. This script accepts two arguments to be used: -the version of Visual Studio (vc8 - vc12) and the architecture (win32 or win64). +the version of Visual Studio (vc8 -- vc12) and the architecture (win32 or win64). The additional environment settings necessary for compiling OCCT libraries and samples by Microsoft Visual Studio can be set using script custom.bat located in the same folder. @@ -569,9 +569,9 @@ There are two samples are representing usage OCCT framework on Android mobile pl jniviewer @image html /overview/images/samples_java_android_occt.jpg @image latex /overview/images/samples_java_android_occt.jpg -Java - See \subpage samples_java_android_occt "Readme" for details. +Java -- See \subpage samples_java_android_occt "Readme" for details. AndroidQt @image html /overview/images/samples_qml_android_occt.jpg @image latex /overview/images/samples_qml_android_occt.jpg -Qt - See \subpage samples_qml_android_occt "Readme" for details. +Qt -- See \subpage samples_qml_android_occt "Readme" for details. diff --git a/dox/technical_overview/technical_overview.md b/dox/technical_overview/technical_overview.md index 776d707a1c..96c53d638a 100644 --- a/dox/technical_overview/technical_overview.md +++ b/dox/technical_overview/technical_overview.md @@ -75,13 +75,13 @@ Geometry types and utilities provide geometric data structures and services for: * Calculation of extrema between geometric objects. Topology defines relationships between simple geometric entities. A shape, which is a basic topological entity, can be divided into components (sub-shapes): - * Vertex – a zero-dimensional shape corresponding to a point; - * Edge - a shape corresponding to a curve and bounded by a vertex at each extremity; - * Wire - a sequence of edges connected by their vertices; - * Face - a part of a plane (in 2D) or a surface (in 3D) bounded by wires; - * Shell - a collection of faces connected by edges of their wire boundaries; - * Solid - a finite closed part of 3D space bounded by shells; - * Compound solid - a collection of solids connected by faces of their shell boundaries. + * Vertex -- a zero-dimensional shape corresponding to a point; + * Edge -- a shape corresponding to a curve and bounded by a vertex at each extremity; + * Wire -- a sequence of edges connected by their vertices; + * Face -- a part of a plane (in 2D) or a surface (in 3D) bounded by wires; + * Shell -- a collection of faces connected by edges of their wire boundaries; + * Solid -- a finite closed part of 3D space bounded by shells; + * Compound solid -- a collection of solids connected by faces of their shell boundaries. Complex shapes can be defined as assemblies of simpler entities. @@ -123,9 +123,9 @@ Top-level API provides the following functionality: * Spheres; * Toruses. * Kinematic Modeling: - * Prisms - linear sweeps; - * Revolutions - rotational sweeps; - * Pipes - general-form sweeps; + * Prisms -- linear sweeps; + * Revolutions -- rotational sweeps; + * Pipes -- general-form sweeps; * Lofting. @figure{/technical_overview/images/0001.png "Shapes containing pipes with variable radius produced by sweeping"} diff --git a/dox/user_guides/boolean_operations/boolean_operations.md b/dox/user_guides/boolean_operations/boolean_operations.md index ccd43d5fcc..305242f712 100644 --- a/dox/user_guides/boolean_operations/boolean_operations.md +++ b/dox/user_guides/boolean_operations/boolean_operations.md @@ -30,12 +30,12 @@ The operator can be represented as: RB=Bj (G1, G2), where: -* *RB* - result of the operation; -* *Bj* - operation of type *j* (Common, Fuse, Cut); +* *RB* -- result of the operation; +* *Bj* -- operation of type *j* (Common, Fuse, Cut); * *G1={S11, S12 ... S1n1}* group of arguments (Objects); * *G2={S21, S22 ... S2n2}* group of arguments (Tools); -* *n1* - Number of arguments in *Objects* group; -* *n2* - Number of arguments in *Tools* group. +* *n1* -- Number of arguments in *Objects* group; +* *n2* -- Number of arguments in *Tools* group. **Note** There is an operation *Cut21*, which is an extension for forward Cut operation, i.e Cut21=Cut(G2, G1). @@ -49,9 +49,9 @@ The GFA operator can be represented as: RGF = GF (S1, S2 ... Sn), where -* *RGF* - result of the operation, -* *S1, S2 ... Sn* - arguments of the operation, -* *n* - number of arguments. +* *RGF* -- result of the operation, +* *S1, S2 ... Sn* -- arguments of the operation, +* *n* -- number of arguments. The result of the Boolean operator, *RB*, can be obtained from *RGF*. @@ -79,11 +79,11 @@ The PA operator can be represented as follows: RPA=PA (G1, G2), where: -* RPA - is the result of the operation; +* RPA -- is the result of the operation; * *G1={S11, S12 ... S1n1}* group of arguments (Objects); * *G2={S21, S22 ... S2n2}* group of arguments (Tools); -* *n1* - Number of arguments in *Objects* group; -* *n2* - Number of arguments in *Tools* group. +* *n1* -- Number of arguments in *Objects* group; +* *n2* -- Number of arguments in *Tools* group. The result *RPA* can be obtained from *RGF* . @@ -105,9 +105,9 @@ The fact that the *RGF* contains the components of *RPA* a The Section operator *SA* can be applied to arbitrary number of arguments in terms of *TopoDS_Shape*. The result of *SA* contains vertices and edges in accordance with interferences between the arguments The SA operator can be represented as follows: RSA=SA(S1, S2… Sn), where -* RSA – is result of the operation; -* S1, S2 … Sn - Arguments of the operation; -* *n* - Number of arguments. +* RSA -- the operation result; +* S1, S2 ... Sn -- the operation arguments; +* *n* -- the number of arguments. @subsection occt_algorithms_2_2 Parts of algorithms @@ -127,7 +127,7 @@ This chapter provides the background terms and definitions that are necessary to There are two groups of interferences. -At first, each shape having a boundary representation (vertex, edge, face) has an internal value of geometrical tolerance. The shapes interfere with each other in terms of their tolerances. The shapes that have a boundary representation interfere when there is a part of 3D space where the distance between the underlying geometry of shapes is less or equal to the sum of tolerances of the shapes. Three types of shapes - vertex, edge and face - produce six types of **BRep interferences:** +At first, each shape having a boundary representation (vertex, edge, face) has an internal value of geometrical tolerance. The shapes interfere with each other in terms of their tolerances. The shapes that have a boundary representation interfere when there is a part of 3D space where the distance between the underlying geometry of shapes is less or equal to the sum of tolerances of the shapes. Three types of shapes: vertex, edge and face -- produce six types of **BRep interferences:** * Vertex/Vertex, * Vertex/Edge, * Vertex/Face, @@ -350,7 +350,7 @@ If the pave blocks *PBi* geometrically coincide with a face *Fj*, the pave block In general case a common block *CB* contains: * Pave blocks *PBi (i=0,1,2, 3… NbPB)*. -* A set of faces *Fj (j=0,1... NbF), NbF* - number of faces. +* A set of faces *Fj (j=0,1... NbF), NbF* -- number of faces. @subsection occt_algorithms_3_6 FaceInfo @@ -702,12 +702,12 @@ The input data for this step is the DS after computing Face/Face interferences. | No | Contents | Implementation | | :---- | :---- | :---- | -| 1 | For each Face/Face interference *nFi, nFj*, retrieve @ref occt_algorithms_4_6 "FaceInfo". Create draft vertices from intersection points *VPk (k=1, 2…, NbVP)*, where *NbVP* is the number of new vertices, and the draft vertex *VPk* is created from an intersection point if *VPk ≠ Vm (m = 0, 1, 2… NbVm)*, where *Vm* is an existing vertex for the faces *nFi* and *nF,j* (*On* or *In* in terms of *TopoDs_Shape*), *NbVm* is the number of vertices existing on faces *nFi* and *nF,j* and ≠ - means non-coincidence in terms of @ref occt_algorithms_3_1_1 "Vertex/Vertex interference". | *BOPAlgo_PaveFiller::MakeBlocks()* | +| 1 | For each Face/Face interference *nFi, nFj*, retrieve @ref occt_algorithms_4_6 "FaceInfo". Create draft vertices from intersection points *VPk (k=1, 2…, NbVP)*, where *NbVP* is the number of new vertices, and the draft vertex *VPk* is created from an intersection point if *VPk ≠ Vm (m = 0, 1, 2… NbVm)*, where *Vm* is an existing vertex for the faces *nFi* and *nF,j* (*On* or *In* in terms of *TopoDs_Shape*), *NbVm* is the number of vertices existing on faces *nFi* and *nF,j* and ≠ -- means non-coincidence in terms of @ref occt_algorithms_3_1_1 "Vertex/Vertex interference". | *BOPAlgo_PaveFiller::MakeBlocks()* | | 2 | For each intersection curve *Cijk* | | | 2.1 | Create paves PVc for the curve using existing vertices, i.e. vertices On or In (in terms of *FaceInfo*) for faces *nFi* and *nFj*. Append the paves *PVc* | *BOPAlgo_PaveFiller::PutPaveOnCurve()* and *BOPDS_PaveBlock::AppendExtPave()* | | 2.2 | Create technological vertices *Vt*, which are the bounding points of an intersection curve (with the value of tolerance *Tol(Cijk)*). Each vertex *Vt* with parameter *Tt* on curve *Cijk* forms pave *PVt* on curve *Cijk*. Append technological paves. | *BOPAlgo_PaveFiller::PutBoundPaveOnCurve()* | | 2.3 | Create pave blocks *PBk* for the curve using paves (k=1, 2…, NbPB), where *NbPB* is the number of pave blocks | *BOPAlgo_PaveFiller::MakeBlocks()* | -| 2.4 | Build draft section edges *ESk* using the pave blocks (k=1, 2…, NbES), where *NbES* is the number of draft section edges The draft section edge is created from a pave block *PBk* if *PBk* has state *In* or *On* for both faces *nFi* and *nF,j* and *PBk ≠ PBm (m=0, 1, 2… NbPBm)*, where *PBm* is an existing pave block for faces *nFi* and *nF,j* (*On* or *In* in terms of *FaceInfo*), *NbVm* is the number of existing pave blocks for faces *nFi* and *nF,j* and ≠ - means non-coincidence (in terms of @ref occt_algorithms_3_1_3 "Vertex/Face interference"). | *BOPTools_Tools::MakeEdge()* | +| 2.4 | Build draft section edges *ESk* using the pave blocks (k=1, 2…, NbES), where *NbES* is the number of draft section edges The draft section edge is created from a pave block *PBk* if *PBk* has state *In* or *On* for both faces *nFi* and *nF,j* and *PBk ≠ PBm (m=0, 1, 2… NbPBm)*, where *PBm* is an existing pave block for faces *nFi* and *nF,j* (*On* or *In* in terms of *FaceInfo*), *NbVm* is the number of existing pave blocks for faces *nFi* and *nF,j* and ≠ -- means non-coincidence (in terms of @ref occt_algorithms_3_1_3 "Vertex/Face interference"). | *BOPTools_Tools::MakeEdge()* | | 3 | Intersect the draft vertices *VPk (k=1, 2…, NbVP)* and the draft section edges *ESk (k=1, 2…, NbES)*. For this: a) create new object *PFn* of type *BOPAlgo_PaveFiller* with its own DS; b) use vertices *VPk* and edges *ESk* as arguments (in terms of @ref occt_algorithms_4_1 "Arguments") of *PFn*; c) invoke method *Perform()* for *PFn*. Resulting vertices *VPXk (k=1, 2… NbVPX)* and edges *ESXk (k=1, 2… NbESX)* are obtained via mapping between *VPk, ESk* and the results of *PVn*. | *BOPAlgo_PaveFiller::PostTreatFF()* | | 4 | Update face info (sections about pave blocks and vertices) | *BOPAlgo_PaveFiller::PerformFF()* | @@ -736,9 +736,9 @@ Building Part (BP) is used to * Provide history information (in terms of \::Generated(), \::Modified() and \::IsDeleted()) BP uses the DS prepared by *BOPAlgo_PaveFiller* described at chapter 5 as input data. BP is implemented in the following classes: -* *BOPAlgo_Builder* - for the General Fuse operator (GFA). -* *BOPAlgo_BOP* - for the Boolean Operation operator (BOA). -* *BOPAlgo_Section* - for the Section operator (SA). +* *BOPAlgo_Builder* -- for the General Fuse operator (GFA). +* *BOPAlgo_BOP* -- for the Boolean Operation operator (BOA). +* *BOPAlgo_Section* -- for the Section operator (SA). @figure{/user_guides/boolean_operations/images/operations_image020.svg, "Diagram for BP classes"} @@ -934,8 +934,8 @@ This step is the same as @ref occt_algorithms_7_4_4 "Building Result of Type Ver The input data for this step is: * *BOPAlgo_Builder* object after building result of type *Edge*; -* Original Shape - Wire -* *Type* - the shape type (TopAbs_WIRE). +* Original Shape -- Wire +* *Type* -- the shape type (TopAbs_WIRE). | No | Contents | Implementation | | :---- | :---- | :----- | @@ -981,8 +981,8 @@ This step is the same as @ref occt_algorithms_7_4_4 "Building Result of Type Ver @subsubsection occt_algorithms_7_4_11 Build Images for Shells The input data for this step is: * *BOPAlgo_Builder* object after building result of type face; -* *Original Shape* - Shell; -* *Type* - the type of the shape (TopAbs_SHELL). +* *Original Shape* -- a Shell; +* *Type* -- the type of the shape (TopAbs_SHELL). The procedure is the same as for building images for wires. @@ -1011,8 +1011,8 @@ This step is the same as @ref occt_algorithms_7_4_4 "Building Result of Type Ver The input data for this step is: * *BOPAlgo_Builder* object after building result of type solid; -* *Original Shape* - Compsolid; -* *Type* - the type of the shape (TopAbs_COMPSOLID). +* *Original Shape* -- a Compsolid; +* *Type* -- the type of the shape (TopAbs_COMPSOLID). The procedure is the same as for building images for wires. @@ -1021,9 +1021,9 @@ This step is the same as @ref occt_algorithms_7_4_4 "Building Result of Type Ver @subsubsection occt_algorithms_7_4_17 Build Images for Compounds The input data for this step is as follows: -* *BOPAlgo_Builder* object after building results of type compsolid; -* *Original Shape* - Compound; -* *Type* - the type of the shape (TopAbs_COMPOUND). +* *BOPAlgo_Builder* object after building results of type *compsolid*; +* *Original Shape* -- a Compound; +* *Type* -- the type of the shape (TopAbs_COMPOUND). The procedure is the same as for building images for wires. @@ -1845,7 +1845,7 @@ The chapter describes the problems that are considered as Algorithm limitations. A lot of failures of GFA algorithm can be caused by bugs in low-level algorithms: Intersection Algorithm, Projection Algorithm, Approximation Algorithm, Classification Algorithm, etc. * The Intersection, Projection and Approximation Algorithms are mostly used at the Intersection step. Their bugs directly cause wrong section results (i.e. incorrect section edges, section points, missing section edges or micro edges). It is not possible to obtain a correct final result of the GFA if a section result is wrong. -* The Projection Algorithm is used at the Intersection step. The purpose of Projection Algorithm is to compute 2D-curves on surfaces. Wrong results here lead to incorrect or missing faces in the final GFA result. +* The Projection Algorithm is used at the Intersection step. The purpose of Projection Algorithm is to compute 2D curves on surfaces. Wrong results here lead to incorrect or missing faces in the final GFA result. * The Classification Algorithm is used at the Building step. The bugs in the Classification Algorithm lead to errors in selecting shape parts (edges, faces, solids) and ultimately to a wrong final GFA result. The description below illustrates some known GFA limitations. It does not enumerate exhaustively all problems that can arise in practice. Please, address cases of Algorithm failure to the OCCT Maintenance Service. @@ -1863,11 +1863,11 @@ However, it is important to note that class *BRepCheck_Analyzer* is just a tool Let us consider the following example: -The Analyzer checks distances between couples of 3D check-points (Pi, PSi) of edge *E* on face *F*. Point *Pi* is obtained from the 3D-curve (at the parameter *ti*) of the edge. *PSi* is obtained from 2D-curve (at the parameter *ti*) of the edge on surface *S* of face *F*. To be valid the distance should be less than *Tol(E)* for all couples of check-points. The number of these check-points is a pre-defined value (e.g. 23). +The Analyzer checks distances between couples of 3D check-points (Pi, PSi) of edge *E* on face *F*. Point *Pi* is obtained from the 3D curve (at the parameter *ti*) of the edge. *PSi* is obtained from 2D curve (at the parameter *ti*) of the edge on surface *S* of face *F*. To be valid the distance should be less than *Tol(E)* for all couples of check-points. The number of these check-points is a predefined value (e.g. 23). Let us consider the case when edge *E* is recognized valid (in terms of *BRepCheck_Analyzer*). -Further, after some operation, edge *E* is split into two edges *E1* and *E2*. Each split edge has the same 3D-curve and 2D-curve as the original edge *E*. +Further, after some operation, edge *E* is split into two edges *E1* and *E2*. Each split edge has the same 3D curve and 2D curve as the original edge *E*. Let us check *E1* (or E2). The Analyzer again checks the distances between the couples of check-points points (Pi, PSi). The number of these check-points is the same constant value (23), but there is no guarantee that the distances will be less than *Tol(E)*, because the points chosen for *E1* are not the same as for *E*. @@ -2071,7 +2071,7 @@ The Fuzzy option is useful on the shapes with gaps or embeddings between the ent Most likely, the Basic Operations will give unsatisfactory results on such models. The result may contain unexpected and unwanted small entities, faulty entities (in terms of *BRepCheck_Analyzer*), or there can be no result at all. -With the Fuzzy option it is possible to get the expected result - it is just necessary to define the appropriate value of fuzzy tolerance for the operation. To define that value it is necessary to measure the value of the gap (or the value of embedding depth) between the entities of the models, slightly increase it (to make the shifted entities coincident in terms of their tolerance plus the additional one) and pass it to the algorithm. +With the Fuzzy option it is possible to get the expected result -- it is just necessary to define the appropriate value of fuzzy tolerance for the operation. To define that value it is necessary to measure the value of the gap (or the value of embedding depth) between the entities of the models, slightly increase it (to make the shifted entities coincident in terms of their tolerance plus the additional one) and pass it to the algorithm. Fuzzy option is included in interface of Intersection Part (class *BOPAlgo_PaveFiller*) and application programming interface (class *BRepAlgoAPI_BooleanOperation*) @@ -2143,13 +2143,13 @@ The chapter contains some examples of the OCCT Boolean Component usage. The usag The package *BRepAlgoAPI* provides the Application Programming Interface of the Boolean Component. The package consists of the following classes: -* *BRepAlgoAPI_Algo* – the root class that provides the interface for algorithms. -* *BRepAlgoAPI_BuilderAlgo* - the class API level of General Fuse algorithm. -* *BRepAlgoAPI_BooleanOperation* – the root class for the classes *BRepAlgoAPI_Fuse*. *BRepAlgoAPI_Common*, *BRepAlgoAPI_Cut* and *BRepAlgoAPI_Section*. -* *BRepAlgoAPI_Fuse* – the class provides Boolean fusion operation. -* *BRepAlgoAPI_Common* - the class provides Boolean common operation. -* *BRepAlgoAPI_Cut* - the class provides Boolean cut operation. -* *BRepAlgoAPI_Section* - the class provides Boolean section operation. +* *BRepAlgoAPI_Algo* -- the root class that provides the interface for algorithms. +* *BRepAlgoAPI_BuilderAlgo* -- the class API level of General Fuse algorithm. +* *BRepAlgoAPI_BooleanOperation* -- the root class for the classes *BRepAlgoAPI_Fuse*. *BRepAlgoAPI_Common*, *BRepAlgoAPI_Cut* and *BRepAlgoAPI_Section*. +* *BRepAlgoAPI_Fuse* -- the class provides Boolean fusion operation. +* *BRepAlgoAPI_Common* -- the class provides Boolean common operation. +* *BRepAlgoAPI_Cut* -- the class provides Boolean cut operation. +* *BRepAlgoAPI_Section* -- the class provides Boolean section operation. @figure{/user_guides/boolean_operations/images/operations_image065.svg, "Diagram of BRepAlgoAPI package"} @@ -2158,8 +2158,8 @@ The detailed description of the classes can be found in corresponding .cdl files @subsection occt_algorithms_11b_2 Package BOPTest The package *BOPTest* provides the usage of the Boolean Component on Tcl level. The method *BOPTest::APICommands* contains corresponding Tcl commands: -* *bapibuild* – for General Fuse Operator; -* *bapibop* – for Boolean Operator and Section Operator. +* *bapibuild* -- for General Fuse Operator; +* *bapibop* -- for Boolean Operator and Section Operator. The examples of how to use the commands are below in this chapter. diff --git a/dox/user_guides/brep_wp/brep_wp.md b/dox/user_guides/brep_wp/brep_wp.md index d0618d10ef..47a07c0d8c 100644 --- a/dox/user_guides/brep_wp/brep_wp.md +++ b/dox/user_guides/brep_wp/brep_wp.md @@ -121,13 +121,13 @@ Q\cdot(x\;y\;z\;1)^{T} = *Q* may be a composition of matrices for the following elementary transformations: - * parallel translation – + * parallel translation -- @f$ \begin{pmatrix} 1 &0 &0 &{q}_{1,4}\\ 0 &1 &0 &{q}_{2,4}\\ 0 &0 &1 &{q}_{3,4} \end{pmatrix}; @f$ - * rotation around an axis with a direction *D(Dx, Dy, Dz)* by an angle @f$ \varphi @f$ – + * rotation around an axis with a direction *D(Dx, Dy, Dz)* by an angle @f$ \varphi @f$ -- @f[ \begin{pmatrix} D_{x}^{2} \cdot (1-cos(\varphi)) + cos(\varphi) &D_{x} \cdot D_{y} \cdot (1-cos(\varphi)) - D_{z} \cdot sin(\varphi) &D_{x} \cdot D_{z} \cdot (1-cos(\varphi)) + D_{y} \cdot sin(\varphi) &0\\ @@ -135,10 +135,10 @@ Q\cdot(x\;y\;z\;1)^{T} = D_{x} \cdot D_{z} \cdot (1-cos(\varphi)) - D_{y} \cdot sin(\varphi) &D_{y} \cdot D_{z} \cdot (1-cos(\varphi)) + D_{x} \cdot sin(\varphi) &D_{z}^{2} \cdot (1-cos(\varphi)) + cos(\varphi) &0 \end{pmatrix}; @f] - * scaling – @f$ \begin{pmatrix} s &0 &0 &0\\ 0 &s &0 &0\\ 0 &0 &s &0 \end{pmatrix} @f$ where @f$ S \in (-\infty,\; \infty)/\left \{ 0 \right \}; @f$ - * central symmetry – @f$ \begin{pmatrix} -1 &0 &0 &0\\ 0 &-1 &0 &0\\ 0 &0 &-1 &0 \end{pmatrix}; @f$ - * axis symmetry – @f$ \begin{pmatrix} -1 &0 &0 &0\\ 0 &-1 &0 &0\\ 0 &0 &1 &0 \end{pmatrix}; @f$ - * plane symmetry – @f$ \begin{pmatrix} 1 &0 &0 &0\\ 0 &1 &0 &0\\ 0 &0 &-1 &0 \end{pmatrix}. @f$ + * scaling -- @f$ \begin{pmatrix} s &0 &0 &0\\ 0 &s &0 &0\\ 0 &0 &s &0 \end{pmatrix} @f$ where @f$ S \in (-\infty,\; \infty)/\left \{ 0 \right \}; @f$ + * central symmetry -- @f$ \begin{pmatrix} -1 &0 &0 &0\\ 0 &-1 &0 &0\\ 0 &0 &-1 &0 \end{pmatrix}; @f$ + * axis symmetry -- @f$ \begin{pmatrix} -1 &0 &0 &0\\ 0 &-1 &0 &0\\ 0 &0 &1 &0 \end{pmatrix}; @f$ + * plane symmetry -- @f$ \begin{pmatrix} 1 &0 &0 &0\\ 0 &1 &0 &0\\ 0 &0 &-1 &0 \end{pmatrix}. @f$ \ is interpreted as a composition of locations raised to a power and placed above this \ in the section \. \ is a sequence @f$l_{1}p_{1} ... l_{n}p_{n}@f$ of @f$ n \geq 0 @f$ integer pairs @f$ l_{i}p_{i} \; (1 \leq i \leq n) @f$. \ 0 is the indicator of the sequence end. The sequence is interpreted as a composition @f$ L_{l_{1}}^{p_{1}} \cdot ... \cdot L_{l_{n}}^{p_{n}} @f$ where @f$ L_{l_{i}} @f$ is a location from @f$ l_{i} @f$-th \ in the section locations. \ numbering starts from 1. @@ -1621,22 +1621,22 @@ An example of section shapes and a whole *.brep file are given in chapter 7 @re \ @f$ f_{1}\; f_{2}\; f_{3}\; f_{4}\; f_{5}\; f_{6}\; f_{7} @f$ \s @f$ f_{i}\;(1\leq i \leq 7) @f$ are interpreted as shape flags in the following way: - * @f$ f_{1} @f$ – free; - * @f$ f_{2} @f$ – modified; - * @f$ f_{3} @f$ – IGNORED(version 1) \\ checked (version 2); - * @f$ f_{4} @f$ – orientable; - * @f$ f_{5} @f$ – closed; - * @f$ f_{6} @f$ – infinite; - * @f$ f_{7} @f$ – convex. + * @f$ f_{1} @f$ -- free; + * @f$ f_{2} @f$ -- modified; + * @f$ f_{3} @f$ -- IGNORED(version 1) \\ checked (version 2); + * @f$ f_{4} @f$ -- orientable; + * @f$ f_{5} @f$ -- closed; + * @f$ f_{6} @f$ -- infinite; + * @f$ f_{7} @f$ -- convex. The flags are used in a special way [1]. \ is interpreted in the following way: - * + – forward; - * - – reversed; - * i – internal; - * e – external. + * + -- forward; + * - -- reversed; + * i -- internal; + * e -- external. \ is used in a special way [1]. @@ -1644,14 +1644,14 @@ The flags are used in a special way [1]. \ types are interpreted in the following way: - * "Ve" – vertex; - * "Ed" – edge; - * "Wi" – wire; - * "Fa" – face; - * "Sh" – shell; - * "So" – solid; - * "CS" – compsolid; - * "Co" – compound. + * "Ve" -- vertex; + * "Ed" -- edge; + * "Wi" -- wire; + * "Fa" -- face; + * "Sh" -- shell; + * "So" -- solid; + * "CS" -- compsolid; + * "Co" -- compound. \ determines the orientation and location for the whole model. diff --git a/dox/user_guides/draw_test_harness/draw_test_harness.md b/dox/user_guides/draw_test_harness/draw_test_harness.md index 54782ca0a0..632d066e42 100644 --- a/dox/user_guides/draw_test_harness/draw_test_harness.md +++ b/dox/user_guides/draw_test_harness/draw_test_harness.md @@ -72,7 +72,7 @@ Declaration of available plug-ins is done through the special resource file(s). @subsubsection occt_draw_1_3_1 Launching DRAW Test Harness -Test Harness executable *DRAWEXE* is located in the $CASROOT/\/bin directory (where \ is Win for Windows and Linux for Linux operating systems). Prior to launching it is important to make sure that the environment is correctly set-up (usually this is done automatically after the installation process on Windows or after launching specific scripts on Linux). +Test Harness executable *DRAWEXE* is located in the $CASROOT/\/bin directory (where \ is Win for Windows and Linux for Linux operating systems). Prior to launching it is important to make sure that the environment is correctly setup (usually this is done automatically after the installation process on Windows or after launching specific scripts on Linux). @subsubsection occt_draw_1_3_2 Plug-in resource file @@ -103,8 +103,8 @@ pload [-PluginFileName] [[Key1] [Key2]...] where: -* -PluginFileName - defines the name of a plug-in resource file (prefix "-" is mandatory) described above. If this parameter is omitted then the default name *DrawPlugin* is used. -* *Key…* - defines the key(s) enumerating plug-ins to be loaded. If no keys are specified then the key named *DEFAULT* is used (if there is no such key in the file then no plug-ins are loaded). +* -PluginFileName -- defines the name of a plug-in resource file (prefix "-" is mandatory) described above. If this parameter is omitted then the default name *DrawPlugin* is used. +* *Key* -- defines the key(s) enumerating plug-ins to be loaded. If no keys are specified then the key named *DEFAULT* is used (if there is no such key in the file then no plug-ins are loaded). According to the OCCT resource file management rules, to access the resource file the environment variable *CSF_PluginFileNameDefaults* (and optionally *CSF_PluginFileNameUserDefaults*) must be set and point to the directory storing the resource file. If it is omitted then the plug-in resource file will be searched in the $CASROOT/src/DrawResources directory. @@ -850,7 +850,7 @@ TopoDS_Solid B = DBRep::Get(argv[1]); @section occt_draw_4 Graphic Commands -Graphic commands are used to manage the Draw graphic system. Draw provides a 2d and a 3d viewer with up to 30 views. Views are numbered and the index of the view is displayed in the window’s title. Objects are displayed in all 2d views or in all 3d views, depending on their type. 2d objects can only be viewed in 2d views while 3d objects – only in 3d views correspondingly. +Graphic commands are used to manage the Draw graphic system. Draw provides a 2d and a 3d viewer with up to 30 views. Views are numbered and the index of the view is displayed in the window’s title. Objects are displayed in all 2d views or in all 3d views, depending on their type. 2d objects can only be viewed in 2d views while 3d objects -- only in 3d views correspondingly. @subsection occt_draw_4_1 Axonometric viewer @@ -1274,7 +1274,7 @@ Graphic operations are buffered by Draw (and also by the X system). Usually the See also: @ref occt_draw_4_1_11 "pick" command. -@subsection occt_draw_4_2 AIS viewer – view commands +@subsection occt_draw_4_2 AIS viewer -- view commands @subsubsection occt_draw_4_2_1 vinit @@ -1544,13 +1544,13 @@ vstereo [0|1] [-mode Mode] [-reverse {0|1}] [-anaglyph Filter] Control stereo output mode. Available modes for -mode: - * quadBuffer - OpenGL QuadBuffer stereo, requires driver support. Should be called BEFORE vinit! - * anaglyph - Anaglyph glasses - * rowInterlaced - row-interlaced display - * columnInterlaced - column-interlaced display - * chessBoard - chess-board output - * sideBySide - horizontal pair - * overUnder - vertical pair + * quadBuffer -- OpenGL QuadBuffer stereo, requires driver support. Should be called BEFORE vinit! + * anaglyph -- Anaglyph glasses + * rowInterlaced -- row-interlaced display + * columnInterlaced -- column-interlaced display + * chessBoard -- chess-board output + * sideBySide -- horizontal pair + * overUnder -- vertical pair Available Anaglyph filters for -anaglyph: * redCyan, redCyanSimple, yellowBlue, yellowBlueSimple, greenMagentaSimple @@ -1576,7 +1576,7 @@ vfrustumculling [toEnable] Enables/disables objects clipping. -@subsection occt_draw_4_3 AIS viewer – display commands +@subsection occt_draw_4_3 AIS viewer -- display commands @subsubsection occt_draw_4_3_1 vdisplay @@ -1607,7 +1607,7 @@ Local selection context will be opened if there is not any. * *trsfPersPos* sets an anchor point for transform persistence. * *2d|-2dTopDown* displays object in screen coordinates. * *dispmode* sets display mode for objects. -* *highmode* sets hilight mode for objects. +* *highmode* sets highlight mode for objects. * *redisplay* recomputes presentation of objects. **Example:** @@ -1776,7 +1776,7 @@ vaspects [-noupdate|-update] [name1 [name2 [...]] | -defaults] Manage presentation properties of all, selected or named objects. When *-subshapes* is specified than following properties will be assigned to specified sub-shapes. When *-defaults* is specified than presentation properties will be assigned to all objects that have not their own specified properties and to all objects to be displayed in the future. -If *-defaults* is used there should not be any objects' names and -subshapes specifier. +If *-defaults* is used there should not be any names of objects and *-subshapes* specifier. Aliases: ~~~~~ @@ -2009,8 +2009,8 @@ vstate [-entities] [-hasSelected] [name1] ... [nameN] ~~~~~ Reports show/hidden state for selected or named objects - * *entities* - print low-level information about detected entities - * *hasSelected* - prints 1 if context has selected shape and 0 otherwise + * *entities* -- prints low-level information about detected entities; + * *hasSelected* -- prints 1 if the context has a selected shape and 0 otherwise. @subsubsection occt_draw_4_3_25 vraytrace @@ -2032,17 +2032,17 @@ vrenderparams [-rayTrace|-raster] [-rayDepth 0..10] [-shadows {on|off}] ~~~~~ Manages rendering parameters: -* rayTrace - Enables GPU ray-tracing -* raster - Disables GPU ray-tracing -* rayDepth - Defines maximum ray-tracing depth -* shadows - Enables/disables shadows rendering -* reflections - Enables/disables specular reflections -* fsaa - Enables/disables adaptive anti-aliasing -* gleam - Enables/disables transparency shadow effects -* gi - Enables/disables global illumination effects -* brng - Enables/disables blocked RNG (fast coherent PT) -* env - Enables/disables environment map background -* shadingModel - Controls shading model from enumeration color, flat, gouraud, phong +* rayTrace -- Enables GPU ray-tracing +* raster -- Disables GPU ray-tracing +* rayDepth -- Defines maximum ray-tracing depth +* shadows -- Enables/disables shadows rendering +* reflections -- Enables/disables specular reflections +* fsaa -- Enables/disables adaptive anti-aliasing +* gleam -- Enables/disables transparency shadow effects +* gi -- Enables/disables global illumination effects +* brng -- Enables/disables blocked RNG (fast coherent PT) +* env -- Enables/disables environment map background +* shadingModel -- Controls shading model from enumeration color, flat, gouraud, phong Unlike vcaps, these parameters dramatically change visual properties. Command is intended to control presentation quality depending on hardware capabilities and performance. @@ -2082,7 +2082,7 @@ vinit vsetcolorbg 200 0 200 ~~~~~ -@subsection occt_draw_4_4 AIS viewer – object commands +@subsection occt_draw_4_4 AIS viewer -- object commands @subsubsection occt_draw_4_4_1 vtrihedron @@ -2186,8 +2186,8 @@ vplane name [PlaneName] [PointName] Creates a plane from named or interactively selected entities. TypeOfSensitivity: - * 0 - Interior - * 1 - Boundary + * 0 -- Interior + * 1 -- Boundary **Example:** ~~~~~ @@ -2275,15 +2275,15 @@ vselmode [object] mode_number is_turned_on=(1|0) Sets the selection mode for an object. If the object value is not defined, the selection mode is set for all displayed objects. *Mode_number* is non-negative integer that has different meaning for different interactive object classes. For shapes the following *mode_number* values are allowed: - * 0 - shape - * 1 - vertex - * 2 - edge - * 3 - wire - * 4 - face - * 5 - shell - * 6 - solid - * 7 - compsolid - * 8 - compound + * 0 -- shape + * 1 -- vertex + * 2 -- edge + * 3 -- wire + * 4 -- face + * 5 -- shell + * 6 -- solid + * 7 -- compsolid + * 8 -- compound *is_turned_on* is: * 1 if mode is to be switched on * 0 if mode is to be switched off @@ -2361,18 +2361,18 @@ vpointcloud name shape [-randColor] [-normals] [-noNormals] Creates an interactive object for an arbitary set of points from the triangulated shape. Additional options: - * *randColor* - generate random color per point - * *normals* - generate normal per point (default) - * *noNormals* - do not generate normal per point + * *randColor* -- generate random color per point + * *normals* -- generate normal per point (default) + * *noNormals* -- do not generate normal per point ~~~~~ vpointcloud name x y z r npts {surface|volume} [-randColor] [-normals] [-noNormals] ~~~~~ Creates an arbitrary set of points (npts) randomly distributed on a spheric surface or within a spheric volume (x y z r). Additional options: - * *randColor* - generate random color per point - * *normals* - generate normal per point (default) - * *noNormals* - do not generate normal per point + * *randColor* -- generate random color per point + * *normals* -- generate normal per point (default) + * *noNormals* -- do not generate normal per point **Example:** ~~~~~ @@ -2385,21 +2385,21 @@ vfit Syntax: ~~~~~ -vclipplane maxplanes - gets plane limit for the view. -vclipplane create - creates a new plane. -vclipplane delete - delete a plane. -vclipplane clone - clones the plane definition. -vclipplane set/unset object - sets/unsets the plane for an IO. -vclipplane set/unset view - sets/unsets plane for a view. -vclipplane change on/off - turns clipping on/off. -vclipplane change equation - changes plane equation. -vclipplane change capping on/off - turns capping on/off. -vclipplane change capping color - sets color. -vclipplane change capping texname - sets texture. -vclipplane change capping texscale - sets texture scale. -vclipplane change capping texorigin - sets texture origin. -vclipplane change capping texrotate - sets texture rotation. -vclipplane change capping hatch on/off/ - sets hatching mask. +vclipplane maxplanes -- gets plane limit for the view. +vclipplane create -- creates a new plane. +vclipplane delete -- deletes a plane. +vclipplane clone -- clones the plane definition. +vclipplane set/unset object -- sets/unsets the plane for an IO. +vclipplane set/unset view -- sets/unsets plane for a view. +vclipplane change on/off -- turns clipping on/off. +vclipplane change equation -- changes plane equation. +vclipplane change capping on/off -- turns capping on/off. +vclipplane change capping color -- sets color. +vclipplane change capping texname -- sets texture. +vclipplane change capping texscale -- sets texture scale. +vclipplane change capping texorigin -- sets texture origin. +vclipplane change capping texrotate -- sets texture rotation. +vclipplane change capping hatch on/off/ -- sets hatching mask. ~~~~~ Manages clipping planes @@ -2498,7 +2498,7 @@ vmovedim dim1 -10 30 0 ~~~~~ -@subsection occt_draw_4_5 AIS viewer – Mesh Visualization Service +@subsection occt_draw_4_5 AIS viewer -- Mesh Visualization Service **MeshVS** (Mesh Visualization Service) component provides flexible means of displaying meshes with associated pre- and post- processor data. @@ -2543,10 +2543,10 @@ meshselmode meshname selectionmode ~~~~~ Changes the selection mode of object **meshname**. The *selectionmode* is integer OR-combination of mode flags. The basic flags are the following: -* *1* – node selection; -* *2* – 0D elements (not supported in STL); -* *4* – links (not supported in STL); -* *8* – faces. +* *1* -- node selection; +* *2* -- 0D elements (not supported in STL); +* *4* -- links (not supported in STL); +* *8* -- faces. **Example:** ~~~~~ @@ -2597,27 +2597,27 @@ meshmat meshname material Changes the material of object **meshname**. *material* is represented with an integer value as follows (equivalent to enumeration *Graphic3d_NameOfMaterial*): -* *0 - BRASS,* -* *1 - BRONZE,* -* *2 - COPPER,* -* *3 - GOLD,* -* *4 - PEWTER,* -* *5 - PLASTER,* -* *6 - PLASTIC,* -* *7 - SILVER,* -* *8 - STEEL,* -* *9 - STONE,* -* *10 - SHINY_PLASTIC,* -* *11 - SATIN,* -* *12 - METALIZED,* -* *13 - NEON_GNC,* -* *14 - CHROME,* -* *15 - ALUMINIUM,* -* *16 - OBSIDIAN,* -* *17 - NEON_PHC,* -* *18 - JADE,* -* *19 - DEFAULT,* -* *20 - UserDefined* +* *0 -- BRASS,* +* *1 -- BRONZE,* +* *2 -- COPPER,* +* *3 -- GOLD,* +* *4 -- PEWTER,* +* *5 -- PLASTER,* +* *6 -- PLASTIC,* +* *7 -- SILVER,* +* *8 -- STEEL,* +* *9 -- STONE,* +* *10 -- SHINY_PLASTIC,* +* *11 -- SATIN,* +* *12 -- METALIZED,* +* *13 -- NEON_GNC,* +* *14 -- CHROME,* +* *15 -- ALUMINIUM,* +* *16 -- OBSIDIAN,* +* *17 -- NEON_PHC,* +* *18 -- JADE,* +* *19 -- DEFAULT,* +* *20 -- UserDefined* **Example:** ~~~~~ @@ -2949,7 +2949,7 @@ Syntax: IsInSession path ~~~~~ -Returns *0*, if **path** document is managed by the application session, *1* – otherwise. +Returns *0*, if **path** document is managed by the application session, *1* -- otherwise. **Example:** ~~~~~ @@ -3183,7 +3183,7 @@ Syntax: NewCommand docname ~~~~~ -This is a short-cut for Commit and Open transaction. +This is a shortcut for Commit and Open transaction. **Example:** ~~~~~ @@ -3765,7 +3765,7 @@ Finds or creates a Plane attribute at *entry* label and sets *plane* as generate **Example:** ~~~~~ -plane pl 10 20 30 –1 0 0 +plane pl 10 20 30 -1 0 0 SetPlane D 0:2 pl ~~~~~ @@ -4695,7 +4695,7 @@ Syntax: ~~~~~ cone name [x y z [dx dy dz [ux uy uz]]] semi-angle radius ~~~~~ -Creates a cone in the infinite coordinate system along the Z-axis. The radius is that of the circle at the intersection of the cone and the XY plane. The semi-angle is the angle formed by the cone relative to the axis; it should be between –90 and 90. If the radius is 0, the vertex is the origin. +Creates a cone in the infinite coordinate system along the Z-axis. The radius is that of the circle at the intersection of the cone and the XY plane. The semi-angle is the angle formed by the cone relative to the axis; it should be between -90 and 90. If the radius is 0, the vertex is the origin. **Example:** ~~~~~ @@ -5765,11 +5765,11 @@ normals s (length = 10), disp normals range name value value ~~~~~ -* **orientation** assigns the orientation of shapes - simple and complex - to one of the following four values: *FORWARD, REVERSED, INTERNAL, EXTERNAL*. -* **complement** changes the current orientation of shapes to its complement, *FORWARD - REVERSED, INTERNAL - EXTERNAL*. -* **invert** creates a new shape which is a copy of the original with the orientation all subshapes reversed. For example, it may be useful to reverse the normals of a solid. -* *normals** returns the assignment of colors to orientation values. -* **range** defines the length of a selected edge by defining the values of a starting point and an end point. +* **orientation** -- assigns the orientation of simple and complex shapes to one of the following four values: *FORWARD, REVERSED, INTERNAL, EXTERNAL*. +* **complement** -- changes the current orientation of shapes to its complement: *FORWARD* to *REVERSED* and *INTERNAL* to *EXTERNAL*. +* **invert** -- creates a copy of the original shape with a reversed orientation of all subshapes. For example, it may be useful to reverse the normals of a solid. +* *normals** -- returns the assignment of colors to orientation values. +* **range** -- defines the length of a selected edge by defining the values of a starting point and an end point. **Example:** ~~~~~ @@ -5851,7 +5851,7 @@ add name toname compound [name ...] compoundname ~~~~~ -**emptycopy** returns an empty shape with the same orientation, location, and geometry as the target shape, but with no sub-shapes. If the newname argument is not given, the new shape is stored with the same name. This command is used to modify a frozen shape. A frozen shape is a shape used by another one. To modify it, you must emptycopy it. Its subshape may be reinserted with the **add** command. +**emptycopy** returns an empty shape with the same orientation, location, and geometry as the target shape, but with no sub-shapes. If the **newname** argument is not given, the new shape is stored with the same name. This command is used to modify a frozen shape. A frozen shape is a shape used by another one. To modify it, you must **emptycopy** it. Its subshape may be reinserted with the **add** command. **add** inserts shape *C* into shape *S*. Verify that *C* and *S* reference compatible types of objects: * Any *Shape* can be added to a *Compound*. @@ -5884,10 +5884,10 @@ checkshape [-top] shape [result] [-short] ~~~~~ Where: -* *top* – optional parameter, which allows checking only topological validity of a shape. -* *shape*– the only required parameter which represents the name of the shape to check. -* *result* – optional parameter which is the prefix of the output shape names. -* *short* – a short description of the check. +* *top* -- optional parameter, which allows checking only topological validity of a shape. +* *shape* -- the only required parameter which represents the name of the shape to check. +* *result* -- optional parameter which is the prefix of the output shape names. +* *short* -- a short description of the check. **checkshape** examines the selected object for topological and geometric coherence. The object should be a three dimensional shape. @@ -6385,7 +6385,7 @@ All these commands create solid blocks in the default coordinate system, using t **psphere** creates a solid sphere centered on the origin. If two angles, *angle1* and *angle2*, are given, the solid will be limited by two planes at latitude *angle1* and *angle2*. The angles must be increasing and in the range -90,90. -**ptorus** creates a solid torus with the given radii, centered on the origin, which is a point along the z axis. If two angles increasing in degree in the range 0 – 360 are given, the solid will be bounded by two planar surfaces at those positions on the circle. +**ptorus** creates a solid torus with the given radii, centered on the origin, which is a point along the z axis. If two angles increasing in degree in the range 0 -- 360 are given, the solid will be bounded by two planar surfaces at those positions on the circle. **Example:** ~~~~~ @@ -6424,11 +6424,11 @@ halfspace hr b_3 0.5 0.5 0.5 Sweeping creates shapes by sweeping out a shape along a defined path: - * **prism** sweeps along a direction. - * **revol** sweeps around an axis. - * **pipe** sweeps along a wire. - * **mksweep** and **buildsweep** are commands to create sweeps by defining the arguments and algorithms. - * **thrusections** creates a sweep from wire in different planes. + * **prism** -- sweeps along a direction. + * **revol** -- sweeps around an axis. + * **pipe** -- sweeps along a wire. + * **mksweep** and **buildsweep** -- to create sweeps by defining the arguments and algorithms. + * **thrusections** -- creates a sweep from wire in different planes. @subsubsection occt_draw_7_4_1 prism @@ -6511,12 +6511,12 @@ options are : * *-G guide* These commands are used to create a shape from wires. One wire is designated as the contour that defines the direction; it is called the spine. At least one other wire is used to define the the sweep profile. -* **mksweep** initializes the sweep creation and defines the wire to be used as the spine. -* **addsweep** defines the wire to be used as the profile. -* **deletesweep** cancels the choice of profile wire, without leaving the mksweep mode. You can re-select a profile wire. -* **setsweep** commands the algorithms used for the construction of the sweep. -* **simulsweep** can be used to create a preview of the shape. [n] is the number of sections that are used to simulate the sweep. -* **buildsweep** creates the sweep using the arguments defined by all the commands. +* **mksweep** -- initializes the sweep creation and defines the wire to be used as the spine. +* **addsweep** -- defines the wire to be used as the profile. +* **deletesweep** -- cancels the choice of profile wire, without leaving the mksweep mode. You can re-select a profile wire. +* **setsweep** -- commands the algorithms used for the construction of the sweep. +* **simulsweep** -- can be used to create a preview of the shape. [n] is the number of sections that are used to simulate the sweep. +* **buildsweep** -- creates the sweep using the arguments defined by all the commands. **Example:** ~~~~~ @@ -6568,9 +6568,9 @@ Tolerances obtenues -- 3d : 0 Transformations are applications of matrices. When the transformation is nondeforming, such as translation or rotation, the object is not copied. The topology localcoordinate system feature is used. The copy can be enforced with the **tcopy** command. - * **tcopy** makes a copy of the structure of a shape. - * **ttranslate**, **trotate**, **tmove**, **reset** move a shape. - * **tmirror**, **tscale** always modify the shape. + * **tcopy** -- makes a copy of the structure of a shape. + * **ttranslate**, **trotate**, **tmove** and **reset** -- move a shape. + * **tmirror** and **tscale** -- always modify the shape. @subsubsection occt_draw_7_5_1 tcopy @@ -6875,19 +6875,19 @@ bop shape1 shape2 bopsection result ~~~~~ -* **bopsection** creates a compound object consisting of the edges for the intersection curves on the faces of two shapes. -* **bop** fills data structure (DS) of boolean operation for *shape1* and *shape2*. -* **bopsection** command used after **bop** command. +* **bopsection** -- creates a compound object consisting of the edges for the intersection curves on the faces of two shapes. +* **bop** -- fills data structure (DS) of boolean operation for *shape1* and *shape2*. +* **bopsection** -- is used after **bop** command. Short variant syntax: ~~~~~ bsection result shape1 shape2 [-2d/-2d1/-2s2] [-a] ~~~~~ -* -2d - PCurves are computed on both parts. -* -2d1 - PCurves are computed on first part. -* -2d2 - PCurves are computed on second part. -* -a - built geometries are approximated. +* -2d -- PCurves are computed on both parts. +* -2d1 -- PCurves are computed on first part. +* -2d2 -- PCurves are computed on second part. +* -a -- built geometries are approximated. **Example:** @@ -6914,15 +6914,15 @@ bopargcheck shape1 [[shape2] [-F/O/C/T/S/U] [/R|F|T|V|E|I|P]] [#BF] **bopargcheck** checks the validity of argument(s) for boolean operations. -* Boolean Operation - (by default a section is made) : +* Boolean Operation -- (by default a section is made) : * **F** (fuse) * **O** (common) * **C** (cut) * **T** (cut21) * **S** (section) * **U** (unknown) -* Test Options - (by default all options are enabled) : - * **R** (disable small edges (shrank range) test) +* Test Options -- (by default all options are enabled) : + * **R** (disable small edges (shrink range) test) * **F** (disable faces verification test) * **T** (disable tangent faces searching test) * **V** (disable test possibility to merge vertices) @@ -6930,8 +6930,8 @@ bopargcheck shape1 [[shape2] [-F/O/C/T/S/U] [/R|F|T|V|E|I|P]] [#BF] * **I** (disable self-interference test) * **P** (disable shape type test) * Additional Test Options : - * **B** (stop test on first faulty found) - by default it is off; - * **F** (full output for faulty shapes) - by default the output is made in a short format. + * **B** (stop test on first faulty found) -- by default it is off; + * **F** (full output for faulty shapes) -- by default the output is made in a short format. **Note** that Boolean Operation and Test Options are used only for a couple of argument shapes, except for I and P options that are always used to test a couple of shapes as well as a single shape. @@ -7252,11 +7252,11 @@ xdistc2dc2dss curve2d_1 curve2d_2 surface_1 surface_2 startParam finishParam [Nu It is assumed that curves have the same parametrization range and *startParam* is less than *finishParam*. Commands with prefix *xdist* allow checking the distance between two objects on even grid: - * **xdistef** - distance between edge and face; - * **xdistcs** - distance between curve and surface. This means that the projection of each sample point to the surface is computed; - * **xdistcc** - distance between two 3D curves; - * **xdistcc2ds** - distance between 3d curve and 2d curve on surface; - * **xdistc2dc2dss** - distance between two 2d curves on surface. + * **xdistef** -- distance between edge and face; + * **xdistcs** -- distance between curve and surface. This means that the projection of each sample point to the surface is computed; + * **xdistcc** -- distance between two 3D curves; + * **xdistcc2ds** -- distance between 3d curve and 2d curve on surface; + * **xdistc2dc2dss** -- distance between two 2d curves on surface. **Examples** ~~~~~ @@ -7693,21 +7693,21 @@ See @ref occt_user_guides__boolean_operations "Boolean operations" user's guide @subsection occt_draw_20_1 Definitions The following terms and definitions are used in this document: -* **Objects** – list of shapes that are arguments of the algorithm. -* **Tools** – list of shapes that are arguments of the algorithm. Difference between Objects and Tools is defined by specific requirements of the operations (Boolean Operations, Partition Operation). -* **DS** – internal data structure used by the algorithm (*BOPDS_DS* object). -* **PaveFiller** – intersection part of the algorithm (*BOPAlgo_PaveFiller* object). -* **Builder** – builder part of the algorithm (*BOPAlgo_Builder* object). -* **IDS Index** – the index of the vector *myLines*. +* **Objects** -- list of shapes that are arguments of the algorithm. +* **Tools** -- list of shapes that are arguments of the algorithm. Difference between Objects and Tools is defined by specific requirements of the operations (Boolean Operations, Partition Operation). +* **DS** -- internal data structure used by the algorithm (*BOPDS_DS* object). +* **PaveFiller** -- intersection part of the algorithm (*BOPAlgo_PaveFiller* object). +* **Builder** -- builder part of the algorithm (*BOPAlgo_Builder* object). +* **IDS Index** -- the index of the vector *myLines*. @subsection occt_draw_20_2 General commands -* **bclearobjects** - clears the list of Objects; -* **bcleartools** - clears the list of Tools; -* **baddobjects** *S1 S2...Sn* - adds shapes *S1, S2, ... Sn* as Objects; -* **baddtools** *S1 S2...Sn* - adds shapes *S1, S2, ... Sn* as Tools; -* **bfillds** - performs the Intersection Part of the Algorithm; -* **bbuild** *r* - performs the Building Part of the Algorithm; *r* is the resulting shape. +* **bclearobjects** -- clears the list of Objects; +* **bcleartools** -- clears the list of Tools; +* **baddobjects** *S1 S2...Sn* -- adds shapes *S1, S2, ... Sn* as Objects; +* **baddtools** *S1 S2...Sn* -- adds shapes *S1, S2, ... Sn* as Tools; +* **bfillds** -- performs the Intersection Part of the Algorithm; +* **bbuild** *r* -- performs the Building Part of the Algorithm; *r* is the resulting shape. @subsection occt_draw_20_3 Commands for Intersection Part @@ -7717,14 +7717,14 @@ All commands listed below are available when the Intersection Part of the algor Syntax: ~~~~ -bopds –v [e, f] +bopds -v [e, f] ~~~~ Displays: * all BRep shapes of arguments that are in the DS [default]; -* –v : only vertices of arguments that are in the DS; -* –e : only edges of arguments that are in the DS; -* –f : only faces of arguments that are in the DS. +* -v : only vertices of arguments that are in the DS; +* -e : only edges of arguments that are in the DS; +* -f : only faces of arguments that are in the DS. @subsubsection occt_draw_20_3_2 bopdsdump @@ -7751,9 +7751,9 @@ Example: ~~~~ @code 0 : SOLID { 1 } @endcode has the following meaning: -* *0* – index in the DS; -* *SOLID* – type of the shape; -* { 1 } – a DS index of the successors. +* *0* -- index in the DS; +* *SOLID* -- type of the shape; +* { 1 } -- a DS index of the successors. @subsubsection occt_draw_20_3_3 bopindex @@ -7773,9 +7773,9 @@ bopiterator [t1 t2] Prints pairs of DS indices of source shapes that are intersected in terms of bounding boxes. [t1 t2] are types of the shapes: -* *7* - vertex; -* *6* - edge; -* *4* – face. +* *7* -- vertex; +* *6* -- edge; +* *4* -- face. Example: ~~~~ @@ -7789,7 +7789,7 @@ Example: ~~~~ * *bopiterator 6 4* prints pairs of indices for types: edge/face; -* *z58 z12* - DS indices of intersecting edge and face. +* *z58 z12* -- DS indices of intersecting edge and face. @subsubsection occt_draw_20_3_5 bopinterf @@ -7813,9 +7813,9 @@ Example: ~~~~ Here, record (58, 12, 68) means: -* *58* – a DS index of the edge; -* *12* – a DS index of the face; -* *68* – a DS index of the new vertex. +* *58* -- a DS index of the edge; +* *12* -- a DS index of the face; +* *68* -- a DS index of the new vertex. @subsubsection occt_draw_20_3_6 bopsp @@ -7832,8 +7832,8 @@ Example: edge 38 : z38_84 z38_85 ~~~~ -* *edge 58* – 58 is a DS index of the original edge. -* *z58_74 z58_75* – split edges, where 74, 75 are DS indices of the split edges. +* *edge 58* -- 58 is a DS index of the original edge. +* *z58_74 z58_75* -- split edges, where 74, 75 are DS indices of the split edges. @subsubsection occt_draw_20_3_7 bopcb @@ -7855,13 +7855,13 @@ Example: ~~~~ This command dumps common blocks for the source edge with index 17. -* *PB* – information about the Pave Block; - * *71* – a DS index of the split edge - * *17* – a DS index of the original edge -* Pave1 : { 68 3.000 } – information about the Pave: - * *68* – a DS index of the vertex of the pave - * *3.000* – a parameter of vertex 68 on edge 17 -* *Faces: 36* – 36 is a DS index of the face the common block belongs to. +* *PB* -- information about the Pave Block; + * *71* -- a DS index of the split edge + * *17* -- a DS index of the original edge +* Pave1 : { 68 3.000 } -- information about the Pave: + * *68* -- a DS index of the vertex of the pave + * *3.000* -- a parameter of vertex 68 on edge 17 +* *Faces: 36* -- 36 is a DS index of the face the common block belongs to. @subsubsection occt_draw_20_3_8 bopfin @@ -7884,8 +7884,8 @@ Example: ~~~~ -* PB:{ E:71 orE:17 Pave1: { 68 3.000 } Pave2: { 18 10.000 } } – information about the Pave Block; -* vrts In ... 18 – 18 a DS index of the vertex IN the face. +* PB:{ E:71 orE:17 Pave1: { 68 3.000 } Pave2: { 18 10.000 } } -- information about the Pave Block; +* vrts In ... 18 -- a DS index of the vertex IN the face. @subsubsection occt_draw_20_3_9 bopfon @@ -7907,8 +7907,8 @@ Example: 68 69 70 71 ~~~~ -* PB:{ E:72 orE:38 Pave1: { 69 0.000 } Pave2: { 68 10.000 } } – information about the Pave Block; -* vrts On: ... 68 69 70 71 – 68, 69, 70, 71 DS indices of the vertices ON the face. +* PB:{ E:72 orE:38 Pave1: { 69 0.000 } Pave2: { 68 10.000 } } -- information about the Pave Block; +* vrts On: ... 68 69 70 71 -- DS indices of the vertices ON the face. @subsubsection occt_draw_20_3_10 bopwho @@ -7925,7 +7925,7 @@ Example: rank: 0 ~~~~ -* *rank: 0* – means that shape 5 results from the Argument with index 0. +* *rank: 0* -- means that shape 5 results from the Argument with index 0. Example: ~~~~ @@ -7937,9 +7937,9 @@ Example: ~~~~ This means that shape 68 is a result of the following interferences: -* *EF: (58, 12)* – edge 58 / face 12 -* *FF curves: (12, 56)* – edge from the intersection curve between faces 12 and 56 -* *FF curves: (12, 64)* – edge from the intersection curve between faces 12 and 64 +* *EF: (58, 12)* -- edge 58 / face 12 +* *FF curves: (12, 56)* -- edge from the intersection curve between faces 12 and 56 +* *FF curves: (12, 64)* -- edge from the intersection curve between faces 12 and 64 @subsubsection occt_draw_20_3_11 bopnews @@ -7948,8 +7948,8 @@ Syntax: bopnews -v [-e] ~~~~ -* -v - displays all new vertices produced during the operation; -* -e - displays all new edges produced during the operation. +* -v -- displays all new vertices produced during the operation; +* -e -- displays all new edges produced during the operation. @subsection occt_draw_20_4 Commands for the Building Part @@ -8102,11 +8102,11 @@ stepwrite mode shape_name file_name Writes an OCCT shape to a STEP file. The following modes are available : - * *a* - as is – mode is selected automatically depending on the type & geometry of the shape; - * *m* - *manifold_solid_brep* or *brep_with_voids* - * *f* - *faceted_brep* - * *w* - *geometric_curve_set* - * *s* - *shell_based_surface_model* + * *a* -- as is -- the mode is selected automatically depending on the type & geometry of the shape; + * *m* -- *manifold_solid_brep* or *brep_with_voids* + * *f* -- *faceted_brep* + * *w* -- *geometric_curve_set* + * *s* -- *shell_based_surface_model* For further information see Writing a STEP file. @@ -8412,17 +8412,17 @@ tpstat [*|?] [] Provides all statistics on the last transfer, including a list of transferred entities with mapping from IGES or STEP to OCCT types, as well as fail and warning messages. The parameter \ defines what information will be printed: -* *g* - General statistics (a list of results and messages) -* *c* - Count of all warning and fail messages -* *C* - List of all warning and fail messages -* *f* - Count of all fail messages -* *F* - List of all fail messages -* *n* - List of all transferred roots -* *s* - The same, with types of source entity and the type of result -* *b* - The same, with messages -* *t* - Count of roots for geometrical types -* *r* - Count of roots for topological types -* *l* - The same, with the type of the source entity +* *g* -- General statistics (a list of results and messages) +* *c* -- Count of all warning and fail messages +* *C* -- List of all warning and fail messages +* *f* -- Count of all fail messages +* *F* -- List of all fail messages +* *n* -- List of all transferred roots +* *s* -- The same, with types of source entity and the type of result +* *b* -- The same, with messages +* *t* -- Count of roots for geometrical types +* *r* -- Count of roots for topological types +* *l* -- The same, with the type of the source entity The sign \* before parameters *n, s, b, t, r* makes it work on all entities (not only on roots). @@ -8455,7 +8455,7 @@ xload /disk1/tmp/aaa.stp @subsection occt_draw_8_4 Overview of XDE commands -These commands are used for translation of IGES and STEP files into an XCAF document (special document is inherited from CAF document and is intended for Extended Data Exchange (XDE) ) and working with it. XDE translation allows reading and writing of shapes with additional attributes – colors, layers etc. All commands can be divided into the following groups: +These commands are used for translation of IGES and STEP files into an XCAF document (special document is inherited from CAF document and is intended for Extended Data Exchange (XDE) ) and working with it. XDE translation allows reading and writing of shapes with additional attributes -- colors, layers etc. All commands can be divided into the following groups: * XDE translation commands * XDE general commands * XDE shape’s commands @@ -8607,7 +8607,7 @@ Syntax: XShow [ … ] ~~~~~ -Shows a shape from a given label in the 3D viewer. If the label is not given – shows all shapes from the document. +Shows a shape from a given label in the 3D viewer. If the label is not given -- shows all shapes from the document. **Example:** ~~~~~ @@ -8759,7 +8759,7 @@ XGetFreeShapes [shape_prefix] ~~~~~ Print labels or create DRAW shapes for all free shapes in the document. -If *shape_prefix* is absent – prints labels, else – creates DRAW shapes with names +If *shape_prefix* is absent -- prints labels, else -- creates DRAW shapes with names shape_prefix_num (i.e. for example: there are 3 free shapes and *shape_prefix* = a therefore shapes will be created with names a_1, a_2 and a_3). **Note**: a free shape is a shape to which no other shape refers to. @@ -8985,7 +8985,7 @@ Syntax: XGetShapeColor