NEWS
SOLVED [gelöst] Adapterinstallation - node gyp error
-
@Ralla66 - okay, dann gebe ich mich erstmal geschlagen! Danke trotzdem für deine Hilfe!
-
Installier mal canvas 2.6
-
@Zefau - danke für den hinweis. hast du einen Tipp wo und wie genau ich das installieren soll? Der Fehler mit "package.json" kommt leider auch bei dem entsprechendem Link von der 2.6 Version..
Ich habe als root einfach folgendes gemacht:
npm install https://github.com/node-gfx/node-canvas-prebuilt/releases/download/v2.6.0/canvas-v2.6.0-node-v64-linux-glibc-x64.tar.gz
Aber der Fehler mit dem package.json bleibt:
root@HOME:/home/pi# npm install https://github.com/node-gfx/node-canvas-prebuilt/releases/download/v2.6.0/canvas-v2.6.0-node-v64-linux-glibc-x64.tar.gz npm ERR! code ENOPACKAGEJSON npm ERR! package.json Non-registry package missing package.json: https://github.com/node-gfx/node-canvas-prebuilt/releases/download/v2.6.0/canvas-v2.6.0-node-v64-linux-glibc-x64.tar.gz. npm ERR! package.json npm can't find a package.json file in your current directory. npm ERR! A complete log of this run can be found in: npm ERR! /root/.npm/_logs/2019-08-08T16_25_34_957Z-debug.log
Hast du einen Tipp?
-
Sorry, war noch unterwegs, daher die knappe Antwort.
Hast du die build-essentials installiert?
sudo apt-get install build-essential libcairo2-dev libpango1.0-dev libjpeg-dev libgif-dev librsvg2-dev
Danach dann einfach canvas 2.6.0 von npm:
sudo npm install canvas@2.6.0 --unsafe-perm=true
EDIT: den zweiten Befehl im iobroker.roomba Ordner ausführen. Also unter
/opt/iobroker/node_modules/iobroker.roomba
.EDIT2: Hab jetzt den Verlauf nicht komplett gelesen, aber die fehlende
package.json
liegt daran, dass du in einem völlig falschen Ordner bist (/home/pi
?). Die Befehle müssen im iobroker.roomba Ordner ausgeführt werden, wenn diese dafür greifen sollen. -
@Zefau kein Problem, danke für deine Unterstützung.
Auch die Installtion von 2.6.0 schlägt fehl (404), allerdings scheint das Problem in einem falschen Link in dem package zu liegen. Habe diese Issue hier gefunden: https://github.com/node-gfx/node-canvas-prebuilt/issues/84
Dann muss man aktuell wohl warten, bis das seitens der entwickler von node-canvas behoben ist, wenn ich das richtig verstehe?
-
@Sundance Kannst du das Log bitte posten? Welche URL wirft 404? Siehe https://github.com/node-gfx/node-canvas-prebuilt/releases welche prebuilts es gibt.
Die prebuilds gibt es nur für LTS Versionen von node, also v8, v10 und v12. Du solltest von v11 zurück auf v10 gehen.
Davon unabhängig: Wenn er keine prebuilts findet, dann kompiliert Linux eigl. selbst. Versucht das System dies bei dir gar nicht, oder kommt dann dein node-gyp Fehler?
-
@Zefau Aktuell bin ich auf node Version 10.16.2 - müsste also passen, oder? Hier das log von der installation von canvas 2.6.0:
root@HOME:/home/pi# sudo npm install canvas@2.6.0 --unsafe-perm=true > canvas@2.6.0 install /home/pi/node_modules/canvas > node-pre-gyp install --fallback-to-build node-pre-gyp WARN Using request for node-pre-gyp https download node-pre-gyp WARN Tried to download(404): https://github.com/node-gfx/node-canvas-prebuilt/releases/download/v2.6.0/canvas-v2.6.0-node-v64-linux-glibc-arm.tar.gz node-pre-gyp WARN Pre-built binaries not found for canvas@2.6.0 and node@10.16.2 (node-v64 ABI, glibc) (falling back to source compile with node-gyp) make: Entering directory '/home/pi/node_modules/canvas/build' SOLINK_MODULE(target) Release/obj.target/canvas-postbuild.node COPY Release/canvas-postbuild.node CXX(target) Release/obj.target/canvas/src/backend/Backend.o CXX(target) Release/obj.target/canvas/src/backend/ImageBackend.o CXX(target) Release/obj.target/canvas/src/backend/PdfBackend.o CXX(target) Release/obj.target/canvas/src/backend/SvgBackend.o CXX(target) Release/obj.target/canvas/src/bmp/BMPParser.o ../src/bmp/BMPParser.cc: In member function 'void BMPParser::Parser::parse(uint8_t*, int, uint8_t*)': ../src/bmp/BMPParser.cc:189:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data > imgdOffset, "image data overlaps with another structure"); ~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ ../src/bmp/BMPParser.cc:204:27: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data + imgdSize > len, "not enough image data"); ~~~~~~~~~~~~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ CXX(target) Release/obj.target/canvas/src/Backends.o CXX(target) Release/obj.target/canvas/src/Canvas.o ../src/Canvas.cc: In static member function 'static Nan::NAN_METHOD_RETURN_TYPE Canvas::ToBuffer(Nan::NAN_METHOD_ARGS_TYPE)': ../src/Canvas.cc:415:26: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if (canvas->nBytes() > node::Buffer::kMaxLength) { ~~~~~~~~~~~~~~~~~^~~~~~ CXX(target) Release/obj.target/canvas/src/CanvasGradient.o CXX(target) Release/obj.target/canvas/src/CanvasPattern.o CXX(target) Release/obj.target/canvas/src/CanvasRenderingContext2d.o CXX(target) Release/obj.target/canvas/src/closure.o CXX(target) Release/obj.target/canvas/src/color.o CXX(target) Release/obj.target/canvas/src/Image.o CXX(target) Release/obj.target/canvas/src/ImageData.o CXX(target) Release/obj.target/canvas/src/init.o CXX(target) Release/obj.target/canvas/src/register_font.o SOLINK_MODULE(target) Release/obj.target/canvas.node COPY Release/canvas.node make: Leaving directory '/home/pi/node_modules/canvas/build' npm WARN saveError ENOENT: no such file or directory, open '/home/pi/package.json' npm WARN enoent ENOENT: no such file or directory, open '/home/pi/package.json' npm WARN pi No description npm WARN pi No repository field. npm WARN pi No README data npm WARN pi No license field. + canvas@2.6.0 added 62 packages from 35 contributors and audited 741 packages in 127.47s found 0 vulnerabilities
Ich habe danach einfach nochmal die adapter installation versucht, aber sie schlägt weiterhin mit folgendem Log fehl:
root@HOME:/home/pi# iobroker install iobroker.roomba ^[fNPM version: 6.9.0 npm install iobroker.roomba@1.0.0 --production --save --prefix "/opt/iobroker" (System call) node-pre-gyp WARN Using request for node-pre-gyp https download node-pre-gyp WARN Tried to download(404): https://github.com/node-gfx/node-canvas-prebuilt/releases/download/v2.5.0/canvas-v2.5.0-node-v64-linux-glibc-arm.tar.gz node-pre-gyp WARN Pre-built binaries not found for canvas@2.5.0 and node@10.16.2 (node-v64 ABI, glibc) (falling back to source compile with node-gyp) ../src/bmp/BMPParser.cc: In member function 'void BMPParser::Parser::parse(uint8_t*, int, uint8_t*)': ../src/bmp/BMPParser.cc:193:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data > imgdOffset, "image data overlaps with another structure"); ~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ ../src/bmp/BMPParser.cc:208:27: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data + imgdSize > len, "not enough image data"); ~~~~~~~~~~~~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ ../src/CanvasRenderingContext2d.cc: In static member function 'static Nan::NAN_METHOD_RETURN_TYPE Context2d::DrawImage(Nan::NAN_METHOD_ARGS_TYPE)': ../src/CanvasRenderingContext2d.cc:1291:45: error: call of overloaded 'abs(double&)' is ambiguous double current_scale_x = abs(transforms[1]); ^ In file included from /usr/include/c++/6/cstdlib:75:0, from /usr/include/c++/6/ext/string_conversions.h:41, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/10.16.2/include/node/v8.h:21, from /home/iobroker/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/stdlib.h:735:12: note: candidate: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^~~ In file included from /usr/include/c++/6/ext/string_conversions.h:41:0, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/10.16.2/include/node/v8.h:21, from /home/iobroker/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/c++/6/cstdlib:180:3: note: candidate: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^~~ /usr/include/c++/6/cstdlib:172:3: note: candidate: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^~~ ../src/CanvasRenderingContext2d.cc:1292:45: error: call of overloaded 'abs(double&)' is ambiguous double current_scale_y = abs(transforms[2]); ^ In file included from /usr/include/c++/6/cstdlib:75:0, from /usr/include/c++/6/ext/string_conversions.h:41, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/10.16.2/include/node/v8.h:21, from /home/iobroker/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/stdlib.h:735:12: note: candidate: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^~~ In file included from /usr/include/c++/6/ext/string_conversions.h:41:0, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/10.16.2/include/node/v8.h:21, from /home/iobroker/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/c++/6/cstdlib:180:3: note: candidate: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^~~ /usr/include/c++/6/cstdlib:172:3: note: candidate: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^~~ make: *** [Release/obj.target/canvas/src/CanvasRenderingContext2d.o] Error 1 gyp ERR! build error gyp ERR! stack Error: `make` failed with exit code: 2 gyp ERR! stack at ChildProcess.onExit (/usr/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23) gyp ERR! stack at ChildProcess.emit (events.js:198:13) gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:248:12) gyp ERR! System Linux 4.19.57-v7+ gyp ERR! command "/usr/bin/node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "build" "--fallback-to-build" "--module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node" "--module_name=canvas" "--module_path=/opt/iobroker/node_modules/canvas/build/Release" "--napi_version=4" "--node_abi_napi=napi" "--napi_build_version=0" "--node_napi_label=node-v64" gyp ERR! cwd /opt/iobroker/node_modules/canvas gyp ERR! node -v v10.16.2 gyp ERR! node-gyp -v v3.8.0 gyp ERR! not ok node-pre-gyp ERR! build error node-pre-gyp ERR! stack Error: Failed to execute '/usr/bin/node /usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js build --fallback-to-build --module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node --module_name=canvas --module_path=/opt/iobroker/node_modules/canvas/build/Release --napi_version=4 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v64' (1) node-pre-gyp ERR! stack at ChildProcess.<anonymous> (/opt/iobroker/node_modules/canvas/node_modules/node-pre-gyp/lib/util/compile.js:83:29) node-pre-gyp ERR! stack at ChildProcess.emit (events.js:198:13) node-pre-gyp ERR! stack at maybeClose (internal/child_process.js:982:16) node-pre-gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:259:5) node-pre-gyp ERR! System Linux 4.19.57-v7+ node-pre-gyp ERR! command "/usr/bin/node" "/opt/iobroker/node_modules/canvas/node_modules/.bin/node-pre-gyp" "install" "--fallback-to-build" node-pre-gyp ERR! cwd /opt/iobroker/node_modules/canvas node-pre-gyp ERR! node -v v10.16.2 node-pre-gyp ERR! node-pre-gyp -v v0.11.0 node-pre-gyp ERR! not ok npm WARN bl@0.7.0 requires a peer of stream-browserify@* but none is installed. You must install peer dependencies yourself. npm WARN optional SKIPPING OPTIONAL DEPENDENCY: osx-temperature-sensor@1.0.3 (node_modules/osx-temperature-sensor): npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for osx-temperature-sensor@1.0.3: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"arm"}) npm ERR! code ELIFECYCLE npm ERR! errno 1 npm ERR! canvas@2.5.0 install: `node-pre-gyp install --fallback-to-build` npm ERR! Exit status 1 npm ERR! npm ERR! Failed at the canvas@2.5.0 install script. npm ERR! This is probably not a problem with npm. There is likely additional logging output above. npm ERR! A complete log of this run can be found in: npm ERR! /home/iobroker/.npm/_logs/2019-08-08T18_50_01_882Z-debug.log host.HOME Adapter directory "null" does not exists Cannot parse null/io-package.json:Error: ENOENT: no such file or directory, open 'null/io-package.json'
-
@Sundance Sieht an sich gut aus. Die Installation von Canvas 2.6.0 läuft durch, die von 2.5.0 (die aktuell noch bei ioBroker.roomba gezogen wird) nicht.
Versuch mal die aktuelle Version vom Repository zu installieren:
iobroker url https://github.com/Zefau/ioBroker.roomba
.
Github habe ich jetzt auf 2.6.0 aktualisiert, dann sollte es passen. -
@Zefau - Danke für das Update, jetzt hat es funktioniert!
Adapter lies sich jetzt problemlos installieren - den 404 Fehler im Installationsdurchlauf zeigt er zwar immernoch an, aber es hat trotzdem geklappt.
Vielen dank bin gespannt auf den Adapter
-
@Sundance Klasse, freut mich!
-
@Sundance
Na dann läuft ja alles .Sundance vor 22 Stunden