--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.0... --------------------------------------------------------------------------------------------------------------- [14:51:20.044] Vidbot :: start() [14:51:20.045] Vidbot :: _next(), _stepIndex:0 of 4 [14:51:20.045] index :: _onStepStarted_vidbot(), step: 1 [14:51:20.047] Vidbot :: step[0], label:Initializing Core [14:51:20.085] index :: _onStepProgress_vidbot(), percent: 20 [14:51:20.085] Vidbot :: _parse() [14:51:20.087] index :: _onStepProgress_vidbot(), percent: 40 [14:51:20.087] Vidbot :: _validate() [14:51:20.088] index :: _onStepProgress_vidbot(), percent: 60 [14:51:20.088] Vidbot :: _fonts() [14:51:20.088] FabricFontManager :: add(), id: SourceSansPro-Bold [14:51:20.088] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [14:51:20.097] FabricFontManager :: add(), id: SourceSansPro-Light [14:51:20.097] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [14:51:20.098] FabricFontManager :: add(), id: DINOT-Bold [14:51:20.098] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [14:51:20.099] FabricFontManager :: add(), id: DINOT-Light [14:51:20.100] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [14:51:20.100] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [14:51:20.101] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [14:51:20.101] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [14:51:20.102] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [14:51:20.103] index :: _onStepProgress_vidbot(), percent: 80 [14:51:20.103] Vidbot :: _clips() [14:51:20.104] StreamManager :: add(), id:audio_vo, type:audio [14:51:20.104] AudioClip[audio_vo] :: constructor() [14:51:20.104] InputStream[audio_vo] :: constructor() [14:51:20.105] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [14:51:20.108] StreamManager :: add(), id:bg_music, type:audio [14:51:20.108] AudioClip[bg_music] :: constructor() [14:51:20.108] InputStream[bg_music] :: constructor() [14:51:20.108] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [14:51:20.108] StreamManager :: add(), id:intro, type:video [14:51:20.109] VideoStream[intro] :: constructor() [14:51:20.109] InputStream[intro] :: constructor() [14:51:20.109] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'intro', clipId: null } [14:51:20.109] StreamManager :: add(), id:simplefadedisplay, type:canvas [14:51:20.110] CanvasStream[canvas_1183695440330] :: constructor() [14:51:20.110] InputStream[canvas_1183695440330] :: constructor() [14:51:20.196] KenBurnsSlideshow[simplefadedisplay] :: constructor() [14:51:20.197] Overlay[simplefadedisplay] :: constructor() [14:51:20.197] CanvasClip[simplefadedisplay] :: constructor() [14:51:20.197] Clip[simplefadedisplay] :: constructor() [14:51:20.197] clip:"simplefadedisplay" added to stream:"canvas_1183695440330" [14:51:20.197] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1183695440330', clipId: 'simplefadedisplay' } [14:51:20.198] StreamManager :: add(), id:caption, type:canvas [14:51:20.198] RenCaption[caption] :: constructor() [14:51:20.198] Ren[caption] :: constructor() [14:51:20.198] Overlay[caption] :: constructor() [14:51:20.198] CanvasClip[caption] :: constructor() [14:51:20.198] Clip[caption] :: constructor() [14:51:20.198] clip:"caption" added to stream:"canvas_1183695440330" [14:51:20.198] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1183695440330', clipId: 'caption' } [14:51:20.198] StreamManager :: add(), id:outro, type:video [14:51:20.198] VideoStream[outro] :: constructor() [14:51:20.199] InputStream[outro] :: constructor() [14:51:20.199] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'outro', clipId: null } [14:51:20.199] all added... [14:51:20.199] Vidbot :: _next(), _stepIndex:1 of 4 [14:51:20.199] index :: _onStepCompleted_vidbot(), step: 1 [14:51:20.199] index :: _onStepStarted_vidbot(), step: 2 [14:51:20.200] Vidbot :: step[1], label:Initializing Input Streams [14:51:20.200] StreamManager :: init() [14:51:20.200] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.2 } [14:51:20.201] index :: _onStepProgress_vidbot(), percent: 20 [14:51:20.201] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.4 } [14:51:20.201] index :: _onStepProgress_vidbot(), percent: 40 [14:51:20.201] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'intro', progress: 0.6 } [14:51:20.201] index :: _onStepProgress_vidbot(), percent: 60 [14:51:20.202] CanvasStream[canvas_1183695440330] :: _init(), BEGIN [14:51:20.202] i:0, c.id:simplefadedisplay [14:51:20.202] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [14:51:20.202] KenBurnsSlideshow[simplefadedisplay] :: _validate() [14:51:20.203] KenBurnsSlideshow[undefined] :: _validateAnim() [14:51:20.203] KenBurnsSlideshow[undefined] :: _validateTheme() [14:51:20.204] i:1, c.id:caption [14:51:20.205] RenCaption[caption] :: _init() [14:51:20.205] RenCaption[caption] :: _validate() [14:51:20.206] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'outro', progress: 0.8 } [14:51:20.206] index :: _onStepProgress_vidbot(), percent: 80 [14:51:20.207] KenBurnsSlideshow[simplefadedisplay] :: _build() [14:51:20.213] AnimatedImageFrame[aif] :: constructor() [14:51:20.214] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.214] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_1.jpg [14:51:20.229] RenCaption[caption] :: _build() [14:51:20.251] Overlay[caption] :: _animate() [14:51:20.255] CanvasStream[caption] :: _init(), p.then() [14:51:20.283] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.286] AnimatedImageFrame[aif] :: _init(), END [14:51:20.288] AnimatedImageFrame[aif] :: constructor() [14:51:20.288] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.288] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_2.jpg [14:51:20.332] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.334] AnimatedImageFrame[aif] :: _init(), END [14:51:20.334] AnimatedImageFrame[aif] :: constructor() [14:51:20.335] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.335] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_3.jpg [14:51:20.361] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.362] AnimatedImageFrame[aif] :: _init(), END [14:51:20.363] AnimatedImageFrame[aif] :: constructor() [14:51:20.363] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.363] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_4.jpg [14:51:20.391] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.392] AnimatedImageFrame[aif] :: _init(), END [14:51:20.392] AnimatedImageFrame[aif] :: constructor() [14:51:20.393] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.393] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_5.jpg [14:51:20.416] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.418] AnimatedImageFrame[aif] :: _init(), END [14:51:20.418] AnimatedImageFrame[aif] :: constructor() [14:51:20.418] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.418] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_6.jpg [14:51:20.443] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.444] AnimatedImageFrame[aif] :: _init(), END [14:51:20.445] AnimatedImageFrame[aif] :: constructor() [14:51:20.445] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.445] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_7.jpg [14:51:20.472] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.473] AnimatedImageFrame[aif] :: _init(), END [14:51:20.473] AnimatedImageFrame[aif] :: constructor() [14:51:20.474] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.474] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_8.jpg [14:51:20.498] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.499] AnimatedImageFrame[aif] :: _init(), END [14:51:20.500] AnimatedImageFrame[aif] :: constructor() [14:51:20.500] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.500] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_9.jpg [14:51:20.525] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.526] AnimatedImageFrame[aif] :: _init(), END [14:51:20.527] AnimatedImageFrame[aif] :: constructor() [14:51:20.527] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.527] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_1.jpg [14:51:20.549] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.550] AnimatedImageFrame[aif] :: _init(), END [14:51:20.551] AnimatedImageFrame[aif] :: constructor() [14:51:20.551] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.551] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_2.jpg [14:51:20.573] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.574] AnimatedImageFrame[aif] :: _init(), END [14:51:20.575] AnimatedImageFrame[aif] :: constructor() [14:51:20.575] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.575] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_3.jpg [14:51:20.600] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.601] AnimatedImageFrame[aif] :: _init(), END [14:51:20.601] AnimatedImageFrame[aif] :: constructor() [14:51:20.601] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.602] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_4.jpg [14:51:20.631] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.671] AnimatedImageFrame[aif] :: _init(), END [14:51:20.672] AnimatedImageFrame[aif] :: constructor() [14:51:20.672] AnimatedImageFrame[aif] :: _init(), BEGIN [14:51:20.672] CanvasClip :: LoadImageWithPromise(), src: C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF_5.jpg [14:51:20.695] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:51:20.697] AnimatedImageFrame[aif] :: _init(), END [14:51:20.697] Overlay[simplefadedisplay] :: _animate() [14:51:20.698] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [14:51:20.698] CanvasStream[simplefadedisplay] :: _init(), p.then() [14:51:20.698] CanvasStream[canvas_1183695440330] :: _init(), promise.all.then() [14:51:20.700] CanvasStream[canvas_1183695440330] :: _init(), END [14:51:20.701] StreamMangaer :: init(), stream[canvas_1183695440330].then() [14:51:20.701] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1183695440330', progress: 1 } [14:51:20.701] index :: _onStepProgress_vidbot(), percent: 100 [14:51:20.701] StreamManager :: init(), promise.all.then... [14:51:20.701] Vidbot :: StreamMgr.on( 'INITED' ) [14:51:20.701] Vidbot :: _next(), _stepIndex:2 of 4 [14:51:20.702] index :: _onStepCompleted_vidbot(), step: 2 [14:51:20.702] index :: _onStepStarted_vidbot(), step: 3 [14:51:20.702] Vidbot :: step[2], label:Rendering Canvas Streams [14:51:20.702] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [14:51:20.702] StreamManager :: render() [14:51:20.703] CanvasStream[canvas_1183695440330] :: render() [14:51:20.739] index :: _onStepProgress_vidbot(), percent: 0 [14:51:23.488] index :: _onStepProgress_vidbot(), percent: 5 [14:51:27.259] index :: _onStepProgress_vidbot(), percent: 10 [14:51:30.077] index :: _onStepProgress_vidbot(), percent: 15 [14:51:32.964] index :: _onStepProgress_vidbot(), percent: 20 [14:51:35.798] index :: _onStepProgress_vidbot(), percent: 25 [14:51:38.648] index :: _onStepProgress_vidbot(), percent: 30 [14:51:41.505] index :: _onStepProgress_vidbot(), percent: 35 [14:51:46.209] index :: _onStepProgress_vidbot(), percent: 40 [14:52:12.177] index :: _onStepProgress_vidbot(), percent: 45 [14:52:37.041] index :: _onStepProgress_vidbot(), percent: 50 [14:52:59.221] index :: _onStepProgress_vidbot(), percent: 55 [14:53:20.622] index :: _onStepProgress_vidbot(), percent: 60 [14:53:44.016] index :: _onStepProgress_vidbot(), percent: 65 [14:54:10.077] index :: _onStepProgress_vidbot(), percent: 70 [14:54:35.476] index :: _onStepProgress_vidbot(), percent: 75 [14:54:58.622] index :: _onStepProgress_vidbot(), percent: 80 [14:55:22.012] index :: _onStepProgress_vidbot(), percent: 85 [14:55:45.247] index :: _onStepProgress_vidbot(), percent: 90 [14:56:07.522] index :: _onStepProgress_vidbot(), percent: 95 [14:56:24.013] index :: _onStepProgress_vidbot(), percent: 100 [14:56:24.268] StreamManager :: render(), Promise.all.then... [14:56:24.268] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [14:56:24.269] Vidbot :: _next(), _stepIndex:3 of 4 [14:56:24.269] index :: _onStepCompleted_vidbot(), step: 3 [14:56:24.269] index :: _onStepStarted_vidbot(), step: 4 [14:56:24.270] Vidbot :: step[3], label:Encoding Media [14:56:24.272] VideoStream[intro] :: inputOptions() [14:56:24.273] VideoFilters :: Scale() [14:56:24.273] VideoFilters :: Overlay() [14:56:24.274] CanvasFilters :: Overlay() [14:56:24.274] VideoStream[outro] :: inputOptions() [14:56:24.274] VideoFilters :: Tpad() [14:56:24.274] VideoFilters :: Scale() [14:56:24.274] VideoFilters :: Overlay() [14:56:24.275] AudioStream[audio_vo] :: inputOptions() [14:56:24.275] AudioFilters :: Volume() [14:56:24.275] filter: [4:a]volume=1[4_vol] [14:56:24.275] AudioFilters :: Delay() [14:56:24.275] filter: [4_vol]adelay=28040|28040[4_del] [14:56:24.275] AudioStream[bg_music] :: inputOptions() [14:56:24.275] AudioFilters :: Volume() [14:56:24.276] filter: [5:a]volume=0.25[5_vol] [14:56:24.276] AudioFilters :: FadeOut() [14:56:24.276] filter: [5_vol]afade=t=out:st=40.99:d=1[5_fadeout] [14:56:24.276] AudioFilters :: Delay() [14:56:24.276] filter: [5_fadeout]adelay=28040|28040[5_del] [14:56:24.276] VideoStream[intro] :: inputOptions() [14:56:24.276] AudioFilters :: Volume() [14:56:24.276] filter: [6:a]volume=1[6_vol] [14:56:24.276] AudioFilters :: Delay() [14:56:24.276] filter: [6_vol]adelay=0|0[6_del] [14:56:24.276] VideoStream[outro] :: inputOptions() [14:56:24.276] AudioFilters :: Volume() [14:56:24.276] filter: [7:a]volume=1[7_vol] [14:56:24.276] AudioFilters :: Delay() [14:56:24.277] filter: [7_vol]adelay=69030|69030[7_del] [14:56:24.277] AudioFilters :: Mix() [14:56:24.277] filter: [4_del][5_del][6_del][7_del]amix=inputs=4:duration=longest[a_out] [14:56:24.277] mixed filter: [4_del][5_del][6_del][7_del]amix=inputs=4:duration=longest[a_out] [14:56:24.279] hang.time: 60 [14:56:24.372] Vidbot :: ffmpeg.on( 'start' ) [14:56:24.372] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=75.13 -to 00:00:28.039 -i file:///var/www/html/clients/9067/library/intro.mp4 -r 30 -i ./tmp [14:56:24.372] /canvas_1183695440330_%05d.png -to 00:00:06.099 -i file:///var/www/html/clients/9067/library/outro.mp4 -to 00:00:40.990 -i file:///var/www/html/client [14:56:24.372] s/9067/audio/C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF.mp3 -to 00:00:40.990 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Concept11.mp3 [14:56:24.372] -to 00:00:28.039 -i file:///var/www/html/clients/9067/library/intro.mp4 -to 00:00:06.099 -i file:///var/www/html/clients/9067/library/outro.mp4 -y -f [14:56:24.372] ilter_complex [1:v]scale=w=640:h=360[1_scaled];[0:v][1_scaled]overlay=x=0:y=0:enable='between(t,0,28.04)'[1_out];[1_out][2:v]overlay=x=0:y=0[2_out];[3 [14:56:24.372] :v]tpad=start_duration=68.98[3_tpad];[3_tpad]scale=w=640:h=360[3_scaled];[2_out][3_scaled]overlay=x=0:y=0:enable='between(t,69.03,75.13)'[3_out];[4:a] [14:56:24.372] volume=1[4_vol];[4_vol]adelay=28040|28040[4_del];[5:a]volume=0.25[5_vol];[5_vol]afade=t=out:st=40.99:d=1[5_fadeout];[5_fadeout]adelay=28040|28040[5_de [14:56:24.373] l];[6:a]volume=1[6_vol];[6_vol]adelay=0|0[6_del];[7:a]volume=1[7_vol];[7_vol]adelay=69030|69030[7_del];[4_del][5_del][6_del][7_del]amix=inputs=4:durat [14:56:24.373] ion=longest[a_out] -acodec aac -vcodec libx264 -r 30 -f mp4 -map [a_out] -map [3_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix [14:56:24.373] _fmt yuv420p /var/www/html/clients/9067/video/C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF.mp4 [14:56:24.594] index :: _onStepProgress_vidbot(), percent: -2764872165 [14:56:25.053] index :: _onStepProgress_vidbot(), percent: 1 [14:56:26.041] index :: _onStepProgress_vidbot(), percent: 6 [14:56:27.551] index :: _onStepProgress_vidbot(), percent: 10 [14:56:29.055] index :: _onStepProgress_vidbot(), percent: 15 [14:56:30.562] index :: _onStepProgress_vidbot(), percent: 21 [14:56:31.562] index :: _onStepProgress_vidbot(), percent: 26 [14:56:32.567] index :: _onStepProgress_vidbot(), percent: 30 [14:56:34.071] index :: _onStepProgress_vidbot(), percent: 36 [14:56:35.073] index :: _onStepProgress_vidbot(), percent: 41 [14:56:36.578] index :: _onStepProgress_vidbot(), percent: 46 [14:56:37.579] index :: _onStepProgress_vidbot(), percent: 50 [14:56:39.094] index :: _onStepProgress_vidbot(), percent: 56 [14:56:40.609] index :: _onStepProgress_vidbot(), percent: 62 [14:56:41.602] index :: _onStepProgress_vidbot(), percent: 66 [14:56:42.624] index :: _onStepProgress_vidbot(), percent: 71 [14:56:43.655] index :: _onStepProgress_vidbot(), percent: 76 [14:56:44.681] index :: _onStepProgress_vidbot(), percent: 81 [14:56:45.673] index :: _onStepProgress_vidbot(), percent: 88 [14:56:46.175] index :: _onStepProgress_vidbot(), percent: 90 [14:56:47.175] index :: _onStepProgress_vidbot(), percent: 97 [14:56:47.341] index :: _onStepProgress_vidbot(), percent: 100 [14:56:47.380] Vidbot :: ffmpeg.on( 'end' ), Done! [14:56:47.381] StreamManager :: dispose() [14:56:47.381] CanvasStream[canvas_1183695440330] :: dispose() [14:56:47.387] Vidbot :: fflog.on( 'finish' ) [14:56:47.387] fflog.path: /var/www/html/clients/9067/video/C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF.mp4.fflog [14:56:47.387] Vidbot :: _next(), _stepIndex:4 of 4 [14:56:47.387] index :: _onStepCompleted_vidbot(), step: 4 [14:56:47.387] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 327.363, output: '/var/www/html/clients/9067/video/C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF.mp4', duration: 75.13 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/9067/video/C6AF85E1-FEFA-6DB7-FCF4-9E4228DD64BF.mp4 Media Duration : 00:01:15.129 Generation Time : 00:05:27.362 ---------------------------------------------------------------------------------------------------------------