Keyboard firmwares for Atmel AVR and Cortex-M
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

RPCFunction.cpp 1.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. /* mbed Microcontroller Library
  2. * Copyright (c) 2006-2013 ARM Limited
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #include "RPCFunction.h"
  17. namespace mbed {
  18. //Custom rpc method caller for execute so that the string will not be delimited by anything
  19. void rpc_method_caller_run(RPC *this_ptr, Arguments *arguments, Reply *result) {
  20. ((static_cast<RPCFunction*>(this_ptr))->run)(arguments, result);
  21. }
  22. RPCFunction::RPCFunction(void (*f)(Arguments*, Reply*), const char* name) : RPC(name) {
  23. _ftr = f;
  24. }
  25. //Just run the attached function using the string thats in private memory - or just using null values,
  26. void RPCFunction::run(Arguments* args, Reply* r) {
  27. (*_ftr)(args, r);
  28. }
  29. const rpc_method *RPCFunction::get_rpc_methods() {
  30. static const rpc_method rpc_methods[] = {
  31. {"run", rpc_method_caller_run }, //Run using custom caller, all characters accepted in string
  32. RPC_METHOD_SUPER(RPC)
  33. };
  34. return rpc_methods;
  35. }
  36. }