6.1. PikaScript C module overview

We still use keil’s simulation project as an example, if you don’t get the simulation project yet, please refer to 1. Three minutes to get started quickly

6.1.1. PikaScript module and module interface

We open the pikascript folder and find that in addition to main.py, there are Device.pyi, PikaObj.pyi and PikaStdLib.pyi in the root of the folder, which correspond to three PikaScript C modules (class package), each .pyi file itself is called the module interface (package interface). A C module can contain several classes that are more related.

_images/1638582993068-0a8afe28-baa2-41ad-bac1-6626d50192ad.png

Each PikaScript C module consists of two parts: module interface and module implementation (package implement). Let’s start by opening Device.pyi to see the contents, we will call Device.pyi the Device module interface in the subsequent documentation. Here is the entire contents of Device.pyi.

  1. # Device.pyi
  2. from PikaObj import *
  3. class LED(TinyObj):
  4. def on(self):
  5. pass
  6. def off(self):
  7. pass
  8. class Uart(TinyObj):
  9. def send(self, data:str):
  10. pass
  11. def setName(self, name:str):
  12. pass
  13. def printName(self):
  14. pass

As you can see, there are two classes defined in Device.pyi using pyhon standard syntax, the LED class and the Uart class, both of which inherit from TinyObj.

The LED class defines two methods, the on() method and the off() method, while the Uart class defines the send(data:str) method, the setName(name:str) method, and the printName() method.

As you can see, all these methods have the feature that instead of being definitions of methods, they are declarations (annotations) of methods, because all method implementations are passed out and none of them are written for implementation. And the method’s entry parameters are all with type declarations. For example, data:str means a data parameter with the type str, i.e. a string type.

This is because the module implementation of this module is written in C, i.e. the C modules of PikaScript are written with declarations in python syntax and implementations in C. PikaScript’s module development is a hybrid programming technique for interface-oriented programming.

However, when using an existing module, it is not necessary to know the module implementation, but only the module interface, in order to use the module.

6.1.2. Importing and calling modules

Let’s see how to use this module.

Let’s open main.py in the project, see the name, this file is the entry file for PikaScript.

The content of main.py is as follows

  1. # main.py
  2. from PikaObj import *
  3. import Device
  4. import PikaStdLib
  5. led = Device.LED()
  6. uart = Device.Uart()
  7. mem = PikaStdLib.MemChecker()
  8. print('hello wrold')
  9. uart.setName('com1')
  10. uart.send('My name is:')
  11. uart.printName()
  12. print('mem used max:')
  13. mem.max()
  14. print('mem used now:')
  15. mem.now()

Importing an already written C module is very simple, for example, to import the Device module, you just need to import Device, and note that all .py and .pyi files should be placed in the root directory of the pikascript fileshelf.

The call method uses the form uart.setName('com'), which is standard Python syntax and does not need much introduction.

After writing the module calls in main.py, double-click on rust-msc-v0.5.0.exe to pre-compile the PikaScript project, the pre-compiled output file is in the pikascrip-api folder.

_images/1638582989556-feafe97a-037f-44b2-8f2c-55ddf8f041ea.png

The pika pre-compiler generates .h declaration files and -api.c constructor files for the imported modules. The filenames start with the module name and each class corresponds to one .h file and one -api.c file.

https://user-images.githubusercontent.com/88232613/171088787-0e7239ef-0081-434e-9461-59d5c162a6ba.png

And PikaMain-api.c and PikaMain.h correspond to a special class that is the main PikaScript class, compiled from main.py.

https://user-images.githubusercontent.com/88232613/171088880-83247a92-2b1c-4d3f-a075-b4811132e54e.png

pikaScript.c and pikaScript.h, on the other hand, are initialization functions compiled from main.py. When the initialization functions are run, the startup script is automatically executed.

https://user-images.githubusercontent.com/88232613/171089013-7a690617-3972-436b-966b-75c6e975c497.png

In the current main.py, the startup script is written in the outermost method call, which is:

  1. led = Device.LED()
  2. uart = Device.Uart()
  3. mem = PikaStdLib.MemChecker()
  4. print('hello wrold')
  5. uart.setName('com1')
  6. uart.send('My name is:')
  7. uart.printName()
  8. print('mem used max:')
  9. mem.max()
  10. print('mem used now:')
  11. mem.now()

The compiled pikaScriptInit() initialization function corresponds to:

  1. PikaObj * pikaScriptInit(){
  2. PikaObj * pikaMain = newRootObj("pikaMain", New_PikaMain);
  3. obj_run(pikaMain,
  4. "\n"
  5. "led = Device.LED()\n"
  6. "uart = Device.Uart()\n"
  7. "mem = PikaStdLib.MemChecker()\n"
  8. "\n"
  9. "print('hello wrold')\n"
  10. "uart.setName('com1')\n"
  11. "uart.send('My name is:')\n"
  12. "uart.printName()\n"
  13. "print('mem used max:')\n"
  14. "mem.max()\n"
  15. "print('mem used now:')\n"
  16. "mem.now()\n"
  17. "\n"
  18. "\n");
  19. return pikaMain;
  20. }