Commit Graph

100 Commits (e634bc9fab938d83b128358f82eced686c605686)

Author SHA1 Message Date
Marc-Antoine Ruel e634bc9fab Fix a ton of golint messages.
The remainder is ALL_CAPS, underscores and golint confusion when multiple
exported variables are defined on a single line.

No functional change except one error string tweaked.
8 years ago
Marc-Antoine Ruel 501558c627 conn/display: simplify Drawer
display: move devices.Display as display.Drawer

This removes the last interface from devices, which was misplaced due to
historical accident. The new package display will also be the location for an
interface for text output only devices.

Remove io.Writer from this interface. While it's a good performance optimization
for some drivers, it shouldn't be required.

Change Draw():
- Return an error, so that communication erorr can be surfaced correctly,
  instead of an adhoc driver specific Err() method.
8 years ago
Marc-Antoine Ruel 6f8bd69f03 Consistently cache display device Bounds()
Improve Draw() performance.
8 years ago
Marc-Antoine Ruel 8fa8a276a6 apa102: fix typo, use DefaultOpts in cmd
Reduce the number of constants by having cmd/apa102 uses the values from
apa102.DefaultOpts. This increases the default intensity from 127 to 255.
8 years ago
Marc-Antoine Ruel 332037c25e Update use of frequency to use physic.Frequency
This is borderline pedantic but enables 30*physic.MegaHertz which I think is
more readable than 30000000, reducing the risk of typos.

Do not change Stream.Resolution() gpiostream yet, but I'll likely change it too
to match in a follow up.
8 years ago
Marc-Antoine Ruel 0b285a6cb6 cci: make Dev implement physic.SenseEnv
Remove unnecessary Sprintf() call.
8 years ago
Marc-Antoine Ruel 79423600fb ds18b20: change Dev to implement physic.SenseEnv; tweak String()
This removes the Temperature() function for coherency with the other drivers.

This removes the dependency on package fmt.
8 years ago
Marc-Antoine Ruel ecfe99ea32 physic: Add Precision to SenseEnv
Implement for bme280 and sysfs
8 years ago
Marc-Antoine Ruel e9544992d9 physic: increase RelativeHumidity precision by 10x
MicroRH comment are incorrect.

It's actually too low for BME280's sensitivity.
8 years ago
Marc-Antoine Ruel 458e322fcf lepton: complete the lepton driver overhaul
- New(): Remove cs argument.
- Frame uses image14bit.Gray14 instead of image.Gray16.
- ReadImg(): Removed in favor to NextFrame().
8 years ago
Marc-Antoine Ruel 3e5b1a8345 ssd1306: switch to use DefaultOpts pattern 8 years ago
Marc-Antoine Ruel ffc32d2881 ds248x: switch to use DefaultOpts pattern
Simplifies the expectations a bit, and the code too.

I²C address is not an option, for consistency with the other drivers.
8 years ago
Marc-Antoine Ruel ad7ff7dcea bmxx80: switch to a required Opts pattern
Issue #194
8 years ago
Marc-Antoine Ruel caf4bf4327 apa102: switch to an Opts pattern
While it may not look necessary to some drivers, it is useful to have a
consistent pattern. The Opts never specify connectivity, only other parameters.

Issue #194
8 years ago
Marc-Antoine Ruel fc241bc91d devices: Move interfaces and structs into physic
This made otherwise a weird import DAG.

Fixes #137
8 years ago
Marc-Antoine Ruel cd1516dfb2 devices: Remove devices.Device
Use conn.Resource instead.

Fixes #184
8 years ago
Marc-Antoine Ruel 79501ae489 bmxx80: change bmx280 tests
Make the float calibration calculation to use float64 instead of float32. It's
the same performance on all platforms.
Include conversion back to physic units for the float based benchmark, to be
more realistic.
8 years ago
Marc-Antoine Ruel f15a60524d Benchmark related changes
- .gohci.yml: Run with both -cover and -bench on odroid and win10 and make the
  benchtime 1000ms instead of 10ms to increase precision, as this was lacking.
- apa102: add benchmark for toRGBFast()
- bmxx80: add benchmark for conversion functions.
- gpiotest: silence test (was leaking output during benchmarks)
- physic: add benchmark for the current int64 String() implementation compared
  to an hypothetical (simpler) float64 based implementation.
8 years ago
Menno Finlay-Smits 66af77a36a lepton: Add new image14bit subpackage
This defines a image/draw compatible Gray14 image type and Intensity14
pixel type. These will soon be used to store the frames return by the
lepton driver.

This is part of the work for #218.
8 years ago
Marc-Antoine Ruel 9660271642 lepton: add NextFrame, explicit Halt, deprecation warnings
Both New() cs argument and ReadImg() will be removed, add warnings.

Done as part of issue #217 and #218.
8 years ago
Marc-Antoine Ruel ce57d1e222 lepton: add Dev.Bounds()
This is in preparation to support the lepton 3 and refactor the driver to be in
better shape.
8 years ago
Marc-Antoine Ruel 84ee99bd88 Fix remaining misuses of °K and one KPa 8 years ago
Marc-Antoine Ruel 7abb5ac69e conn/physic: redo the package that was added in 0bc4d173ac
It realized I did it wrong. Decouple and disambiguate the 'measurement type'
from the 'unit used'.

While trying to micro-optimize for 32 bits architecture, I missed the greater
picture. Use int64 for most types.

Include 100% test coverage and examples.
8 years ago
Marc-Antoine Ruel 3b9eef0d46 Fix travis failure in c7b6b899f1
Looks like my gofmt and the one used by travis do not agree on a comment inside
an empty struct. Move the comment outside the struct to work around the problem.
8 years ago
Marc-Antoine Ruel c7b6b899f1 Fix Makefile go vet to use -unsafeptr=false, formatting in bmp180_test.go 8 years ago
Marc-Antoine Ruel f4eadbf1e1 Follow up on 0bc4d173ac
Had forgotten to git add conn/physic/example_test.go.
Typoed the replacements in devices/devices.go.
8 years ago
Marc-Antoine Ruel 0bc4d173ac conn/physic: add units and sensing devices
This is to provide a saner abstraction and also stop host from depending on
devices.

Add Ampere, Centi and Volt.

This is to fix #137.
8 years ago
Marc-Antoine Ruel 989d5f693d Benchmarks: call ReportAllocs() explicitly everywhere
This removes the need to specify the flag -benchmem.
8 years ago
Marc-Antoine Ruel c9255b11f7 apa102: remove allocation in Halt
Document where Draw() cause a memory allocation in the case of an image format
other than NRGBA.
8 years ago
Marc-Antoine Ruel 53e3ff1b30 lepton: Add String() in preparation to conn changes
Soon most objects will have to implement String.
8 years ago
Marc-Antoine Ruel cf6b4f08f0 devices: stop using fmt for units
Use strconv directly instead.
8 years ago
Marc-Antoine Ruel 5b5083e8fb Move code around to make drivers follow a common pattern
The idea is to enable navigating across the code more easily by using similar
layout amongs the drivers.

Similar to gofmt, it's not about making a stylistic choice, but having a single
style.

Use the following layout for drivers:
- exported support types
- Opts struct
- New func
- Dev struct and methods
- Private support code

No functional change.

A lot of code moved around, so it will likely break any pending PR or fork. :/
8 years ago
Marc-Antoine Ruel 89531ab87e Reduce references to devices.Device
This interface will be removed in v3.
8 years ago
Marc-Antoine Ruel 7306448a6d devices: replace bus reference to port 8 years ago
Marc-Antoine Ruel 124fa6f98b I was so happy with recent Example refactors, did it for all packages
This creates an example_test.go for each package with at least one
Example, and move all examples in it. Make the example_test.go file live
into a separate package 'foo_test' so it can call host.Init() and thus
can be copied as-is.
8 years ago
Cássio Botaro eccbfb4b4d removing redundant code (#213) 8 years ago
M-A b46e37feba Remove all time.Sleep calls during tests (#204)
It slows down tests, nobody wants that.
9 years ago
Marc-Antoine Ruel 089b8dccab Reduce number of errcheck lint messages from 117 to 2.
- Ran github.com/kisielk/errcheck on the code base, and either trapped errors or
  marked them as ignored explicitly. The stats was calculated via:
    errcheck ./... | grep -v defer | wc -l
- Stop registering gpio.INVALID, it can't be registered.
- Fix a go vet issue in cap1188.
9 years ago
Marc-Antoine Ruel f015c64bb3 lepton: fix go test on go1.10beta1 9 years ago
Marc-Antoine Ruel e95c422e15 periph-smoketest: various usability improvements
This makes the tool more pleasant to use for newcomers and this makes flag
parsing more coherent.

- Print help on error.
- Consistently use NewFlagSet() everywhere with Usage() that prints nicer help
  page.
- Move code around for the ones that were not layed out in the same way as the
  rest.

This is a breaking change for gpiosmoketest, since it is switched from
undocumented positional arguments to flags.
9 years ago
Marc-Antoine Ruel dd32a7900e devices: move units code to units.go
No functional change.

I plan to add more units, and eventually this could make sense to split it off
into its own package. For now split it into its own source file.
9 years ago
Marc-Antoine Ruel 9e66c6ec1b Make the smoke tests more consistent
- Use the test name for the flag set.
- Assert that no extra argument on the command line is silently ignored
9 years ago
M-A 7dc1026c65 conn: Add Resource, superseds devices.Device (#162)
In practice I want to be able for gpioreg.Register() to eventually enforce that
Halt() is implemented on gpio.Pin, so that three's a consistent way to stop
gpiostream operations or PWM() output. This requires the interface to live in
conn, not in devices.

Do not use go1.9 type alias to not break compatibility with older Go version
yet.
9 years ago
M-A 3d1aec5647 apa102: minor tweaks (#158)
- Disallow writing a buffer longer than the number used. Silently
  dropping data is always annoying to debug. Clear failure is better.
- Rename private variables and document them better.
- Replace 'lights' by 'pixels'. This is more precise.
9 years ago
Marc-Antoine Ruel e6e8b5e2b3 bmxx80: clarify NewSPI documentation
The doc stated that NewSPI could be used for BME280. It can also be used for BMP280.
9 years ago
Marc-Antoine Ruel 14f6450ea7 sysfs: Improve coverage for thermal
- Correct minor typos.
- Improve sysfs-thermal error wrapping.
- No significant functional change.
9 years ago
M-A 5e39729535 bmxx80: Merge bmp180 and bme280 and add support for bmp280 (#156)
- cmd/bmxx80 now can read any of these 3 devices.
- Rewrite the driver to support all 3 devices. More devices of the family (like
  the bme680) could be easily added.
- Add -ia to bmx280smoketest

Fix #155
9 years ago
Marc-Antoine Ruel bbed3b44f7 Fix negative RelativeHumidity.String() 9 years ago
M-A 70fd9082bb bmp180: promote to stable; fix bug in bme280 (#152)
- bme280: fix hang in Halt() if SenseContinuous() listener is hung.
- bmp180: Add unit tests; increase test coverage to 96%.
- bmp180: Remove Reset(). There's no known use case.
- bmp180: Implement SenseContinuous().
- Consistently wrap errors in both packages.
- Various typos.
9 years ago
M-A e235d09bc8 gpioreg: Remove ByNumber() (#153)
It is still possible to get a pin by its logical number using the string
representation, but the function is not exported anymore.

This simplifies the interface, one less way to do the same thing.
9 years ago