File: README.source

package info (click to toggle)
arduino 2%3A1.8.19%2Bdfsg1-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 23,960 kB
  • sloc: java: 26,464; python: 8,872; cpp: 3,573; xml: 1,237; sh: 551; perl: 90; ansic: 89; makefile: 53
file content (110 lines) | stat: -rw-r--r-- 4,826 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
Organization of maintenance for src:arduino
-------------------------------------------

This package is maintained with git-buildpackage(1).

It uses pristine-tar(1) to store enough information in git to generate bit
identical tarballs when building the package without having downloaded an
upstream tarball first.

When working with patches it is recommended to use "gbp pq import" to
import the patches, modify the source and then use "gbp pq export
--commit" to commit the modifications.

The changelog is generated using "gbp dch" so if you submit any changes
don't bother to add changelog entries but rather provide a nice git commit
message that can then end up in the changelog.

It is recommended to build the package with pbuilder using:

    gbp builpackage --git-pbuilder

For information on how to set up a pbuilder environment see the
git-pbuilder(1) manpage. In short:

    DIST=sid git-pbuilder create
    gbp clone https://salsa.debian.org/electronics-team/arduino/arduino.git
    cd arduino
    gbp buildpackage --git-pbuilder


Importing a new upstream version
--------------------------------

To minimize workload and decrease possible mistakes the preferred way to
import a new version is doing this by git-buildpackage and let d/gbp.conf
control the whole import process. Importing a new version is done by

  gbp import orig --sign-tags [--verbose] /path/to/arduino-$version.tar.xz

In case you need to modify the list of files or folders to exclude you can
tune this by modifying the section [import-orig] in d/gbp.conf. Don't forget
to also adjust d/copyright afterwards in case adjustments are needed.

Once the new version is imported you will need to check the patch queue is
applying or needs also adjustments. Also here git-buildpackage is helping
with this task.

  gbp pq import [--time-machine=x]

In case the upstream changes are small git will discover the changes and will
apply the patch from the queue. Depending on the upstream changes you will
need to use the option '--time-machine=' so git-buildpackage will apply the
patch queue to an older version from there you can use the rebase option.
In case '--time-machine=' was needed to get used you need to rebase the
patch-queue branch against the version in your packaging branch which is
mostly debian/sid (or debian/experimental).

  git rebase debian/sid

As usual you need to fix any rebasing issue if pop up. Once finished you
can export back the patch queue.

  gbp pq export

This will switch back to your working packaging branch and also creates all
files and folder under debian/patches/. Review the changes and commit your
work, please explain in the commit message what's new or what did change in
the patch queue. This will help later preparing the d/changelog entry!


Using of Debian packaged Java libraries, linking to packaged libraries
----------------------------------------------------------------------

As the Arduino IDE is an Java application it is requiring the availability of
the required libraries. Upstream is shipping them prebuilt and bundled within
the lib/ folder.
Debian can't use and pick them as there is no source available in the source
tarball from there the libraries could be rebuilt. Thus all these files are
getting cleaned out while import the source. But there is no need to rebuild
all the various libraries, all the used libs are available within the Debian
main archive. To get them usable all the required libraries need to get
linked back into the lib/ folder while the build process of the package.
This is done within the linking sequencer file 'arduino.links'.

To add such a linking you need to do some things to get the chain working.

1. Have a look at the .jar files within the lib/ folder of the upstream
   tarball.
2. Search the Debian package which is providing the used Java library.
3. Add an entry for the library to arduino.links it will get linked.
   Note! Don't use any versioned files, remove the version suffix from the
         upstream file name.
   Example: 'batik-1.8.jar' becomes 'batik.jar'
4. Check if the Depends field for the package arduino in debian/control needs
   an addition of the package that is providing the Java library you've
   added. Keep new added packages in d/control please in alphabetical order!

There are small exceptions between used upstream Java libraries and by Debian
provided and used libraries! For the follow libraries upstream is using
different or other versions.

 Upstream version     | Debian version
 ---------------------+---------------
 bcpg-jdk15on-*.jar   | bcpg-*.jar
 bcprov-jdk15on-*.jar | bcprov-*.jar
 jssc-*-arduino4.jar  | jssc.jar

The first two libraries working fine with the IDE, from the modified jssc
library is no source available so it can't get rebuilt nor do we know what
Arduino LCC has modified.