--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [23:31:19.931] Vidbot :: start() [23:31:19.932] Vidbot :: _next(), _stepIndex:0 of 4 [23:31:19.932] index :: _onStepStarted_vidbot(), step: 1 [23:31:19.933] Vidbot :: step[0], label:Initializing Core [23:31:19.942] index :: _onStepProgress_vidbot(), percent: 20 [23:31:19.942] Vidbot :: _parse() [23:31:19.943] index :: _onStepProgress_vidbot(), percent: 40 [23:31:19.943] Vidbot :: _validate() [23:31:19.944] index :: _onStepProgress_vidbot(), percent: 60 [23:31:19.944] Vidbot :: _fonts() [23:31:19.945] FabricFontManager :: add(), id: SourceSansPro-Bold [23:31:19.945] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [23:31:19.953] FabricFontManager :: add(), id: SourceSansPro-Light [23:31:19.953] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [23:31:19.954] FabricFontManager :: add(), id: DINOT-Bold [23:31:19.954] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [23:31:19.955] FabricFontManager :: add(), id: DINOT-Light [23:31:19.955] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [23:31:19.955] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [23:31:19.955] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [23:31:19.956] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [23:31:19.956] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [23:31:19.957] index :: _onStepProgress_vidbot(), percent: 80 [23:31:19.957] Vidbot :: _clips() [23:31:19.958] StreamManager :: add(), id:audio_vo, type:audio [23:31:19.958] AudioClip[audio_vo] :: constructor() [23:31:19.959] InputStream[audio_vo] :: constructor() [23:31:19.959] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [23:31:19.961] StreamManager :: add(), id:bg_music, type:audio [23:31:19.962] AudioClip[bg_music] :: constructor() [23:31:19.962] InputStream[bg_music] :: constructor() [23:31:19.962] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [23:31:19.962] StreamManager :: add(), id:simplefadedisplay, type:canvas [23:31:19.962] CanvasStream[canvas_1476138649356] :: constructor() [23:31:19.963] InputStream[canvas_1476138649356] :: constructor() [23:31:20.037] KenBurnsSlideshow[simplefadedisplay] :: constructor() [23:31:20.037] Overlay[simplefadedisplay] :: constructor() [23:31:20.037] CanvasClip[simplefadedisplay] :: constructor() [23:31:20.037] Clip[simplefadedisplay] :: constructor() [23:31:20.037] clip:"simplefadedisplay" added to stream:"canvas_1476138649356" [23:31:20.038] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1476138649356', clipId: 'simplefadedisplay' } [23:31:20.038] StreamManager :: add(), id:caption, type:canvas [23:31:20.038] RenCaption[caption] :: constructor() [23:31:20.038] Ren[caption] :: constructor() [23:31:20.038] Overlay[caption] :: constructor() [23:31:20.038] CanvasClip[caption] :: constructor() [23:31:20.038] Clip[caption] :: constructor() [23:31:20.038] clip:"caption" added to stream:"canvas_1476138649356" [23:31:20.038] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1476138649356', clipId: 'caption' } [23:31:20.038] all added... [23:31:20.039] Vidbot :: _next(), _stepIndex:1 of 4 [23:31:20.039] index :: _onStepCompleted_vidbot(), step: 1 [23:31:20.039] index :: _onStepStarted_vidbot(), step: 2 [23:31:20.039] Vidbot :: step[1], label:Initializing Input Streams [23:31:20.040] StreamManager :: init() [23:31:20.040] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [23:31:20.040] index :: _onStepProgress_vidbot(), percent: 33 [23:31:20.040] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [23:31:20.040] index :: _onStepProgress_vidbot(), percent: 67 [23:31:20.041] CanvasStream[canvas_1476138649356] :: _init(), BEGIN [23:31:20.041] i:0, c.id:simplefadedisplay [23:31:20.041] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [23:31:20.042] KenBurnsSlideshow[simplefadedisplay] :: _validate() [23:31:20.042] KenBurnsSlideshow[undefined] :: _validateAnim() [23:31:20.043] KenBurnsSlideshow[undefined] :: _validateTheme() [23:31:20.044] i:1, c.id:caption [23:31:20.044] RenCaption[caption] :: _init() [23:31:20.044] RenCaption[caption] :: _validate() [23:31:20.045] KenBurnsSlideshow[simplefadedisplay] :: _build() [23:31:20.058] AnimatedImageFrame[aif] :: constructor() [23:31:20.059] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.059] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_1.jpg [23:31:20.072] RenCaption[caption] :: _build() [23:31:20.092] Overlay[caption] :: _animate() [23:31:20.094] CanvasStream[caption] :: _init(), p.then() [23:31:20.116] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.120] AnimatedImageFrame[aif] :: _init(), END [23:31:20.122] AnimatedImageFrame[aif] :: constructor() [23:31:20.122] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.122] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_2.jpg [23:31:20.141] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.143] AnimatedImageFrame[aif] :: _init(), END [23:31:20.143] AnimatedImageFrame[aif] :: constructor() [23:31:20.144] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.144] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_3.jpg [23:31:20.164] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.165] AnimatedImageFrame[aif] :: _init(), END [23:31:20.166] AnimatedImageFrame[aif] :: constructor() [23:31:20.166] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.166] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_4.jpg [23:31:20.182] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.183] AnimatedImageFrame[aif] :: _init(), END [23:31:20.184] AnimatedImageFrame[aif] :: constructor() [23:31:20.184] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.184] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_5.jpg [23:31:20.203] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.204] AnimatedImageFrame[aif] :: _init(), END [23:31:20.205] AnimatedImageFrame[aif] :: constructor() [23:31:20.205] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.205] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_6.jpg [23:31:20.223] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.224] AnimatedImageFrame[aif] :: _init(), END [23:31:20.225] AnimatedImageFrame[aif] :: constructor() [23:31:20.225] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.225] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_7.jpg [23:31:20.249] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.250] AnimatedImageFrame[aif] :: _init(), END [23:31:20.251] AnimatedImageFrame[aif] :: constructor() [23:31:20.251] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.251] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_8.jpg [23:31:20.269] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.270] AnimatedImageFrame[aif] :: _init(), END [23:31:20.271] AnimatedImageFrame[aif] :: constructor() [23:31:20.271] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.271] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_9.jpg [23:31:20.292] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.293] AnimatedImageFrame[aif] :: _init(), END [23:31:20.294] AnimatedImageFrame[aif] :: constructor() [23:31:20.294] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.294] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_10.jpg [23:31:20.314] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.315] AnimatedImageFrame[aif] :: _init(), END [23:31:20.315] AnimatedImageFrame[aif] :: constructor() [23:31:20.315] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.315] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_11.jpg [23:31:20.338] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.339] AnimatedImageFrame[aif] :: _init(), END [23:31:20.340] AnimatedImageFrame[aif] :: constructor() [23:31:20.340] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.340] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_12.jpg [23:31:20.353] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.354] AnimatedImageFrame[aif] :: _init(), END [23:31:20.355] AnimatedImageFrame[aif] :: constructor() [23:31:20.355] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.355] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_13.jpg [23:31:20.375] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.376] AnimatedImageFrame[aif] :: _init(), END [23:31:20.376] AnimatedImageFrame[aif] :: constructor() [23:31:20.376] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.377] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_14.jpg [23:31:20.408] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.408] AnimatedImageFrame[aif] :: _init(), END [23:31:20.409] AnimatedImageFrame[aif] :: constructor() [23:31:20.409] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.409] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_15.jpg [23:31:20.427] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.428] AnimatedImageFrame[aif] :: _init(), END [23:31:20.429] AnimatedImageFrame[aif] :: constructor() [23:31:20.429] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.429] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_16.jpg [23:31:20.448] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.449] AnimatedImageFrame[aif] :: _init(), END [23:31:20.450] AnimatedImageFrame[aif] :: constructor() [23:31:20.450] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.450] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_17.jpg [23:31:20.471] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.472] AnimatedImageFrame[aif] :: _init(), END [23:31:20.472] AnimatedImageFrame[aif] :: constructor() [23:31:20.472] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.473] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_18.jpg [23:31:20.489] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.490] AnimatedImageFrame[aif] :: _init(), END [23:31:20.491] AnimatedImageFrame[aif] :: constructor() [23:31:20.491] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.491] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_19.jpg [23:31:20.512] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.513] AnimatedImageFrame[aif] :: _init(), END [23:31:20.514] AnimatedImageFrame[aif] :: constructor() [23:31:20.514] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.514] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_20.jpg [23:31:20.532] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.533] AnimatedImageFrame[aif] :: _init(), END [23:31:20.534] AnimatedImageFrame[aif] :: constructor() [23:31:20.534] AnimatedImageFrame[aif] :: _init(), BEGIN [23:31:20.534] CanvasClip :: LoadImageWithPromise(), src: BB145B09-6E81-1C57-2CD1-EFF78C93DC84_1.jpg [23:31:20.550] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [23:31:20.551] AnimatedImageFrame[aif] :: _init(), END [23:31:20.552] Overlay[simplefadedisplay] :: _animate() [23:31:20.552] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [23:31:20.552] CanvasStream[simplefadedisplay] :: _init(), p.then() [23:31:20.553] CanvasStream[canvas_1476138649356] :: _init(), promise.all.then() [23:31:20.554] CanvasStream[canvas_1476138649356] :: _init(), END [23:31:20.555] StreamMangaer :: init(), stream[canvas_1476138649356].then() [23:31:20.555] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1476138649356', progress: 1 } [23:31:20.555] index :: _onStepProgress_vidbot(), percent: 100 [23:31:20.555] StreamManager :: init(), promise.all.then... [23:31:20.555] Vidbot :: StreamMgr.on( 'INITED' ) [23:31:20.555] Vidbot :: _next(), _stepIndex:2 of 4 [23:31:20.555] index :: _onStepCompleted_vidbot(), step: 2 [23:31:20.555] index :: _onStepStarted_vidbot(), step: 3 [23:31:20.556] Vidbot :: step[2], label:Rendering Canvas Streams [23:31:20.556] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [23:31:20.556] StreamManager :: render() [23:31:20.557] CanvasStream[canvas_1476138649356] :: render() [23:31:20.589] index :: _onStepProgress_vidbot(), percent: 0 [23:31:36.257] index :: _onStepProgress_vidbot(), percent: 5 [23:31:54.402] index :: _onStepProgress_vidbot(), percent: 10 [23:32:13.647] index :: _onStepProgress_vidbot(), percent: 15 [23:32:28.345] index :: _onStepProgress_vidbot(), percent: 20 [23:32:47.411] index :: _onStepProgress_vidbot(), percent: 25 [23:33:04.408] index :: _onStepProgress_vidbot(), percent: 30 [23:33:21.302] index :: _onStepProgress_vidbot(), percent: 35 [23:33:38.204] index :: _onStepProgress_vidbot(), percent: 40 [23:33:56.410] index :: _onStepProgress_vidbot(), percent: 45 [23:34:15.217] index :: _onStepProgress_vidbot(), percent: 50 [23:34:35.546] index :: _onStepProgress_vidbot(), percent: 55 [23:34:47.263] index :: _onStepProgress_vidbot(), percent: 60 [23:35:03.847] index :: _onStepProgress_vidbot(), percent: 65 [23:35:23.428] index :: _onStepProgress_vidbot(), percent: 70 [23:35:41.678] index :: _onStepProgress_vidbot(), percent: 75 [23:36:00.513] index :: _onStepProgress_vidbot(), percent: 80 [23:36:23.032] index :: _onStepProgress_vidbot(), percent: 85 [23:36:40.924] index :: _onStepProgress_vidbot(), percent: 90 [23:36:54.427] index :: _onStepProgress_vidbot(), percent: 95 [23:37:13.738] index :: _onStepProgress_vidbot(), percent: 100 [23:37:15.968] StreamManager :: render(), Promise.all.then... [23:37:15.968] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [23:37:15.968] Vidbot :: _next(), _stepIndex:3 of 4 [23:37:15.968] index :: _onStepCompleted_vidbot(), step: 3 [23:37:15.969] index :: _onStepStarted_vidbot(), step: 4 [23:37:15.970] Vidbot :: step[3], label:Encoding Media [23:37:15.972] CanvasFilters :: Overlay() [23:37:15.972] AudioStream[audio_vo] :: inputOptions() [23:37:15.973] AudioFilters :: Volume() [23:37:15.973] filter: [2:a]volume=1[2_vol] [23:37:15.973] AudioFilters :: Delay() [23:37:15.973] filter: [2_vol]adelay=0|0[2_del] [23:37:15.973] AudioStream[bg_music] :: inputOptions() [23:37:15.973] AudioFilters :: Volume() [23:37:15.973] filter: [3:a]volume=0.25[3_vol] [23:37:15.973] AudioFilters :: FadeOut() [23:37:15.974] filter: [3_vol]afade=t=out:st=60.2:d=1[3_fadeout] [23:37:15.974] AudioFilters :: Delay() [23:37:15.974] filter: [3_fadeout]adelay=0|0[3_del] [23:37:15.974] AudioFilters :: Mix() [23:37:15.974] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [23:37:15.974] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [23:37:15.977] hang.time: 60 [23:37:16.086] Vidbot :: ffmpeg.on( 'start' ) [23:37:16.087] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60.2 -r 30 -i ./tmp/canvas_1476138649356_%05d.png -to 00:01:00.200 -i file:///var/www/html/c [23:37:16.087] lients/10231/audio/BB145B09-6E81-1C57-2CD1-EFF78C93DC84.mp3 -to 00:01:00.200 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Hip Hop [23:37:16.087] -3.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]afade=t=out:st [23:37:16.087] =60.2: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 mp4 -map [a [23:37:16.087] _out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/10231/video/BB145B09-6E81-1C57-2 [23:37:16.087] CD1-EFF78C93DC84.mp4 [23:37:16.263] index :: _onStepProgress_vidbot(), percent: -3450578833 [23:37:16.687] index :: _onStepProgress_vidbot(), percent: 1 [23:37:17.693] index :: _onStepProgress_vidbot(), percent: 5 [23:37:18.707] index :: _onStepProgress_vidbot(), percent: 11 [23:37:19.733] index :: _onStepProgress_vidbot(), percent: 15 [23:37:20.741] index :: _onStepProgress_vidbot(), percent: 20 [23:37:21.753] index :: _onStepProgress_vidbot(), percent: 25 [23:37:22.754] index :: _onStepProgress_vidbot(), percent: 30 [23:37:23.773] index :: _onStepProgress_vidbot(), percent: 35 [23:37:24.793] index :: _onStepProgress_vidbot(), percent: 42 [23:37:25.309] index :: _onStepProgress_vidbot(), percent: 45 [23:37:26.322] index :: _onStepProgress_vidbot(), percent: 50 [23:37:27.329] index :: _onStepProgress_vidbot(), percent: 57 [23:37:27.836] index :: _onStepProgress_vidbot(), percent: 61 [23:37:28.850] index :: _onStepProgress_vidbot(), percent: 66 [23:37:29.860] index :: _onStepProgress_vidbot(), percent: 71 [23:37:30.873] index :: _onStepProgress_vidbot(), percent: 76 [23:37:31.885] index :: _onStepProgress_vidbot(), percent: 81 [23:37:32.895] index :: _onStepProgress_vidbot(), percent: 86 [23:37:33.909] index :: _onStepProgress_vidbot(), percent: 92 [23:37:34.412] index :: _onStepProgress_vidbot(), percent: 95 [23:37:35.085] index :: _onStepProgress_vidbot(), percent: 100 [23:37:35.125] Vidbot :: ffmpeg.on( 'end' ), Done! [23:37:35.126] StreamManager :: dispose() [23:37:35.126] CanvasStream[canvas_1476138649356] :: dispose() [23:37:35.131] Vidbot :: fflog.on( 'finish' ) [23:37:35.131] fflog.path: /var/www/html/clients/10231/video/BB145B09-6E81-1C57-2CD1-EFF78C93DC84.mp4.fflog [23:37:35.131] Vidbot :: _next(), _stepIndex:4 of 4 [23:37:35.131] index :: _onStepCompleted_vidbot(), step: 4 [23:37:35.132] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 375.219, output: '/var/www/html/clients/10231/video/BB145B09-6E81-1C57-2CD1-EFF78C93DC84.mp4', duration: 60.2 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/10231/video/BB145B09-6E81-1C57-2CD1-EFF78C93DC84.mp4 Media Duration : 00:01:00.200 Generation Time : 00:06:15.218 ---------------------------------------------------------------------------------------------------------------