--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [18:52:11.254] Vidbot :: start() [18:52:11.255] Vidbot :: _next(), _stepIndex:0 of 4 [18:52:11.255] index :: _onStepStarted_vidbot(), step: 1 [18:52:11.256] Vidbot :: step[0], label:Initializing Core [18:52:11.265] index :: _onStepProgress_vidbot(), percent: 20 [18:52:11.265] Vidbot :: _parse() [18:52:11.266] index :: _onStepProgress_vidbot(), percent: 40 [18:52:11.266] Vidbot :: _validate() [18:52:11.267] index :: _onStepProgress_vidbot(), percent: 60 [18:52:11.267] Vidbot :: _fonts() [18:52:11.268] FabricFontManager :: add(), id: SourceSansPro-Bold [18:52:11.268] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [18:52:11.276] FabricFontManager :: add(), id: SourceSansPro-Light [18:52:11.276] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [18:52:11.277] FabricFontManager :: add(), id: DINOT-Bold [18:52:11.277] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [18:52:11.278] FabricFontManager :: add(), id: DINOT-Light [18:52:11.278] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [18:52:11.279] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [18:52:11.279] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [18:52:11.279] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [18:52:11.279] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [18:52:11.280] index :: _onStepProgress_vidbot(), percent: 80 [18:52:11.281] Vidbot :: _clips() [18:52:11.281] StreamManager :: add(), id:audio_vo, type:audio [18:52:11.281] AudioClip[audio_vo] :: constructor() [18:52:11.282] InputStream[audio_vo] :: constructor() [18:52:11.282] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [18:52:11.284] StreamManager :: add(), id:bg_music, type:audio [18:52:11.284] AudioClip[bg_music] :: constructor() [18:52:11.284] InputStream[bg_music] :: constructor() [18:52:11.285] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [18:52:11.285] StreamManager :: add(), id:simplefadedisplay, type:canvas [18:52:11.285] CanvasStream[canvas_1441197991162] :: constructor() [18:52:11.285] InputStream[canvas_1441197991162] :: constructor() [18:52:11.359] KenBurnsSlideshow[simplefadedisplay] :: constructor() [18:52:11.359] Overlay[simplefadedisplay] :: constructor() [18:52:11.359] CanvasClip[simplefadedisplay] :: constructor() [18:52:11.359] Clip[simplefadedisplay] :: constructor() [18:52:11.359] clip:"simplefadedisplay" added to stream:"canvas_1441197991162" [18:52:11.359] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1441197991162', clipId: 'simplefadedisplay' } [18:52:11.360] StreamManager :: add(), id:infosheet, type:canvas [18:52:11.360] RenInfosheet[infosheet] :: constructor() [18:52:11.360] Ren[infosheet] :: constructor() [18:52:11.360] Overlay[infosheet] :: constructor() [18:52:11.360] CanvasClip[infosheet] :: constructor() [18:52:11.360] Clip[infosheet] :: constructor() [18:52:11.360] clip:"infosheet" added to stream:"canvas_1441197991162" [18:52:11.360] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1441197991162', clipId: 'infosheet' } [18:52:11.360] StreamManager :: add(), id:caption, type:canvas [18:52:11.360] RenCaption[caption] :: constructor() [18:52:11.360] Ren[caption] :: constructor() [18:52:11.361] Overlay[caption] :: constructor() [18:52:11.361] CanvasClip[caption] :: constructor() [18:52:11.361] Clip[caption] :: constructor() [18:52:11.361] clip:"caption" added to stream:"canvas_1441197991162" [18:52:11.361] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1441197991162', clipId: 'caption' } [18:52:11.361] StreamManager :: add(), id:price, type:canvas [18:52:11.361] RenPrice[price] :: constructor() [18:52:11.361] Ren[price] :: constructor() [18:52:11.361] Overlay[price] :: constructor() [18:52:11.361] CanvasClip[price] :: constructor() [18:52:11.361] Clip[price] :: constructor() [18:52:11.361] clip:"price" added to stream:"canvas_1441197991162" [18:52:11.361] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1441197991162', clipId: 'price' } [18:52:11.362] StreamManager :: add(), id:options, type:canvas [18:52:11.362] RenOptions[options] :: constructor() [18:52:11.362] Ren[options] :: constructor() [18:52:11.362] Overlay[options] :: constructor() [18:52:11.362] CanvasClip[options] :: constructor() [18:52:11.362] Clip[options] :: constructor() [18:52:11.362] clip:"options" added to stream:"canvas_1441197991162" [18:52:11.362] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1441197991162', clipId: 'options' } [18:52:11.362] all added... [18:52:11.362] Vidbot :: _next(), _stepIndex:1 of 4 [18:52:11.362] index :: _onStepCompleted_vidbot(), step: 1 [18:52:11.363] index :: _onStepStarted_vidbot(), step: 2 [18:52:11.363] Vidbot :: step[1], label:Initializing Input Streams [18:52:11.363] StreamManager :: init() [18:52:11.364] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [18:52:11.364] index :: _onStepProgress_vidbot(), percent: 33 [18:52:11.364] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [18:52:11.364] index :: _onStepProgress_vidbot(), percent: 67 [18:52:11.364] CanvasStream[canvas_1441197991162] :: _init(), BEGIN [18:52:11.365] i:0, c.id:simplefadedisplay [18:52:11.365] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [18:52:11.365] KenBurnsSlideshow[simplefadedisplay] :: _validate() [18:52:11.366] KenBurnsSlideshow[undefined] :: _validateAnim() [18:52:11.366] KenBurnsSlideshow[undefined] :: _validateTheme() [18:52:11.367] i:1, c.id:infosheet [18:52:11.367] RenInfosheet[infosheet] :: _init() [18:52:11.368] RenInfosheet[infosheet] :: _validate() [18:52:11.368] i:2, c.id:caption [18:52:11.369] RenCaption[caption] :: _init() [18:52:11.369] RenCaption[caption] :: _validate() [18:52:11.369] i:3, c.id:price [18:52:11.370] RenPrice[price] :: _init() [18:52:11.370] RenPrice[price] :: _validate() [18:52:11.370] i:4, c.id:options [18:52:11.370] RenPrice[options] :: _init() [18:52:11.371] RenOptions[options] :: _validate() [18:52:11.372] KenBurnsSlideshow[simplefadedisplay] :: _build() [18:52:11.377] AnimatedImageFrame[aif] :: constructor() [18:52:11.378] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.378] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_1.jpg [18:52:11.390] RenInfosheet[infosheet] :: _assets() [18:52:11.390] CanvasClip :: LoadSVGFromStringWithPromise() [18:52:11.410] CanvasClip :: LoadSVGFromString(), loaded [18:52:11.411] RenCaption[caption] :: _build() [18:52:11.427] RenInfosheet[price] :: _assets() [18:52:11.427] CanvasClip :: LoadSVGFromStringWithPromise() [18:52:11.433] CanvasClip :: LoadSVGFromString(), loaded [18:52:11.434] RenOptions[options] :: _assets() [18:52:11.434] CanvasClip :: LoadSVGFromStringWithPromise() [18:52:11.445] CanvasClip :: LoadSVGFromString(), loaded [18:52:11.448] Overlay[caption] :: _animate() [18:52:11.451] RenInfosheet[infosheet] :: _build() [18:52:11.472] RenPrice[price] :: _build() [18:52:11.477] RenOptions[options] :: _build() [18:52:11.590] Overlay[infosheet] :: _animate() [18:52:11.591] CanvasStream[caption] :: _init(), p.then() [18:52:11.591] Overlay[price] :: _animate() [18:52:11.592] RenOptions[options] :: _animate() [18:52:11.592] Overlay[options] :: _animate() [18:52:11.593] CanvasStream[infosheet] :: _init(), p.then() [18:52:11.593] CanvasStream[price] :: _init(), p.then() [18:52:11.593] CanvasStream[options] :: _init(), p.then() [18:52:11.607] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.610] AnimatedImageFrame[aif] :: _init(), END [18:52:11.612] AnimatedImageFrame[aif] :: constructor() [18:52:11.612] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.612] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_2.jpg [18:52:11.623] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.624] AnimatedImageFrame[aif] :: _init(), END [18:52:11.625] AnimatedImageFrame[aif] :: constructor() [18:52:11.625] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.625] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_3.jpg [18:52:11.636] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.637] AnimatedImageFrame[aif] :: _init(), END [18:52:11.637] AnimatedImageFrame[aif] :: constructor() [18:52:11.637] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.637] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_4.jpg [18:52:11.647] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.648] AnimatedImageFrame[aif] :: _init(), END [18:52:11.649] AnimatedImageFrame[aif] :: constructor() [18:52:11.649] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.649] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_1.jpg [18:52:11.659] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.660] AnimatedImageFrame[aif] :: _init(), END [18:52:11.660] AnimatedImageFrame[aif] :: constructor() [18:52:11.660] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.660] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_2.jpg [18:52:11.670] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.671] AnimatedImageFrame[aif] :: _init(), END [18:52:11.673] AnimatedImageFrame[aif] :: constructor() [18:52:11.673] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.673] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_3.jpg [18:52:11.684] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.685] AnimatedImageFrame[aif] :: _init(), END [18:52:11.685] AnimatedImageFrame[aif] :: constructor() [18:52:11.685] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.685] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_4.jpg [18:52:11.695] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.695] AnimatedImageFrame[aif] :: _init(), END [18:52:11.696] AnimatedImageFrame[aif] :: constructor() [18:52:11.696] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.696] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_1.jpg [18:52:11.706] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.707] AnimatedImageFrame[aif] :: _init(), END [18:52:11.708] AnimatedImageFrame[aif] :: constructor() [18:52:11.708] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.708] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_2.jpg [18:52:11.718] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.719] AnimatedImageFrame[aif] :: _init(), END [18:52:11.719] AnimatedImageFrame[aif] :: constructor() [18:52:11.719] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.719] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_3.jpg [18:52:11.730] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.730] AnimatedImageFrame[aif] :: _init(), END [18:52:11.731] AnimatedImageFrame[aif] :: constructor() [18:52:11.731] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.731] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_4.jpg [18:52:11.742] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.742] AnimatedImageFrame[aif] :: _init(), END [18:52:11.743] AnimatedImageFrame[aif] :: constructor() [18:52:11.743] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.743] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_1.jpg [18:52:11.754] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.755] AnimatedImageFrame[aif] :: _init(), END [18:52:11.755] AnimatedImageFrame[aif] :: constructor() [18:52:11.755] AnimatedImageFrame[aif] :: _init(), BEGIN [18:52:11.755] CanvasClip :: LoadImageWithPromise(), src: 7323EF09-92A3-70F9-7110-EC60CB939483_2.jpg [18:52:11.765] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:52:11.766] AnimatedImageFrame[aif] :: _init(), END [18:52:11.766] Overlay[simplefadedisplay] :: _animate() [18:52:11.766] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [18:52:11.767] CanvasStream[simplefadedisplay] :: _init(), p.then() [18:52:11.767] CanvasStream[canvas_1441197991162] :: _init(), promise.all.then() [18:52:11.770] CanvasStream[canvas_1441197991162] :: _init(), END [18:52:11.770] StreamMangaer :: init(), stream[canvas_1441197991162].then() [18:52:11.770] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1441197991162', progress: 1 } [18:52:11.770] index :: _onStepProgress_vidbot(), percent: 100 [18:52:11.770] StreamManager :: init(), promise.all.then... [18:52:11.770] Vidbot :: StreamMgr.on( 'INITED' ) [18:52:11.770] Vidbot :: _next(), _stepIndex:2 of 4 [18:52:11.771] index :: _onStepCompleted_vidbot(), step: 2 [18:52:11.771] index :: _onStepStarted_vidbot(), step: 3 [18:52:11.771] Vidbot :: step[2], label:Rendering Canvas Streams [18:52:11.771] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [18:52:11.771] StreamManager :: render() [18:52:11.772] CanvasStream[canvas_1441197991162] :: render() [18:52:11.802] index :: _onStepProgress_vidbot(), percent: 0 [18:52:16.125] index :: _onStepProgress_vidbot(), percent: 5 [18:52:21.265] index :: _onStepProgress_vidbot(), percent: 10 [18:52:25.974] index :: _onStepProgress_vidbot(), percent: 15 [18:52:31.939] index :: _onStepProgress_vidbot(), percent: 20 [18:52:37.889] index :: _onStepProgress_vidbot(), percent: 25 [18:52:42.645] index :: _onStepProgress_vidbot(), percent: 30 [18:52:48.689] index :: _onStepProgress_vidbot(), percent: 35 [18:52:54.688] index :: _onStepProgress_vidbot(), percent: 40 [18:52:59.642] index :: _onStepProgress_vidbot(), percent: 45 [18:53:05.102] index :: _onStepProgress_vidbot(), percent: 50 [18:53:10.877] index :: _onStepProgress_vidbot(), percent: 55 [18:53:16.422] index :: _onStepProgress_vidbot(), percent: 60 [18:53:22.514] index :: _onStepProgress_vidbot(), percent: 65 [18:53:28.596] index :: _onStepProgress_vidbot(), percent: 70 [18:53:34.196] index :: _onStepProgress_vidbot(), percent: 75 [18:53:39.908] index :: _onStepProgress_vidbot(), percent: 80 [18:53:45.095] index :: _onStepProgress_vidbot(), percent: 85 [18:53:50.283] index :: _onStepProgress_vidbot(), percent: 90 [18:53:55.815] index :: _onStepProgress_vidbot(), percent: 95 [18:54:01.439] index :: _onStepProgress_vidbot(), percent: 100 [18:54:02.085] StreamManager :: render(), Promise.all.then... [18:54:02.086] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [18:54:02.086] Vidbot :: _next(), _stepIndex:3 of 4 [18:54:02.086] index :: _onStepCompleted_vidbot(), step: 3 [18:54:02.087] index :: _onStepStarted_vidbot(), step: 4 [18:54:02.088] Vidbot :: step[3], label:Encoding Media [18:54:02.090] CanvasFilters :: Overlay() [18:54:02.091] AudioStream[audio_vo] :: inputOptions() [18:54:02.091] AudioFilters :: Volume() [18:54:02.091] filter: [2:a]volume=1[2_vol] [18:54:02.091] AudioFilters :: Delay() [18:54:02.091] filter: [2_vol]adelay=0|0[2_del] [18:54:02.091] AudioStream[bg_music] :: inputOptions() [18:54:02.091] AudioFilters :: Volume() [18:54:02.091] filter: [3:a]volume=0.25[3_vol] [18:54:02.092] AudioFilters :: FadeOut() [18:54:02.092] filter: [3_vol]afade=t=out:st=39.05:d=1[3_fadeout] [18:54:02.092] AudioFilters :: Delay() [18:54:02.092] filter: [3_fadeout]adelay=0|0[3_del] [18:54:02.092] AudioFilters :: Mix() [18:54:02.092] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [18:54:02.092] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [18:54:02.095] hang.time: 60 [18:54:02.205] Vidbot :: ffmpeg.on( 'start' ) [18:54:02.205] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=39.05 -r 30 -i ./tmp/canvas_1441197991162_%05d.png -to 00:00:42.049 -i file:///var/www/html/ [18:54:02.205] clients/13834/audio/7323EF09-92A3-70F9-7110-EC60CB939483.mp3 -to 00:00:39.049 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF3_Ea [18:54:02.205] sy_Listening.mp3 -y -filter_complex [0:v][1:v]overlay=x=0:y=0[1_out];[2:a]volume=1[2_vol];[2_vol]adelay=0|0[2_del];[3:a]volume=0.25[3_vol];[3_vol]afad [18:54:02.206] e=t=out:st=39.05:d=1[3_fadeout];[3_fadeout]adelay=0|0[3_del];[2_del][3_del]amix=inputs=2:duration=longest[a_out] -acodec aac -vcodec libx264 -r 30 -f [18:54:02.206] mp4 -map [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/13834/video/7323EF09- [18:54:02.206] 92A3-70F9-7110-EC60CB939483.mp4 [18:54:02.361] index :: _onStepProgress_vidbot(), percent: -5319458277 [18:54:02.789] index :: _onStepProgress_vidbot(), percent: 3 [18:54:03.302] index :: _onStepProgress_vidbot(), percent: 8 [18:54:03.805] index :: _onStepProgress_vidbot(), percent: 14 [18:54:04.308] index :: _onStepProgress_vidbot(), percent: 20 [18:54:04.810] index :: _onStepProgress_vidbot(), percent: 26 [18:54:05.311] index :: _onStepProgress_vidbot(), percent: 31 [18:54:05.824] index :: _onStepProgress_vidbot(), percent: 36 [18:54:06.323] index :: _onStepProgress_vidbot(), percent: 41 [18:54:06.828] index :: _onStepProgress_vidbot(), percent: 46 [18:54:07.329] index :: _onStepProgress_vidbot(), percent: 51 [18:54:07.834] index :: _onStepProgress_vidbot(), percent: 55 [18:54:08.334] index :: _onStepProgress_vidbot(), percent: 61 [18:54:08.834] index :: _onStepProgress_vidbot(), percent: 65 [18:54:09.336] index :: _onStepProgress_vidbot(), percent: 70 [18:54:09.841] index :: _onStepProgress_vidbot(), percent: 75 [18:54:10.339] index :: _onStepProgress_vidbot(), percent: 80 [18:54:10.846] index :: _onStepProgress_vidbot(), percent: 85 [18:54:11.350] index :: _onStepProgress_vidbot(), percent: 91 [18:54:11.852] index :: _onStepProgress_vidbot(), percent: 96 [18:54:12.225] index :: _onStepProgress_vidbot(), percent: 100 [18:54:12.255] Vidbot :: ffmpeg.on( 'end' ), Done! [18:54:12.256] StreamManager :: dispose() [18:54:12.256] CanvasStream[canvas_1441197991162] :: dispose() [18:54:12.261] Vidbot :: fflog.on( 'finish' ) [18:54:12.261] fflog.path: /var/www/html/clients/13834/video/7323EF09-92A3-70F9-7110-EC60CB939483.mp4.fflog [18:54:12.261] Vidbot :: _next(), _stepIndex:4 of 4 [18:54:12.261] index :: _onStepCompleted_vidbot(), step: 4 [18:54:12.262] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 121.026, output: '/var/www/html/clients/13834/video/7323EF09-92A3-70F9-7110-EC60CB939483.mp4', duration: 39.05 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/13834/video/7323EF09-92A3-70F9-7110-EC60CB939483.mp4 Media Duration : 00:00:39.049 Generation Time : 00:02:01.025 ---------------------------------------------------------------------------------------------------------------