python_examples: Reformatted, self-checking, executable

* Moved body of each python example to main.  This allows for basic
      load module testing for CI
    * General cleanup of python modules (crlf/tabs/prints/etc)
    * Chmod'ed to 755 to allow running examples without specifying the
      python interpreter
    * Added ctest for loading python2/3 modules
    * Added jniclasscode pragma for java swig interface files.
    * Updated check_examplenames.py module to check all languages vs. a
      cxx example name
    * Added tests for checking python module and test loading
    * Added 'make test' to travis-ci run (run ctests)
    * Print a more meaningful message when not building cxx docs into
      python modules
    * Updated check_clean.py to only check java wrapper files
    * ENABLED ctests for UPM
    * Deleted using_carrays.py python example - this is covered by other
      examples

Signed-off-by: Noel Eck <noel.eck@intel.com>
This commit is contained in:
Noel Eck
2016-09-29 18:24:19 -07:00
parent 62718daf0b
commit 2f78d9f62b
203 changed files with 5890 additions and 5216 deletions

60
examples/python/uln200xa.py Normal file → Executable file
View File

@ -21,46 +21,48 @@
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
import time, sys, signal, atexit
import pyupm_uln200xa as upmULN200XA
# Instantiate a Stepper motor on a ULN200XA Darlington Motor Driver
# This was tested with the Grove Geared Step Motor with Driver
def main():
# Instantiate a Stepper motor on a ULN200XA Darlington Motor Driver
# This was tested with the Grove Geared Step Motor with Driver
# Instantiate a ULN2003XA stepper object
myUln200xa = upmULN200XA.ULN200XA(4096, 8, 9, 10, 11)
# Instantiate a ULN2003XA stepper object
myUln200xa = upmULN200XA.ULN200XA(4096, 8, 9, 10, 11)
## Exit handlers ##
# This stops python from printing a stacktrace when you hit control-C
def SIGINTHandler(signum, frame):
raise SystemExit
## Exit handlers ##
# This stops python from printing a stacktrace when you hit control-C
def SIGINTHandler(signum, frame):
raise SystemExit
# This lets you run code on exit,
# including functions from myUln200xa
def exitHandler():
print "Exiting"
sys.exit(0)
# This lets you run code on exit,
# including functions from myUln200xa
def exitHandler():
print "Exiting"
sys.exit(0)
# Register exit handlers
atexit.register(exitHandler)
signal.signal(signal.SIGINT, SIGINTHandler)
# Register exit handlers
atexit.register(exitHandler)
signal.signal(signal.SIGINT, SIGINTHandler)
myUln200xa.setSpeed(5) # 5 RPMs
myUln200xa.setDirection(upmULN200XA.ULN200XA.DIR_CW)
myUln200xa.setSpeed(5) # 5 RPMs
myUln200xa.setDirection(upmULN200XA.ULN200XA.DIR_CW)
print "Rotating 1 revolution clockwise."
myUln200xa.stepperSteps(4096)
print "Rotating 1 revolution clockwise."
myUln200xa.stepperSteps(4096)
print "Sleeping for 2 seconds..."
time.sleep(2)
print "Sleeping for 2 seconds..."
time.sleep(2)
print "Rotating 1/2 revolution counter clockwise."
myUln200xa.setDirection(upmULN200XA.ULN200XA.DIR_CCW)
myUln200xa.stepperSteps(2048)
print "Rotating 1/2 revolution counter clockwise."
myUln200xa.setDirection(upmULN200XA.ULN200XA.DIR_CCW)
myUln200xa.stepperSteps(2048)
# release
myUln200xa.release()
# release
myUln200xa.release()
# exitHandler is called automatically
# exitHandler is called automatically
if __name__ == '__main__':
main()