--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [01:16:01.360] Vidbot :: start() [01:16:01.360] Vidbot :: _next(), _stepIndex:0 of 4 [01:16:01.361] index :: _onStepStarted_vidbot(), step: 1 [01:16:01.362] Vidbot :: step[0], label:Initializing Core [01:16:01.370] index :: _onStepProgress_vidbot(), percent: 20 [01:16:01.371] Vidbot :: _parse() [01:16:01.372] index :: _onStepProgress_vidbot(), percent: 40 [01:16:01.372] Vidbot :: _validate() [01:16:01.373] index :: _onStepProgress_vidbot(), percent: 60 [01:16:01.373] Vidbot :: _fonts() [01:16:01.373] FabricFontManager :: add(), id: SourceSansPro-Bold [01:16:01.373] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [01:16:01.381] FabricFontManager :: add(), id: SourceSansPro-Light [01:16:01.381] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [01:16:01.382] FabricFontManager :: add(), id: DINOT-Bold [01:16:01.382] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [01:16:01.383] FabricFontManager :: add(), id: DINOT-Light [01:16:01.383] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [01:16:01.384] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [01:16:01.384] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [01:16:01.385] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [01:16:01.385] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [01:16:01.386] index :: _onStepProgress_vidbot(), percent: 80 [01:16:01.386] Vidbot :: _clips() [01:16:01.386] StreamManager :: add(), id:audio_vo, type:audio [01:16:01.387] AudioClip[audio_vo] :: constructor() [01:16:01.387] InputStream[audio_vo] :: constructor() [01:16:01.387] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [01:16:01.389] StreamManager :: add(), id:bg_music, type:audio [01:16:01.390] AudioClip[bg_music] :: constructor() [01:16:01.390] InputStream[bg_music] :: constructor() [01:16:01.390] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [01:16:01.390] StreamManager :: add(), id:simplefadedisplay, type:canvas [01:16:01.390] CanvasStream[canvas_424642683184] :: constructor() [01:16:01.391] InputStream[canvas_424642683184] :: constructor() [01:16:01.463] KenBurnsSlideshow[simplefadedisplay] :: constructor() [01:16:01.463] Overlay[simplefadedisplay] :: constructor() [01:16:01.463] CanvasClip[simplefadedisplay] :: constructor() [01:16:01.463] Clip[simplefadedisplay] :: constructor() [01:16:01.463] clip:"simplefadedisplay" added to stream:"canvas_424642683184" [01:16:01.463] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_424642683184', clipId: 'simplefadedisplay' } [01:16:01.464] StreamManager :: add(), id:infosheet, type:canvas [01:16:01.464] RenInfosheet[infosheet] :: constructor() [01:16:01.464] Ren[infosheet] :: constructor() [01:16:01.464] Overlay[infosheet] :: constructor() [01:16:01.464] CanvasClip[infosheet] :: constructor() [01:16:01.464] Clip[infosheet] :: constructor() [01:16:01.464] clip:"infosheet" added to stream:"canvas_424642683184" [01:16:01.464] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_424642683184', clipId: 'infosheet' } [01:16:01.464] StreamManager :: add(), id:caption, type:canvas [01:16:01.465] RenCaption[caption] :: constructor() [01:16:01.465] Ren[caption] :: constructor() [01:16:01.465] Overlay[caption] :: constructor() [01:16:01.465] CanvasClip[caption] :: constructor() [01:16:01.465] Clip[caption] :: constructor() [01:16:01.465] clip:"caption" added to stream:"canvas_424642683184" [01:16:01.465] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_424642683184', clipId: 'caption' } [01:16:01.465] StreamManager :: add(), id:options, type:canvas [01:16:01.465] RenOptions[options] :: constructor() [01:16:01.465] Ren[options] :: constructor() [01:16:01.465] Overlay[options] :: constructor() [01:16:01.465] CanvasClip[options] :: constructor() [01:16:01.465] Clip[options] :: constructor() [01:16:01.466] clip:"options" added to stream:"canvas_424642683184" [01:16:01.466] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_424642683184', clipId: 'options' } [01:16:01.466] StreamManager :: add(), id:cpo, type:video [01:16:01.466] VideoStream[cpo] :: constructor() [01:16:01.466] InputStream[cpo] :: constructor() [01:16:01.466] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'cpo', clipId: null } [01:16:01.466] all added... [01:16:01.466] Vidbot :: _next(), _stepIndex:1 of 4 [01:16:01.467] index :: _onStepCompleted_vidbot(), step: 1 [01:16:01.467] index :: _onStepStarted_vidbot(), step: 2 [01:16:01.467] Vidbot :: step[1], label:Initializing Input Streams [01:16:01.467] StreamManager :: init() [01:16:01.468] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.25 } [01:16:01.468] index :: _onStepProgress_vidbot(), percent: 25 [01:16:01.468] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.5 } [01:16:01.468] index :: _onStepProgress_vidbot(), percent: 50 [01:16:01.468] CanvasStream[canvas_424642683184] :: _init(), BEGIN [01:16:01.469] i:0, c.id:simplefadedisplay [01:16:01.469] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [01:16:01.469] KenBurnsSlideshow[simplefadedisplay] :: _validate() [01:16:01.470] KenBurnsSlideshow[undefined] :: _validateAnim() [01:16:01.470] KenBurnsSlideshow[undefined] :: _validateTheme() [01:16:01.471] i:1, c.id:infosheet [01:16:01.471] RenInfosheet[infosheet] :: _init() [01:16:01.471] RenInfosheet[infosheet] :: _validate() [01:16:01.472] i:2, c.id:caption [01:16:01.472] RenCaption[caption] :: _init() [01:16:01.473] RenCaption[caption] :: _validate() [01:16:01.473] i:3, c.id:options [01:16:01.473] RenPrice[options] :: _init() [01:16:01.474] RenOptions[options] :: _validate() [01:16:01.474] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'cpo', progress: 0.75 } [01:16:01.474] index :: _onStepProgress_vidbot(), percent: 75 [01:16:01.475] KenBurnsSlideshow[simplefadedisplay] :: _build() [01:16:01.480] AnimatedImageFrame[aif] :: constructor() [01:16:01.481] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.481] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_1.jpg [01:16:01.492] RenInfosheet[infosheet] :: _assets() [01:16:01.493] CanvasClip :: LoadSVGFromStringWithPromise() [01:16:01.511] CanvasClip :: LoadSVGFromString(), loaded [01:16:01.512] RenCaption[caption] :: _build() [01:16:01.526] RenOptions[options] :: _assets() [01:16:01.527] CanvasClip :: LoadSVGFromStringWithPromise() [01:16:01.539] CanvasClip :: LoadSVGFromString(), loaded [01:16:01.542] Overlay[caption] :: _animate() [01:16:01.546] RenInfosheet[infosheet] :: _build() [01:16:01.567] RenOptions[options] :: _build() [01:16:01.657] Overlay[infosheet] :: _animate() [01:16:01.658] CanvasStream[caption] :: _init(), p.then() [01:16:01.658] RenOptions[options] :: _animate() [01:16:01.658] Overlay[options] :: _animate() [01:16:01.659] CanvasStream[infosheet] :: _init(), p.then() [01:16:01.659] CanvasStream[options] :: _init(), p.then() [01:16:01.679] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.683] AnimatedImageFrame[aif] :: _init(), END [01:16:01.684] AnimatedImageFrame[aif] :: constructor() [01:16:01.684] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.684] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_2.jpg [01:16:01.709] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.711] AnimatedImageFrame[aif] :: _init(), END [01:16:01.711] AnimatedImageFrame[aif] :: constructor() [01:16:01.712] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.712] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_3.jpg [01:16:01.741] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.742] AnimatedImageFrame[aif] :: _init(), END [01:16:01.743] AnimatedImageFrame[aif] :: constructor() [01:16:01.743] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.743] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_4.jpg [01:16:01.759] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.760] AnimatedImageFrame[aif] :: _init(), END [01:16:01.761] AnimatedImageFrame[aif] :: constructor() [01:16:01.761] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.761] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_5.jpg [01:16:01.777] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.778] AnimatedImageFrame[aif] :: _init(), END [01:16:01.779] AnimatedImageFrame[aif] :: constructor() [01:16:01.779] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.779] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_6.jpg [01:16:01.797] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.798] AnimatedImageFrame[aif] :: _init(), END [01:16:01.799] AnimatedImageFrame[aif] :: constructor() [01:16:01.799] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.799] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_7.jpg [01:16:01.815] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.816] AnimatedImageFrame[aif] :: _init(), END [01:16:01.817] AnimatedImageFrame[aif] :: constructor() [01:16:01.817] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.817] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_8.jpg [01:16:01.837] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.838] AnimatedImageFrame[aif] :: _init(), END [01:16:01.839] AnimatedImageFrame[aif] :: constructor() [01:16:01.839] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.839] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_9.jpg [01:16:01.859] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.860] AnimatedImageFrame[aif] :: _init(), END [01:16:01.861] AnimatedImageFrame[aif] :: constructor() [01:16:01.861] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.861] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_10.jpg [01:16:01.887] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.888] AnimatedImageFrame[aif] :: _init(), END [01:16:01.888] AnimatedImageFrame[aif] :: constructor() [01:16:01.889] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.889] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_1.jpg [01:16:01.911] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.912] AnimatedImageFrame[aif] :: _init(), END [01:16:01.913] AnimatedImageFrame[aif] :: constructor() [01:16:01.913] AnimatedImageFrame[aif] :: _init(), BEGIN [01:16:01.913] CanvasClip :: LoadImageWithPromise(), src: D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9_2.jpg [01:16:01.928] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:16:01.929] AnimatedImageFrame[aif] :: _init(), END [01:16:01.930] Overlay[simplefadedisplay] :: _animate() [01:16:01.930] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [01:16:01.930] CanvasStream[simplefadedisplay] :: _init(), p.then() [01:16:01.931] CanvasStream[canvas_424642683184] :: _init(), promise.all.then() [01:16:01.933] CanvasStream[canvas_424642683184] :: _init(), END [01:16:01.934] StreamMangaer :: init(), stream[canvas_424642683184].then() [01:16:01.934] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_424642683184', progress: 1 } [01:16:01.934] index :: _onStepProgress_vidbot(), percent: 100 [01:16:01.934] StreamManager :: init(), promise.all.then... [01:16:01.934] Vidbot :: StreamMgr.on( 'INITED' ) [01:16:01.934] Vidbot :: _next(), _stepIndex:2 of 4 [01:16:01.934] index :: _onStepCompleted_vidbot(), step: 2 [01:16:01.935] index :: _onStepStarted_vidbot(), step: 3 [01:16:01.935] Vidbot :: step[2], label:Rendering Canvas Streams [01:16:01.935] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [01:16:01.935] StreamManager :: render() [01:16:01.936] CanvasStream[canvas_424642683184] :: render() [01:16:01.966] index :: _onStepProgress_vidbot(), percent: 0 [01:16:08.161] index :: _onStepProgress_vidbot(), percent: 5 [01:16:16.072] index :: _onStepProgress_vidbot(), percent: 10 [01:16:23.786] index :: _onStepProgress_vidbot(), percent: 15 [01:16:31.951] index :: _onStepProgress_vidbot(), percent: 20 [01:16:38.516] index :: _onStepProgress_vidbot(), percent: 25 [01:16:46.495] index :: _onStepProgress_vidbot(), percent: 30 [01:16:54.200] index :: _onStepProgress_vidbot(), percent: 35 [01:17:01.543] index :: _onStepProgress_vidbot(), percent: 40 [01:17:10.426] index :: _onStepProgress_vidbot(), percent: 45 [01:17:19.543] index :: _onStepProgress_vidbot(), percent: 50 [01:17:27.349] index :: _onStepProgress_vidbot(), percent: 55 [01:17:36.100] index :: _onStepProgress_vidbot(), percent: 60 [01:17:45.209] index :: _onStepProgress_vidbot(), percent: 65 [01:17:53.977] index :: _onStepProgress_vidbot(), percent: 70 [01:18:01.933] index :: _onStepProgress_vidbot(), percent: 75 [01:18:10.045] index :: _onStepProgress_vidbot(), percent: 80 [01:18:18.609] index :: _onStepProgress_vidbot(), percent: 85 [01:18:26.120] index :: _onStepProgress_vidbot(), percent: 90 [01:18:34.151] index :: _onStepProgress_vidbot(), percent: 95 [01:18:38.459] index :: _onStepProgress_vidbot(), percent: 100 [01:18:38.595] StreamManager :: render(), Promise.all.then... [01:18:38.596] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [01:18:38.596] Vidbot :: _next(), _stepIndex:3 of 4 [01:18:38.596] index :: _onStepCompleted_vidbot(), step: 3 [01:18:38.597] index :: _onStepStarted_vidbot(), step: 4 [01:18:38.598] Vidbot :: step[3], label:Encoding Media [01:18:38.601] CanvasFilters :: Overlay() [01:18:38.601] VideoStream[cpo] :: inputOptions() [01:18:38.602] VideoFilters :: Tpad() [01:18:38.602] VideoFilters :: Scale() [01:18:38.603] VideoFilters :: Overlay() [01:18:38.603] AudioStream[audio_vo] :: inputOptions() [01:18:38.604] AudioFilters :: Volume() [01:18:38.604] filter: [3:a]volume=1[3_vol] [01:18:38.604] AudioFilters :: Delay() [01:18:38.604] filter: [3_vol]adelay=0|0[3_del] [01:18:38.604] AudioStream[bg_music] :: inputOptions() [01:18:38.604] AudioFilters :: Volume() [01:18:38.604] filter: [4:a]volume=0.15[4_vol] [01:18:38.605] AudioFilters :: FadeOut() [01:18:38.605] filter: [4_vol]afade=t=out:st=35.46:d=1[4_fadeout] [01:18:38.605] AudioFilters :: Delay() [01:18:38.605] filter: [4_fadeout]adelay=0|0[4_del] [01:18:38.605] VideoStream[cpo] :: inputOptions() [01:18:38.605] AudioFilters :: Volume() [01:18:38.605] filter: [5:a]volume=1[5_vol] [01:18:38.605] AudioFilters :: Delay() [01:18:38.605] filter: [5_vol]adelay=35460|35460[5_del] [01:18:38.605] AudioFilters :: Mix() [01:18:38.606] filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [01:18:38.606] mixed filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [01:18:38.613] hang.time: 60 [01:18:38.717] Vidbot :: ffmpeg.on( 'start' ) [01:18:38.717] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=52.78 -r 30 -i ./tmp/canvas_424642683184_%05d.png -to 00:00:17.320 -i file:///var/app/video_ [01:18:38.717] pre_processor/assets/cpo/toyota/toyota_360.mp4 -to 00:00:38.460 -i file:///var/www/html/clients/20959/audio/D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9.mp3 - [01:18:38.717] to 00:00:35.460 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Concept5.mp3 -to 00:00:17.320 -i file:///var/app/video_pre_processor [01:18:38.717] /assets/cpo/toyota/toyota_360.mp4 -y -filter_complex [0:v][1:v]overlay=x=0:y=0[1_out];[2:v]tpad=start_duration=35.410000000000004[2_tpad];[2_tpad]scal [01:18:38.717] e=w=640:h=360[2_scaled];[1_out][2_scaled]overlay=x=0:y=0:enable='between(t,35.46,52.78)'[2_out];[3:a]volume=1[3_vol];[3_vol]adelay=0|0[3_del];[4:a]vol [01:18:38.717] ume=0.15[4_vol];[4_vol]afade=t=out:st=35.46:d=1[4_fadeout];[4_fadeout]adelay=0|0[4_del];[5:a]volume=1[5_vol];[5_vol]adelay=35460|35460[5_del];[3_del][ [01:18:38.718] 4_del][5_del]amix=inputs=3:duration=longest[a_out] -acodec aac -vcodec libx264 -r 30 -f mp4 -map [a_out] -map [2_out] -preset veryfast -crf 18 -movfla [01:18:38.718] gs frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/20959/video/D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9.mp4 [01:18:39.133] index :: _onStepProgress_vidbot(), percent: -3935673470 [01:18:39.460] index :: _onStepProgress_vidbot(), percent: 1 [01:18:40.976] index :: _onStepProgress_vidbot(), percent: 6 [01:18:41.978] index :: _onStepProgress_vidbot(), percent: 10 [01:18:43.490] index :: _onStepProgress_vidbot(), percent: 16 [01:18:45.019] index :: _onStepProgress_vidbot(), percent: 21 [01:18:46.032] index :: _onStepProgress_vidbot(), percent: 26 [01:18:47.036] index :: _onStepProgress_vidbot(), percent: 30 [01:18:48.542] index :: _onStepProgress_vidbot(), percent: 36 [01:18:49.549] index :: _onStepProgress_vidbot(), percent: 41 [01:18:50.564] index :: _onStepProgress_vidbot(), percent: 45 [01:18:51.565] index :: _onStepProgress_vidbot(), percent: 50 [01:18:53.071] index :: _onStepProgress_vidbot(), percent: 57 [01:18:54.101] index :: _onStepProgress_vidbot(), percent: 61 [01:18:55.102] index :: _onStepProgress_vidbot(), percent: 66 [01:18:56.107] index :: _onStepProgress_vidbot(), percent: 70 [01:18:57.109] index :: _onStepProgress_vidbot(), percent: 76 [01:18:58.111] index :: _onStepProgress_vidbot(), percent: 81 [01:18:59.117] index :: _onStepProgress_vidbot(), percent: 86 [01:18:59.623] index :: _onStepProgress_vidbot(), percent: 91 [01:19:00.624] index :: _onStepProgress_vidbot(), percent: 98 [01:19:00.970] index :: _onStepProgress_vidbot(), percent: 100 [01:19:01.034] Vidbot :: ffmpeg.on( 'end' ), Done! [01:19:01.035] StreamManager :: dispose() [01:19:01.035] CanvasStream[canvas_424642683184] :: dispose() [01:19:01.040] Vidbot :: fflog.on( 'finish' ) [01:19:01.040] fflog.path: /var/www/html/clients/20959/video/D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9.mp4.fflog [01:19:01.040] Vidbot :: _next(), _stepIndex:4 of 4 [01:19:01.040] index :: _onStepCompleted_vidbot(), step: 4 [01:19:01.041] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 179.698, output: '/var/www/html/clients/20959/video/D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9.mp4', duration: 52.78 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/20959/video/D853AF4C-D4F8-C0C0-3C2D-87CBCA9E6EB9.mp4 Media Duration : 00:00:52.780 Generation Time : 00:02:59.698 ---------------------------------------------------------------------------------------------------------------