test/testrumble.c
author Ryan C. Gordon <icculus@icculus.org>
Fri, 12 Aug 2016 19:59:00 -0400
changeset 10266 c09f06c4e8c8
parent 9998 f67cf37e9cd4
permissions -rw-r--r--
emscripten: send fake mouse events for touches, like other targets do. (This really should be handled at the higher level and not in the individual targets, but this fixes the immediate bug.)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5535
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
     1
/*
9998
f67cf37e9cd4 Updated copyright to 2016
Sam Lantinga <slouken@libsdl.org>
parents: 9922
diff changeset
     2
  Copyright (C) 1997-2016 Sam Lantinga <slouken@libsdl.org>
5535
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
     3
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
     4
  This software is provided 'as-is', without any express or implied
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
     5
  warranty.  In no event will the authors be held liable for any damages
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
     6
  arising from the use of this software.
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
     7
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
     8
  Permission is granted to anyone to use this software for any purpose,
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
     9
  including commercial applications, and to alter it and redistribute it
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
    10
  freely.
96594ac5fd1a SDL 1.3 is now under the zlib license.
Sam Lantinga <slouken@libsdl.org>
parents: 5360
diff changeset
    11
*/
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    12
/*
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    13
Copyright (c) 2011, Edgar Simo Serra
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    14
All rights reserved.
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    15
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    16
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    17
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    18
    * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    19
    * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    20
    * Neither the name of the Simple Directmedia Layer (SDL) nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    21
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    22
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    23
*/
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    24
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    25
/*
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    26
 * includes
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    27
 */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    28
#include <stdlib.h>
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    29
#include <string.h>             /* strstr */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    30
#include <ctype.h>              /* isdigit */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    31
6771
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
    32
#include "SDL.h"
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
    33
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
    34
#ifndef SDL_HAPTIC_DISABLED
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
    35
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    36
static SDL_Haptic *haptic;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    37
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    38
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    39
/**
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    40
 * @brief The entry point of this force feedback demo.
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    41
 * @param[in] argc Number of arguments.
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    42
 * @param[in] argv Array of argc arguments.
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    43
 */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    44
int
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    45
main(int argc, char **argv)
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    46
{
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    47
    int i;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    48
    char *name;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    49
    int index;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    50
9922
b066d5fd5fa7 Replaced tabs with spaces in test programs.
Philipp Wiesemann <philipp.wiesemann@arcor.de>
parents: 9619
diff changeset
    51
    /* Enable standard application logging */
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
    52
    SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
    53
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    54
    name = NULL;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    55
    index = -1;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    56
    if (argc > 1) {
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    57
        name = argv[1];
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    58
        if ((strcmp(name, "--help") == 0) || (strcmp(name, "-h") == 0)) {
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
    59
            SDL_Log("USAGE: %s [device]\n"
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    60
                   "If device is a two-digit number it'll use it as an index, otherwise\n"
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    61
                   "it'll use it as if it were part of the device's name.\n",
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    62
                   argv[0]);
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    63
            return 0;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    64
        }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    65
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    66
        i = strlen(name);
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    67
        if ((i < 3) && isdigit(name[0]) && ((i == 1) || isdigit(name[1]))) {
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    68
            index = atoi(name);
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    69
            name = NULL;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    70
        }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    71
    }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    72
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    73
    /* Initialize the force feedbackness */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    74
    SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_JOYSTICK |
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    75
             SDL_INIT_HAPTIC);
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
    76
    SDL_Log("%d Haptic devices detected.\n", SDL_NumHaptics());
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    77
    if (SDL_NumHaptics() > 0) {
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    78
        /* We'll just use index or the first force feedback device found */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    79
        if (name == NULL) {
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    80
            i = (index != -1) ? index : 0;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    81
        }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    82
        /* Try to find matching device */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    83
        else {
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    84
            for (i = 0; i < SDL_NumHaptics(); i++) {
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    85
                if (strstr(SDL_HapticName(i), name) != NULL)
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    86
                    break;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    87
            }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    88
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    89
            if (i >= SDL_NumHaptics()) {
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
    90
                SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to find device matching '%s', aborting.\n",
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    91
                       name);
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    92
                return 1;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    93
            }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    94
        }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    95
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    96
        haptic = SDL_HapticOpen(i);
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    97
        if (haptic == NULL) {
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
    98
            SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to create the haptic device: %s\n",
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
    99
                   SDL_GetError());
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   100
            return 1;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   101
        }
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   102
        SDL_Log("Device: %s\n", SDL_HapticName(i));
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   103
    } else {
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   104
        SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "No Haptic devices found!\n");
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   105
        return 1;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   106
    }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   107
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   108
    /* We only want force feedback errors. */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   109
    SDL_ClearError();
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   110
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   111
    if (SDL_HapticRumbleSupported(haptic) == SDL_FALSE) {
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   112
        SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Rumble not supported!\n");
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   113
        return 1;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   114
    }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   115
    if (SDL_HapticRumbleInit(haptic) != 0) {
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   116
        SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to initialize rumble: %s\n", SDL_GetError());
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   117
        return 1;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   118
    }
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   119
    SDL_Log("Playing 2 second rumble at 0.5 magnitude.\n");
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   120
    if (SDL_HapticRumblePlay(haptic, 0.5, 5000) != 0) {
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   121
       SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to play rumble: %s\n", SDL_GetError() );
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   122
       return 1;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   123
    }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   124
    SDL_Delay(2000);
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   125
    SDL_Log("Stopping rumble.\n");
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   126
    SDL_HapticRumbleStop(haptic);
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   127
    SDL_Delay(2000);
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   128
    SDL_Log("Playing 2 second rumble at 0.3 magnitude.\n");
7437
964e8876ad3b Fixed compiler warnings in test programs.
Philipp Wiesemann <philipp.wiesemann@arcor.de>
parents: 6771
diff changeset
   129
    if (SDL_HapticRumblePlay(haptic, 0.3f, 5000) != 0) {
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   130
       SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to play rumble: %s\n", SDL_GetError() );
5360
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   131
       return 1;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   132
    }
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   133
    SDL_Delay(2000);
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   134
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   135
    /* Quit */
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   136
    if (haptic != NULL)
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   137
        SDL_HapticClose(haptic);
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   138
    SDL_Quit();
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   139
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   140
    return 0;
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   141
}
220d3af9121f Simple rumble API for haptic
Sam Lantinga <slouken@libsdl.org>
parents:
diff changeset
   142
6771
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   143
#else
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   144
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   145
int
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   146
main(int argc, char *argv[])
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   147
{
7639
9406b7dd2f2d Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 7517
diff changeset
   148
    SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL compiled without Haptic support.\n");
6771
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   149
    exit(1);
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   150
}
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   151
55337ff4256f Fix compiler warning; minor harness driver cleanup; fix test build for SDL versions compiled with --disable-joystick or --disable-haptic
Andreas Schiffler <aschiffler@ferzkopp.net>
parents: 5535
diff changeset
   152
#endif