rx-player
Version:
Canal+ HTML5 Video Player
70 lines (65 loc) • 2.03 kB
text/typescript
/**
* Copyright 2015 CANAL+ Group
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import log from "../log";
import type { IEventEmitter } from "../utils/event_emitter";
interface ICompatSourceBufferEvents {
updatestart: Event | undefined;
update: Event | undefined;
updateend: Event | undefined;
error: Event;
}
/**
* Definition of a SourceBuffer Object.
* Adds some non-standard APIs to the regular one like `changeType`, which exist
* on some browsers.
*/
export interface ICompatSourceBuffer extends IEventEmitter<ICompatSourceBufferEvents> {
buffered: TimeRanges;
changeType?: (type: string) => void;
updating: boolean;
appendWindowStart: number;
appendWindowEnd: number;
timestampOffset: number;
appendBuffer(data: BufferSource): void;
remove(from: number, to: number): void;
abort(): void;
}
/**
* If the changeType MSE API is implemented, update the current codec of the
* SourceBuffer and return true if it succeeded.
* In any other cases, return false.
* @param {Object} sourceBuffer
* @param {string} codec
* @returns {boolean}
*/
export default function tryToChangeSourceBufferType(
sourceBuffer: ICompatSourceBuffer,
codec: string,
): boolean {
if (typeof sourceBuffer.changeType === "function") {
try {
sourceBuffer.changeType(codec);
} catch (e) {
log.warn(
"Could not call 'changeType' on the given SourceBuffer:",
e instanceof Error ? e : "",
);
return false;
}
return true;
}
return false;
}