Skip to content

Instantly share code, notes, and snippets.

Working from home

Erik Hellman ErikHellman

Working from home
View GitHub Profile
ErikHellman / MarkdownComposer.kt
Last active Oct 20, 2021
A simple rendered for Markdown text parsed using CommonMarks
View MarkdownComposer.kt
package se.hellsoft.markdowncomposer
import android.util.Log
import androidx.compose.material.Colors
ErikHellman / TextFieldText.dart
Last active Apr 2, 2020
Testing the TextField decoration
View TextFieldText.dart
import 'package:flutter/material.dart';
final Color darkBlue = Color.fromARGB(255, 18, 32, 47);
void main() {
class MyApp extends StatelessWidget {
ErikHellman / LoginScreenWithCompose.kt
Created Dec 16, 2019
A simple demo of using Jetpack Compose to build a Login screen
View LoginScreenWithCompose.kt
package se.hellsoft.jetpackcomposeintro
import android.os.Bundle
import androidx.compose.Composable
import androidx.compose.Model
import androidx.compose.state
import androidx.compose.unaryPlus
import androidx.ui.core.*
ErikHellman / KittyLog.kt
Last active Apr 1, 2022
A super tiny wrapper for Android Log utility that allows log printing in unit tests. For a more advanced log wrapper for Android, see
View KittyLog.kt
Licensed under Apache 2.0 (
This is a tiny log utility for Android Logcat. It allows logs to be used in code that is unit
tested on host (without Android framework available).
The only advantage with this utility above Timber is that it doesn't require any setup.
For real-world, production application I strongly recommend using Timber (see instead.
ErikHellman / KittyLog.kt
Created Aug 19, 2019
A super tiny wrapper for Android Log utility.
View KittyLog.kt
package se.hellsoft.coroutineantipatterns
import android.util.Log
internal const val TAG = "KittyLog"
fun logi(message: String, throwable: Throwable? = null) {
try {
ErikHellman / NonBlockingEchoServer.kt
Last active Sep 7, 2020
A very simple example of an echo-server using the non-blocking Java I/O APIs
View NonBlockingEchoServer.kt
package se.hellsoft.nonblocking.echo
import java.nio.ByteBuffer
import java.nio.channels.SelectionKey
import java.nio.channels.Selector
import java.nio.channels.ServerSocketChannel
import java.nio.channels.SocketChannel
ErikHellman / ImageFormatName.kt
Last active Aug 8, 2019
Kotlin functions for getting the name of an ImageFormat or PixelFormat Integer.
View ImageFormatName.kt
fun imageFormatName(format: Int): String = when (format) {
ImageFormat.DEPTH16 -> "DEPTH16"
ImageFormat.FLEX_RGBA_8888 -> "FLEX_RGBA_8888"
ImageFormat.FLEX_RGB_888 -> "FLEX_RGB_888"
ImageFormat.HEIC -> "HEIC"
ImageFormat.JPEG -> "JPEG"
ImageFormat.NV16 -> "NV16"
ImageFormat.NV21 -> "NV21"
ErikHellman / WebViewServer.kt
Last active Jan 25, 2022
This class is no longer needed now that Google provides WebViewAssetLoader (see
View WebViewServer.kt
MIT License
Copyright (c) 2019 Erik Hellman
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
ErikHellman / WebViewServer.kt
Created Apr 8, 2019
A simple "web server" for handling intercepted WebView requests on Android and deliver local content.
View WebViewServer.kt
package se.hellsoft.webviewserver
import android.content.res.AssetManager
import android.webkit.WebResourceRequest
import android.webkit.WebResourceResponse
ErikHellman / generateSelector.js
Last active Jan 10, 2019
Generate a selector for an element.
View generateSelector.js
// Create a path to an element of the form 2/1/1/34 (index of each child)
function getDomPath(el) {
const stack = [];
while (el.parentNode != null) {
let sibCount = 0;
let sibIndex = 0;
for (let i = 0; i < el.parentNode.childNodes.length; i++) {
const sib = el.parentNode.childNodes[i];
if (sib === el) {