1. 20 Mar, 2020 1 commit
    • Alberto Ferreira's avatar
      Fix SWIG methods that return char** (#2850) · 91185c3a
      Alberto Ferreira authored
      
      
      * [swig] Fix SWIG methods that return char** with StringArray.
      
      + [new] Add StringArray class to manage and manipulate arrays of fixed-length strings:
      
        This class is now used to wrap any char** parameters, manage memory and
        manipulate the strings.
      
        Such class is defined at swig/StringArray.hpp and wrapped in StringArray.i.
      
      + [API+fix] Wrap LGBM_BoosterGetFeatureNames it resulted in segfault before:
      
        Added wrapper LGBM_BoosterGetFeatureNamesSWIG(BoosterHandle) that
        only receives the booster handle and figures how much memory to allocate
        for strings and returns a StringArray which can be easily converted to String[].
      
      + [API+safety] For consistency, LGBM_BoosterGetEvalNamesSWIG was wrapped as well:
      
        * Refactor to detect any kind of errors and removed all the parameters
          besides the BoosterHandle (much simpler API to use in Java).
        * No assumptions are made about the required string space necessary (128 before).
        * The amount of required string memory is computed internally
      
      + [safety] No possibility of undefined behaviour
      
        The two methods wrapped above now compute the necessary string storage space
        prior to allocation, as the low-level C API calls would crash the process
        irreversibly if they write more memory than which is passed to them.
      
      * Changes to C API and wrappers support char**
      
      To support the latest SWIG changes that enable proper char**
      return support that is safe, the C API was changed.
      
      The respecive wrappers in R and Python were changed too.
      
      * Cleanup indentation in new lightgbm_R.cpp code
      
      * Adress review code-style comments.
      
      * Update swig/StringArray.hpp
      Co-Authored-By: default avatarNikita Titov <nekit94-08@mail.ru>
      
      * Update python-package/lightgbm/basic.py
      Co-Authored-By: default avatarNikita Titov <nekit94-08@mail.ru>
      
      * Update src/lightgbm_R.cpp
      Co-Authored-By: default avatarNikita Titov <nekit94-08@mail.ru>
      Co-authored-by: default avataralberto.ferreira <alberto.ferreira@feedzai.com>
      Co-authored-by: default avatarNikita Titov <nekit94-08@mail.ru>
      91185c3a
  2. 13 Nov, 2019 1 commit
  3. 26 Sep, 2019 1 commit
  4. 30 Aug, 2019 1 commit
  5. 25 Jul, 2019 1 commit
  6. 04 May, 2019 1 commit
  7. 29 Apr, 2019 1 commit
  8. 18 Mar, 2019 1 commit
    • Markus Cozowicz's avatar
      Added additional APIs to better support JNI on Spark (#2032) · beeb6e0f
      Markus Cozowicz authored
      * added API changes required for JNI performance optimizations (e.g. predict is 3-4x faster)
      
      * removed commented variables
      
      * removed commented header
      
      * renamed method to make it obvious it is created for Spark
      
      * fixed comment alignment
      
      * replaced GetPrimitiveArrayCritical with GetIntArrayElements for training. fixed dead-lock on databricks
      beeb6e0f
  9. 16 Mar, 2019 1 commit
  10. 25 Aug, 2018 1 commit
  11. 31 Jan, 2018 1 commit
    • Ilya Matiach's avatar
      Adding SWIG Java wrappers to LightGBM (#1223) · 6d58decf
      Ilya Matiach authored
      * Adding Java wrappers to LightGBM by updating CMakeLists and adding SWIG file
      
      * Set SWIG generation to OFF by default
      
      * Added -package option to SWIG_FLAGS
      
      * Fixed jar structure to have class files in proper location
      
      * removed link with OpenMP flags
      6d58decf